--- bin/ldap.pl 2008/03/31 21:50:52 48 +++ bin/ldap.pl 2008/04/09 21:32:34 61 @@ -11,6 +11,8 @@ use Getopt::Long; BEGIN { Jifty->new; }; +Jifty->web->request(Jifty::Request->new); +Jifty->web->response(Jifty::Response->new); my $limit = 0; my @models; @@ -19,14 +21,38 @@ 'model=s', => \@models, ); -@models = ( 'Organization' ) unless @models; - my $ldap = A3C::LDAP->new; -Jifty->log->info( 'syncing: ', join(',', @models) ); +if ( @models ) { -foreach my $model ( @models ) { - my $collection = $ldap->collection( $model, limit => $limit ); - Jifty->log->info( "found ", $collection->count, " entries for $model" ); -} + Jifty->log->info( 'syncing: ', join(',', @models) ); + foreach my $model ( @models ) { + my $collection = $ldap->collection( $model, limit => $limit ); + Jifty->log->info( 'found ', $collection->count, ' entries for ', $model ); + } +} else { + + Jifty->log->info( 'syncing all organizations and users' ); + + my $orgs = $ldap->collection( 'Organization', limit => $limit ); + + my $o_nr = 1; + + while ( my $o = $orgs->next ) { + Jifty->log->info( 'sync organization ', $o_nr++, '/', $orgs->count, ' ', $o->name ); + my $action = Jifty->web->new_action( + class => 'SyncOrganization', + moniker => 'sync', + arguments => { + cn => $o->cn, + } + ); + $action->run; + if ( $action->result->success ) { + Jifty->log->info( $action->result->message ); + } else { + Jifty->log->error( "Can't sync ", $o->name ); + } + } +}