diff options
| author | Russ Allbery <rra@stanford.edu> | 2007-09-19 23:28:48 +0000 | 
|---|---|---|
| committer | Russ Allbery <rra@stanford.edu> | 2007-09-19 23:28:48 +0000 | 
| commit | 94e80cab6d728120be83b4dec42d820c312ee6a5 (patch) | |
| tree | d8cc170f4a6c274ba4157c1ce6aec2c1e33454b9 /perl | |
| parent | a5596f996b55be41659e32b6e5ec41d71d9c0d81 (diff) | |
Add generic attribute support to the object layer and update the API
documentation to talk about overriding it.  Update some other bits of
the API documentation to include more hints about how to handle
overridden methods.
Diffstat (limited to 'perl')
| -rw-r--r-- | perl/Wallet/Object/Base.pm | 31 | ||||
| -rwxr-xr-x | perl/t/object.t | 8 | 
2 files changed, 38 insertions, 1 deletions
| diff --git a/perl/Wallet/Object/Base.pm b/perl/Wallet/Object/Base.pm index 10864b7..b366d6e 100644 --- a/perl/Wallet/Object/Base.pm +++ b/perl/Wallet/Object/Base.pm @@ -271,6 +271,19 @@ sub acl {      }  } +# Get or set an attribute on an object.  Takes the name of the attribute and, +# if setting, the values and trace information.  The values must be provided +# as a reference to an array, even if there is only one value. +# +# Attributes are used by backends for backend-specific information (such as +# enctypes for a keytab).  The default implementation rejects all attribute +# names as unknown. +sub attr { +    my ($self, $attr, $values, $user, $host, $time) = @_; +    $self->error ("unknown attribute $attr"); +    return; +} +  # Get or set the expires value of an object.  Expects an expiration time in  # seconds since epoch.  If setting the expiration, trace information must also  # be provided. @@ -625,6 +638,24 @@ false on failure.  Pass in the empty string for ACL to clear the ACL.  The  other arguments are used for logging and history and should indicate the  user and host from which the change is made and the time of the change. +=item attr(ATTRIBUTE [, VALUES, PRINCIPAL, HOSTNAME [, DATETIME]]) + +Sets or retrieves a given object attribute.  Attributes are used to store +backend-specific information for a particular object type and ATTRIBUTE must +be an attribute type known to the underlying object implementation.  The +default implementation of this method rejects all attributes as unknown. + +If no other arguments besides ATTRIBUTE are given, returns the values of +that attribute, if any, as a list.  On error, returns a list containing one +undefined element. + +If other arguments are given, sets the given ATTRIBUTE values to VALUES, +which must be a reference to an array (even if only one value is being set). +Pass a reference to an empty array to clear the attribute values.  The other +arguments are used for logging and history and should indicate the user and +host from which the change is made and the time of the change.  Returns true +on success and false on failure. +  =item destroy(PRINCIPAL, HOSTNAME [, DATETIME])  Destroys the object by removing all record of it from the database.  The diff --git a/perl/t/object.t b/perl/t/object.t index 73efbb7..a69101e 100755 --- a/perl/t/object.t +++ b/perl/t/object.t @@ -3,7 +3,7 @@  #  # t/object.t -- Tests for the basic object implementation. -use Test::More tests => 125; +use Test::More tests => 129;  use Wallet::ACL;  use Wallet::Config; @@ -150,6 +150,12 @@ if ($object->flag_set ('locked', @trace)) {      is ($object->error, '', ' and setting it again works');  } +# Attributes.  Very boring. +is ($object->attr ('foo'), undef, 'Retrieving an attribute fails'); +is ($object->error, 'unknown attribute foo', ' with the right error'); +is ($object->attr ('foo', [ 'foo' ], @trace), undef, ' and setting fails'); +is ($object->error, 'unknown attribute foo', ' with the right error'); +  # Test stub methods and locked status.  is ($object->store ("Some data", @trace), undef, 'Store fails');  is ($object->error, "cannot store keytab:${princ}: object is locked", | 
