[1] | 1 | package LATMOS::Accounts; |
---|
| 2 | |
---|
| 3 | use 5.010000; |
---|
| 4 | use strict; |
---|
| 5 | use warnings; |
---|
[22] | 6 | use base qw(Config::IniFiles); |
---|
| 7 | use LATMOS::Accounts::Bases; |
---|
[50] | 8 | use LATMOS::Accounts::Synchro; |
---|
[1] | 9 | |
---|
[22] | 10 | our $VERSION = (q$Rev$ =~ /^Rev: (\d+) /)[0]; |
---|
[1] | 11 | |
---|
[22] | 12 | sub new { |
---|
| 13 | my ($class, $config) = @_; |
---|
[1] | 14 | |
---|
[24] | 15 | $config ||= '/etc/latmos-account.ini'; |
---|
| 16 | |
---|
[22] | 17 | my $self = Config::IniFiles->new( |
---|
| 18 | -file => $config |
---|
| 19 | ); |
---|
[1] | 20 | |
---|
[22] | 21 | bless($self, $class) |
---|
| 22 | } |
---|
[1] | 23 | |
---|
[22] | 24 | sub base { |
---|
| 25 | my ($self, $section) = @_; |
---|
| 26 | # this method perform a cache |
---|
| 27 | $self->{_bases}{$section} and return $self->{_bases}{$section}; |
---|
| 28 | $self->load_base($section) ? $self->{_bases}{$section} : undef; |
---|
| 29 | } |
---|
[1] | 30 | |
---|
[24] | 31 | sub default_base { |
---|
| 32 | my ($self) = @_; |
---|
[34] | 33 | my $default = $self->default_base_name or return; |
---|
[24] | 34 | $self->base($default); |
---|
| 35 | } |
---|
| 36 | |
---|
[23] | 37 | # load or a if need base |
---|
[22] | 38 | sub load_base { |
---|
| 39 | my ($self, $section) = @_; |
---|
[23] | 40 | return ($self->{_bases}{$section} ||= $self->_load_base($section)) |
---|
[22] | 41 | ? 1 |
---|
| 42 | : 0; |
---|
| 43 | } |
---|
[1] | 44 | |
---|
[22] | 45 | # do the bad work |
---|
| 46 | sub _load_base { |
---|
| 47 | my ($self, $section) = @_; |
---|
| 48 | my $type = $self->val($section, 'type') or return; |
---|
[34] | 49 | my %params = map { $_ => ($self->val($section, $_)) } $self->Parameters($section); |
---|
[49] | 50 | my $base = LATMOS::Accounts::Bases->new($type, %params, label => $section); |
---|
[34] | 51 | $base->load or return; |
---|
| 52 | $base; |
---|
[22] | 53 | } |
---|
[1] | 54 | |
---|
[24] | 55 | sub default_base_name { |
---|
| 56 | my ($self) = @_; |
---|
| 57 | $self->val('_default_', 'base', ($self->list_bases)[0]); |
---|
| 58 | } |
---|
| 59 | |
---|
[23] | 60 | sub list_bases { |
---|
| 61 | my ($self) = @_; |
---|
| 62 | grep { |
---|
[24] | 63 | !m/^_.*_$/ |
---|
[23] | 64 | } $self->Sections |
---|
| 65 | } |
---|
| 66 | |
---|
| 67 | sub load_all_base { |
---|
| 68 | my ($self) = @_; |
---|
| 69 | foreach ($self->list_bases) { |
---|
| 70 | $self->load_base($_) or do { |
---|
| 71 | warn "Cannot load base $_\n"; |
---|
| 72 | return 0; |
---|
| 73 | }; |
---|
| 74 | } |
---|
| 75 | 1; |
---|
| 76 | } |
---|
| 77 | |
---|
[41] | 78 | sub config_sync_base { |
---|
| 79 | my ($self, $from) = @_; |
---|
| 80 | return split(/ /, $self->val($from, 'push', '')); |
---|
| 81 | } |
---|
| 82 | |
---|
[50] | 83 | sub create_synchro { |
---|
| 84 | my ($self, $from, $to, %options) = @_; |
---|
| 85 | |
---|
| 86 | my $labfrom = $from ? $self->base($from) : $self->default_base; |
---|
| 87 | |
---|
| 88 | my @labto = map { $self->base($_) } |
---|
| 89 | @{ $to || []} |
---|
| 90 | ? @{ $to } |
---|
| 91 | : ($self->config_sync_base($from |
---|
| 92 | ? $from |
---|
| 93 | : $self->default_base_name)); |
---|
| 94 | |
---|
| 95 | my $sync = LATMOS::Accounts::Synchro->new( |
---|
| 96 | $labfrom, [ @labto ], |
---|
| 97 | state_file => $self->val('_default_', 'state_file'), |
---|
| 98 | ); |
---|
| 99 | } |
---|
| 100 | |
---|
| 101 | |
---|
[1] | 102 | 1; |
---|
[24] | 103 | |
---|
[1] | 104 | __END__ |
---|
| 105 | # Below is stub documentation for your module. You'd better edit it! |
---|
| 106 | |
---|
| 107 | =head1 NAME |
---|
| 108 | |
---|
| 109 | LATMOS::Accounts - Perl extension for blah blah blah |
---|
| 110 | |
---|
| 111 | =head1 SYNOPSIS |
---|
| 112 | |
---|
| 113 | use LATMOS::Accounts; |
---|
| 114 | blah blah blah |
---|
| 115 | |
---|
| 116 | =head1 DESCRIPTION |
---|
| 117 | |
---|
| 118 | Stub documentation for LATMOS::Accounts, created by h2xs. It looks like the |
---|
| 119 | author of the extension was negligent enough to leave the stub |
---|
| 120 | unedited. |
---|
| 121 | |
---|
| 122 | Blah blah blah. |
---|
| 123 | |
---|
| 124 | =head2 EXPORT |
---|
| 125 | |
---|
| 126 | None by default. |
---|
| 127 | |
---|
| 128 | |
---|
| 129 | |
---|
| 130 | =head1 SEE ALSO |
---|
| 131 | |
---|
| 132 | Mention other useful documentation such as the documentation of |
---|
| 133 | related modules or operating system documentation (such as man pages |
---|
| 134 | in UNIX), or any relevant external documentation such as RFCs or |
---|
| 135 | standards. |
---|
| 136 | |
---|
| 137 | If you have a mailing list set up for your module, mention it here. |
---|
| 138 | |
---|
| 139 | If you have a web site set up for your module, mention it here. |
---|
| 140 | |
---|
| 141 | =head1 AUTHOR |
---|
| 142 | |
---|
[41] | 143 | Thauvin Olivier, E<lt>olivier.thauvin@latmosipsl.frE<gt> |
---|
[1] | 144 | |
---|
| 145 | =head1 COPYRIGHT AND LICENSE |
---|
| 146 | |
---|
| 147 | Copyright (C) 2009 by Thauvin Olivier |
---|
| 148 | |
---|
| 149 | This library is free software; you can redistribute it and/or modify |
---|
| 150 | it under the same terms as Perl itself, either Perl version 5.10.0 or, |
---|
| 151 | at your option, any later version of Perl 5 you may have available. |
---|
| 152 | |
---|
| 153 | |
---|
| 154 | =cut |
---|