source: LATMOS-Accounts/lib/LATMOS/Accounts/Bases/Sql/Address.pm @ 443

Last change on this file since 443 was 443, checked in by nanardon, 15 years ago
  • manage from address object attributes sn,givenName and mail, this will be needed to map address into ldap
File size: 3.0 KB
Line 
1package LATMOS::Accounts::Bases::Sql::Address;
2
3use 5.010000;
4use strict;
5use warnings;
6
7use base qw(LATMOS::Accounts::Bases::Sql::objects);
8
9our $VERSION = (q$Rev: 594 $ =~ /^Rev: (\d+) /)[0];
10
11=head1 NAME
12
13LATMOS::Ad - Perl extension for blah blah blah
14
15=head1 SYNOPSIS
16
17  use LATMOS::Accounts::Bases;
18  my $base = LATMOS::Accounts::Bases->new('sql');
19  ...
20
21=head1 DESCRIPTION
22
23Account base access over standard unix file format.
24
25=head1 FUNCTIONS
26
27=cut
28
29=head2 new(%options)
30
31Create a new LATMOS::Ad object for windows AD $domain.
32
33domain / server: either the Ad domain or directly the server
34
35ldap_args is an optionnal list of arguments to pass to L<Net::LDAP>.
36
37=cut
38
39sub object_table { 'address' }
40
41sub key_field { 'name' }
42
43sub has_extended_attributes { 1 }
44
45sub _inline_fields {
46    my ($self, $for, $base) = @_;
47
48    my %fields = (
49        $self->SUPER::_inline_fields($for, $base),
50        user            => 'user',
51    );
52    %fields
53}
54
55sub _managed_fields {
56    my ($self, $for, $base) = @_;
57    (site => 'site'),
58    $for !~ /w/ ? (
59        sn => 'sn',
60        mail =>  'mail',
61        givenName => 'givenName',
62    ) : ()
63}
64
65sub _delayed_fields {
66    my ($self)= @_;
67    return qw();
68}
69
70sub _create {
71    my ($class, $base, $id, %data) = @_;
72    $data{user} or return;
73    my $user = $base->get_object('user', $data{user});
74    if (!$user->get_c_field('otheraddress')) {
75        $data{isMainAddress} = 1;
76    }
77    $class->SUPER::_create($base, $id, %data);
78}
79
80sub get_field {
81    my ($self, $field) = @_;
82    if ((grep { $field eq $_ } __PACKAGE__->_address_fields())
83        && (my $fsite = $self->get_c_field('site'))) {
84        my $site = $self->base->get_object('site', $fsite);
85        if ($site) {
86            return $site->get_field($field);
87        }
88    } elsif ($field =~ /^(sn|givenName|mail)$/) {
89        my $user = $self->base->get_object('user', $self->_get_c_field('user'));
90        return $user->_get_c_field($field);
91    } else {
92        return $self->SUPER::get_field($field);
93    }
94}
95
96sub set_fields {
97    my ($self, %data) = @_;
98    my %fdata;
99    foreach my $attr (keys %data) {
100        $attr =~ /^site$/ and do {
101            my $site =
102            $self->base->get_object('site',
103                $data{$attr});
104            if ($site) {
105                foreach (__PACKAGE__->_address_fields()) {
106                    $fdata{$_} = undef;
107                    $data{$_} = undef;
108                }
109            }
110            $fdata{$attr} = $data{$attr} || undef;
111            next;
112        };
113        $fdata{$attr} = $data{$attr} || undef;
114    }
115    if  (keys %fdata) {
116        $self->SUPER::set_fields(%fdata);
117    }
118}
119
1201;
121
122__END__
123
124=head1 SEE ALSO
125
126=head1 AUTHOR
127
128Olivier Thauvin, E<lt>olivier.thauvin@latmos.ipsl.frE<gt>
129
130=head1 COPYRIGHT AND LICENSE
131
132Copyright (C) 2008, 2009 CNRS SA/CETP/LATMOS
133
134This library is free software; you can redistribute it and/or modify
135it under the same terms as Perl itself, either Perl version 5.10.0 or,
136at your option, any later version of Perl 5 you may have available.
137
138
139=cut
Note: See TracBrowser for help on using the repository browser.