--- bin/ldap.pl 2008/03/16 21:32:39 22 +++ bin/ldap.pl 2008/03/31 21:50:52 48 @@ -6,68 +6,27 @@ use lib 'lib'; use Jifty; -use Net::LDAP; +use A3C::LDAP; use Data::Dump qw/dump/; use Getopt::Long; BEGIN { Jifty->new; }; my $limit = 0; +my @models; GetOptions( 'limit=i', => \$limit, + 'model=s', => \@models, ); -my $ldap_config = Jifty->config->app('LDAP'); -Jifty->log->debug( "config->app(LDAP) = ",dump( $ldap_config ) ); +@models = ( 'Organization' ) unless @models; -my $ldap = Net::LDAP->new( $ldap_config->{Server} ) or die "$@"; +my $ldap = A3C::LDAP->new; -# an anonymous bind -#my $mesg = $ldap->bind; -my $mesg = $ldap->bind( $ldap_config->{DN}, password => $ldap_config->{Password} ); - -Jifty->log->info("Connected to ", $ldap_config->{Server}, " with DN ", $ldap_config->{DN}); - -# perform a search -$mesg = $ldap->search( - base => "dc=skole,dc=hr", -# filter => "(&(sn=Barr) (o=Texas Instruments))", - filter => "(objectClass=hrEduPerson)", - sizelimit => $limit, # 0 = off -); - -if ( $mesg->code ) { - Jifty->log->error( $mesg->code, ": ", $mesg->error ); -} - -Jifty->log->info( "found ", $mesg->count, " entries" ); - -foreach my $entry ( $mesg->entries ) { - -# $entry->dump; - - my $data; - my $user = A3C::Model::User->new; - - my @columns = map { $_->name } $user->columns; - #warn "# columns = ",dump( @columns ); - - foreach my $attr ( $entry->attributes ) { - if ( grep(/^\Q$attr\E$/, @columns ) ) { - $data->{$attr} = $entry->get_value( $attr ); - } else { - Jifty->log->error(ref($user)," doesn't have $attr"); - } - } - - Jifty->log->debug( dump( $data ) ); - - my ( $id, $message ) = $user->load_or_create( %$data ); +Jifty->log->info( 'syncing: ', join(',', @models) ); - if ( $id ) { - Jifty->log->info("added $id ", $data->{uid}); - } else { - Jifty->log->error( $message ); - } +foreach my $model ( @models ) { + my $collection = $ldap->collection( $model, limit => $limit ); + Jifty->log->info( "found ", $collection->count, " entries for $model" ); }