diff options
author | Russ Allbery <rra@stanford.edu> | 2007-12-07 00:01:16 +0000 |
---|---|---|
committer | Russ Allbery <rra@stanford.edu> | 2007-12-07 00:01:16 +0000 |
commit | 026a0c50f1b0907d25291b6651c18886e2971d1f (patch) | |
tree | 40f4581c29eb44a8707e0e3d3da5d37bd8866bec /perl/Wallet/ACL.pm | |
parent | 800d3067e3d95d9f3e744444e271f118e7632295 (diff) |
Load the Perl modules for ACL verifiers and object types dynamically
now that we're reading the class from the database.
Diffstat (limited to 'perl/Wallet/ACL.pm')
-rw-r--r-- | perl/Wallet/ACL.pm | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/perl/Wallet/ACL.pm b/perl/Wallet/ACL.pm index f9a163b..7830523 100644 --- a/perl/Wallet/ACL.pm +++ b/perl/Wallet/ACL.pm @@ -18,12 +18,11 @@ use vars qw($VERSION); use DBI; use POSIX qw(strftime); -use Wallet::ACL::Krb5; # This version should be increased on any code change to this module. Always # use two digits for the minor version with a leading zero if necessary so # that it will sort properly. -$VERSION = '0.03'; +$VERSION = '0.04'; ############################################################################## # Constructors @@ -129,7 +128,7 @@ sub name { } # Given an ACL scheme, return the mapping to a class by querying the -# database, or undef if no mapping exists. +# database, or undef if no mapping exists. Also load the relevant module. sub scheme_mapping { my ($self, $scheme) = @_; my $class; @@ -143,6 +142,17 @@ sub scheme_mapping { $self->{dbh}->rollback; return; } + if (defined $class) { + if ($class !~ /^Wallet::ACL::(\w+::)*\w+\z/) { + $self->error ("invalid class name $class for scheme $scheme"); + return; + } + eval "require $class"; + if ($@) { + $self->error ($@); + return; + } + } return $class; } |