# Copyright (c) 2008 Mathieu Parent . All rights reserved. # This program is free software; you can redistribute it and/or # modify it under the same terms as Perl itself. package Net::LDAP::Control::SyncState; use vars qw(@ISA $VERSION); use Net::LDAP::Control; @ISA = qw(Net::LDAP::Control); $VERSION = "0.02"; use Net::LDAP::ASN qw(syncStateValue); use strict; sub init { my($self) = @_; if (exists $self->{value}) { $self->{asn} = $syncStateValue->decode(delete $self->{value}); } else { $self->{asn} = { state => $self->{state} || '', entryUUID => $self->{entryUUID} || '', cookie => defined($self->{cookie}) ? $self->{cookie} : '', }; } $self; } sub state { my $self = shift; $self->{asn} ||= $syncStateValue->decode($self->{value}); if (@_) { delete $self->{value}; return $self->{asn}{state} = shift || 0; } $self->{asn}{state}; } sub entryUUID { my $self = shift; $self->{asn} ||= $syncStateValue->decode($self->{value}); if (@_) { delete $self->{value}; return $self->{asn}{entryUUID} = shift || 0; } $self->{asn}{entryUUID}; } sub cookie { my $self = shift; $self->{asn} ||= $syncStateValue->decode($self->{value}); if (@_) { delete $self->{value}; return $self->{asn}{cookie} = shift || 0; } $self->{asn}{cookie}; } sub value { my $self = shift; exists $self->{value} ? $self->{value} : $self->{value} = $syncStateValue->encode($self->{asn}); } 1; __END__ =head1 NAME Net::LDAP::Control::SyncState - LDAPv3 Sync State control object =head1 SYNOPSIS use Net::LDAP; use Net::LDAP::Control::SyncRequest; use Net::LDAP::Constant qw( LDAP_SYNC_REFRESH_ONLY LDAP_SYNC_REFRESH_AND_PERSIST LDAP_SUCCESS ); $ldap = Net::LDAP->new( "ldap.mydomain.eg" ); $req = Net::LDAP::Control::SyncRequest->new( mode => LDAP_SYNC_REFRESH_ONLY ); my $mesg = $ldap->search(base=> 'dc=mydomain,dc='eg', scope => 'sub', control => [ $req ], callback => \&searchCallback, # call for each entry filter => "(objectClass=*)", attrs => [ '*']); sub searchCallback { my $message = shift; my $entry = shift; my @controls = $message->control; if($controls[0]->isa('Net::LDAP::Control::SyncState')) { print "Received Sync State Control\n"; print $entry->dn()."\n"; print 'State: '.$controls[0]->state."\n".', entryUUID: '.$controls[0]->entryUUID.', cookie: '.$controls[0]->cookie; } elsif($controls[0]->isa('Net::LDAP::Control::SyncDone')) { print "Received Sync Done Control\n"; print 'Cookie: '.$controls[0]->cookie.', refreshDeletes: '.$controls[0]->refreshDeletes; } } =head1 DESCRIPTION C provides an interface for the creation and manipulation of objects that represent the C as described by RFC 4533. =head1 CONSTRUCTOR ARGUMENTS In addition to the constructor arguments described in L the following are provided. =over 4 =item state =item entryUIID =item cookie =back =head1 METHODS As with L each constructor argument described above is also avaliable as a method on the object which will return the current value for the attribute if called without an argument, and set a new value for the attribute if called with an argument. =head1 SEE ALSO L, L, L, L, http://www.ietf.org/rfc/rfc4533.txt =head1 AUTHOR Mathieu Parent Emath.parent@gmail.comE Please report any bugs, or post any suggestions, to the perl-ldap mailing list Eperl-ldap@perl.orgE =head1 COPYRIGHT Copyright (c) 2008 Mathieu Parent. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut