diff options
author | Angelo Naselli <anaselli@linux.it> | 2014-06-25 17:56:21 +0200 |
---|---|---|
committer | Angelo Naselli <anaselli@linux.it> | 2014-06-25 17:56:21 +0200 |
commit | ecf275d1ed5ad4da361aa7aaa758a3d217e4a758 (patch) | |
tree | eae3446fd1e3bd687b1d9b886e2efba46d0f7544 /lib | |
parent | 339ef6668de37f657d0ece0520aa17b574ed0487 (diff) | |
download | manatools-ecf275d1ed5ad4da361aa7aaa758a3d217e4a758.tar manatools-ecf275d1ed5ad4da361aa7aaa758a3d217e4a758.tar.gz manatools-ecf275d1ed5ad4da361aa7aaa758a3d217e4a758.tar.bz2 manatools-ecf275d1ed5ad4da361aa7aaa758a3d217e4a758.tar.xz manatools-ecf275d1ed5ad4da361aa7aaa758a3d217e4a758.zip |
added ntp servers from timezone
Diffstat (limited to 'lib')
-rw-r--r-- | lib/AdminPanel/Shared/TimeZone.pm | 412 |
1 files changed, 153 insertions, 259 deletions
diff --git a/lib/AdminPanel/Shared/TimeZone.pm b/lib/AdminPanel/Shared/TimeZone.pm index 8b1eb81c..8097d095 100644 --- a/lib/AdminPanel/Shared/TimeZone.pm +++ b/lib/AdminPanel/Shared/TimeZone.pm @@ -11,7 +11,7 @@ AdminPanel::Shared::TimeZone - module to manage TimeZone settings my $tz = AdminPanel::Shared::TimeZone->new(); - + =head1 DESCRIPTION This module allows to manage time zone settings. @@ -56,6 +56,7 @@ use Moose; use DateTime::TimeZone; use Config::Auto; +use AdminPanel::Shared::Locales; #============================================================= @@ -97,6 +98,125 @@ has 'clock_configuration_file' => ( +#=== global === +has 'loc' => ( + is => 'rw', + lazy => 1, + init_arg => undef, + builder => '_localeInitialize' +); + +sub _localeInitialize { + my $self = shift; + + # TODO fix domain binding for translation + $self->loc(AdminPanel::Shared::Locales->new(domain_name => 'libDrakX') ); + # TODO if we want to give the opportunity to test locally add dir_name => 'path' +} + + +has 'ntp_servers' => ( + traits => ['Hash'], + is => 'rw', + isa => 'HashRef', + lazy => 1, + handles => { + get_ntp_server => 'get', + ntp_server_pairs => 'kv', + }, + init_arg => undef, + builder => '_buildNTPServers' +); + +sub _buildNTPServers { + my $self = shift; + + my %ntpServersHash; + $ntpServersHash{"-"} = { + $self->loc->N_("Global") => "pool.ntp.org", + }; + $ntpServersHash{Global} = { + $self->loc->N_("Africa") => "africa.pool.ntp.org", + $self->loc->N_("Asia") => "asia.pool.ntp.org", + $self->loc->N_("Europe") => "europe.pool.ntp.org", + $self->loc->N_("North America") => "north-america.pool.ntp.org", + $self->loc->N_("Oceania") => "oceania.pool.ntp.org", + $self->loc->N_("South America") => "south-america.pool.ntp.org", + }; + $ntpServersHash{Africa} = { + $self->loc->N_("South Africa") => "za.pool.ntp.org", + $self->loc->N_("Tanzania") => "tz.pool.ntp.org", + }; + $ntpServersHash{Asia} = { + $self->loc->N_("Bangladesh") => "bd.pool.ntp.org", + $self->loc->N_("China") => "cn.pool.ntp.org", + $self->loc->N_("Hong Kong") => "hk.pool.ntp.org", + $self->loc->N_("India") => "in.pool.ntp.org", + $self->loc->N_("Indonesia") => "id.pool.ntp.org", + $self->loc->N_("Iran") => "ir.pool.ntp.org", + $self->loc->N_("Israel") => "il.pool.ntp.org", + $self->loc->N_("Japan") => "jp.pool.ntp.org", + $self->loc->N_("Korea") => "kr.pool.ntp.org", + $self->loc->N_("Malaysia") => "my.pool.ntp.org", + $self->loc->N_("Philippines") => "ph.pool.ntp.org", + $self->loc->N_("Singapore") => "sg.pool.ntp.org", + $self->loc->N_("Taiwan") => "tw.pool.ntp.org", + $self->loc->N_("Thailand") => "th.pool.ntp.org", + $self->loc->N_("Turkey") => "tr.pool.ntp.org", + $self->loc->N_("United Arab Emirates") => "ae.pool.ntp.org", + }; + $ntpServersHash{Europe} = { + $self->loc->N_("Austria") => "at.pool.ntp.org", + $self->loc->N_("Belarus") => "by.pool.ntp.org", + $self->loc->N_("Belgium") => "be.pool.ntp.org", + $self->loc->N_("Bulgaria") => "bg.pool.ntp.org", + $self->loc->N_("Czech Republic") => "cz.pool.ntp.org", + $self->loc->N_("Denmark") => "dk.pool.ntp.org", + $self->loc->N_("Estonia") => "ee.pool.ntp.org", + $self->loc->N_("Finland") => "fi.pool.ntp.org", + $self->loc->N_("France") => "fr.pool.ntp.org", + $self->loc->N_("Germany") => "de.pool.ntp.org", + $self->loc->N_("Greece") => "gr.pool.ntp.org", + $self->loc->N_("Hungary") => "hu.pool.ntp.org", + $self->loc->N_("Ireland") => "ie.pool.ntp.org", + $self->loc->N_("Italy") => "it.pool.ntp.org", + $self->loc->N_("Lithuania") => "lt.pool.ntp.org", + $self->loc->N_("Luxembourg") => "lu.pool.ntp.org", + $self->loc->N_("Netherlands") => "nl.pool.ntp.org", + $self->loc->N_("Norway") => "no.pool.ntp.org", + $self->loc->N_("Poland") => "pl.pool.ntp.org", + $self->loc->N_("Portugal") => "pt.pool.ntp.org", + $self->loc->N_("Romania") => "ro.pool.ntp.org", + $self->loc->N_("Russian Federation") => "ru.pool.ntp.org", + $self->loc->N_("Slovakia") => "sk.pool.ntp.org", + $self->loc->N_("Slovenia") => "si.pool.ntp.org", + $self->loc->N_("Spain") => "es.pool.ntp.org", + $self->loc->N_("Sweden") => "se.pool.ntp.org", + $self->loc->N_("Switzerland") => "ch.pool.ntp.org", + $self->loc->N_("Ukraine") => "ua.pool.ntp.org", + $self->loc->N_("United Kingdom") => "uk.pool.ntp.org", + $self->loc->N_("Yugoslavia") => "yu.pool.ntp.org", + }; + $ntpServersHash{"North America"} = { + $self->loc->N_("Canada") => "ca.pool.ntp.org", + $self->loc->N_("Guatemala") => "gt.pool.ntp.org", + $self->loc->N_("Mexico") => "mx.pool.ntp.org", + $self->loc->N_("United States") => "us.pool.ntp.org", + }; + $ntpServersHash{Oceania} = { + $self->loc->N_("Australia") => "au.pool.ntp.org", + $self->loc->N_("New Zealand") => "nz.pool.ntp.org", + }; + $ntpServersHash{"South America"} = { + $self->loc->N_("Argentina") => "ar.pool.ntp.org", + $self->loc->N_("Brazil") => "br.pool.ntp.org", + $self->loc->N_("Chile") => "cl.pool.ntp.org", + }; + + return \%ntpServersHash; +} + + #============================================================= @@ -114,7 +234,7 @@ Return the timezone directory (defualt: /usr/share/zoneinfo) #============================================================= -sub get_timezone_prefix() { +sub get_timezone_prefix { my $self = shift; return $self->timezone_prefix; @@ -186,277 +306,51 @@ sub readConfiguration { return $prefs; } -no Moose; -__PACKAGE__->meta->make_immutable; - - -1; - -######################## -=comment +sub _get_ntp_server_tree { + my ($self, $zone) = @_; + $zone = "-" if ! $zone; + my $ns = $self->get_ntp_server($zone); + return if !$ns; - - - -# TODO fix -our $ntp = "ntp"; -my $servername_config_suffix = ""; -# unless (-f $::prefix . "/etc/" . $ntp . ".conf") { -# $ntp = "chrony"; -# $servername_config_suffix = " iburst"; -# } - -sub ntp_server() { - find { $_ ne '127.127.1.0' } map { if_(/^\s*server\s+(\S*)/, $1) } cat_($::prefix . "/etc/" . $ntp . ".conf"); + map { + $ns->{$_} => ( + $self->get_ntp_server($_) ? + $zone ? + $self->loc->N($_) . "|" . $self->loc->N("All servers") : + $self->loc->N("All servers") : + $self->loc->N($zone) . "|" . $self->loc->N($_) + ), + $self->_get_ntp_server_tree($_) + } keys $ns; } -sub set_ntp_server { - my ($server) = @_; - my $f = $::prefix . "/etc/" . $ntp . ".conf"; - -f $f or return; - - my $pool_match = qr/\.pool\.ntp\.org$/; - my @servers = $server =~ $pool_match ? (map { "$_.$server" } 0 .. 2) : $server; - - my $added = 0; - substInFile { - if (/^#?\s*server\s+(\S*)/ && $1 ne '127.127.1.0') { - $_ = $added ? $_ =~ $pool_match ? undef : "#server $1\n" : join('', map { "server $_$servername_config_suffix\n" } @servers); - $added = 1; - } - } $f; - if ($ntp eq "ntp") { - output_p("$::prefix/etc/ntp/step-tickers", join('', map { "$_\n" } @servers)); - } +#============================================================= - require services; - services::set_status($ntp . 'd', to_bool($server), $::isInstall); -} +=head2 ntpServers -sub write { - my ($t) = @_; - - set_ntp_server($t->{ntp}); - - my $tz_prefix = get_timezone_prefix(); - eval { cp_af($tz_prefix . '/' . $t->{timezone}, "$::prefix/etc/localtime") }; - $@ and log::l("installing /etc/localtime failed"); - setVarsInSh("$::prefix/etc/sysconfig/clock", { - ZONE => $t->{timezone}, - UTC => bool2text($t->{UTC}), - ARC => "false", - }); - - my $adjtime_file = $::prefix . '/etc/adjtime'; - my @adjtime = cat_($adjtime_file); - @adjtime or @adjtime = ("0.0 0 0.0\n", "0\n"); - $adjtime[2] = $t->{UTC} ? "UTC\n" : "LOCAL\n"; - output_p($adjtime_file, @adjtime); -} - -sub reload_sys_clock { - my ($t) = @_; - require run_program; - any::disable_x_screensaver(); - run_program::run('hwclock', '--hctosys', ($t->{UTC} ? '--utc' : '--localtime')); - any::enable_x_screensaver(); -} +=head3 OUTPUT -#- best guesses for a given country -my %c2t = ( -'AM' => 'Asia/Yerevan', -'AR' => 'America/Buenos_Aires', -'AT' => 'Europe/Vienna', -'AU' => 'Australia/Sydney', -'BA' => 'Europe/Sarajevo', -'BE' => 'Europe/Brussels', -'BG' => 'Europe/Sofia', -'BR' => 'America/Sao_Paulo', #- most brazilians live on this time zone -'BY' => 'Europe/Minsk', -'CA' => 'Canada/Eastern', -'CH' => 'Europe/Zurich', -'CN' => 'Asia/Beijing', -'CZ' => 'Europe/Prague', -'DE' => 'Europe/Berlin', -'DK' => 'Europe/Copenhagen', -'EE' => 'Europe/Tallinn', -'ES' => 'Europe/Madrid', -'FI' => 'Europe/Helsinki', -'FR' => 'Europe/Paris', -'GB' => 'Europe/London', -'GE' => 'Asia/Yerevan', -'GL' => 'Arctic/Longyearbyen', -'GR' => 'Europe/Athens', -'HR' => 'Europe/Zagreb', -'HU' => 'Europe/Budapest', -'ID' => 'Asia/Jakarta', -'IE' => 'Europe/Dublin', -'IL' => 'Asia/Tel_Aviv', -'IN' => 'Asia/Kolkata', -'IR' => 'Asia/Tehran', -'IS' => 'Atlantic/Reykjavik', -'IT' => 'Europe/Rome', -'JP' => 'Asia/Tokyo', -'KR' => 'Asia/Seoul', -'LT' => 'Europe/Vilnius', -'LV' => 'Europe/Riga', -'MK' => 'Europe/Skopje', -'MT' => 'Europe/Malta', -'MX' => 'America/Mexico_City', -'MY' => 'Asia/Kuala_Lumpur', -'NL' => 'Europe/Amsterdam', -'NO' => 'Europe/Oslo', -'NZ' => 'Pacific/Auckland', -'PL' => 'Europe/Warsaw', -'PT' => 'Europe/Lisbon', -'RO' => 'Europe/Bucharest', -'RU' => 'Europe/Moscow', -'SE' => 'Europe/Stockholm', -'SI' => 'Europe/Ljubljana', -'SK' => 'Europe/Bratislava', -'TH' => 'Asia/Bangkok', -'TJ' => 'Asia/Dushanbe', -'TR' => 'Europe/Istanbul', -'TW' => 'Asia/Taipei', -'UA' => 'Europe/Kiev', -'US' => 'America/New_York', -'UZ' => 'Asia/Tashkent', -'VN' => 'Asia/Saigon', -'YU' => 'Europe/Belgrade', -'ZA' => 'Africa/Johannesburg', -); + HASHREF containing ntp_server => zone info -sub fuzzyChoice { - my ($b, $count) = bestMatchSentence($_[0], keys %c2t); - $count ? $b : ''; -} -sub bestTimezone { $c2t{fuzzyChoice($_[0])} || 'GMT' } +=head3 DESCRIPTION -our %ntp_servers; + This method returns an hash ref containing pairs ntp-server, zone -sub get_ntp_server_tree { - my ($zone) = @_; - map { - $ntp_servers{$zone}{$_} => ( - exists $ntp_servers{$_} ? - $zone ? - translate($_) . "|" . N("All servers") : - N("All servers") : - translate($zone) . "|" . translate($_) - ), - get_ntp_server_tree($_); - } keys %{$ntp_servers{$zone}}; -} +=cut -sub ntp_servers() { +#============================================================= +sub ntpServers { + my ($self) = @_; # FIXME: missing parameter: - +{ get_ntp_server_tree() }; + +{$self->_get_ntp_server_tree()}; } -sub dump_ntp_zone { - my ($zone) = @_; - map { if_(/\[\d+\](.+) -- (.+\.ntp\.org)/, $1 => $2) } `lynx -dump http://www.pool.ntp.org/zone/$zone`; -} -sub print_ntp_zone { - my ($zone, $name) = @_; - # FIXME: missing parameter: - my %servers = dump_ntp_zone($zone); - print qq(\$ntp_servers{"$name"} = {\n); - print join('', map { qq( N_("$_") => "$servers{$_}",\n) } sort(keys %servers)); - print "};\n"; - \%servers; -} -sub print_ntp_servers() { - print_ntp_zone(); - my $servers = print_ntp_zone('@', "Global"); - foreach my $name (sort(keys %$servers)) { - my ($zone) = $servers->{$name} =~ /^(.*?)\./; - print_ntp_zone($zone, $name); - } -} -# perl -Mtimezone -e 'timezone::print_ntp_servers()' -$ntp_servers{""} = { - N_("Global") => "pool.ntp.org", -}; -$ntp_servers{Global} = { - N_("Africa") => "africa.pool.ntp.org", - N_("Asia") => "asia.pool.ntp.org", - N_("Europe") => "europe.pool.ntp.org", - N_("North America") => "north-america.pool.ntp.org", - N_("Oceania") => "oceania.pool.ntp.org", - N_("South America") => "south-america.pool.ntp.org", -}; -$ntp_servers{Africa} = { - N_("South Africa") => "za.pool.ntp.org", - N_("Tanzania") => "tz.pool.ntp.org", -}; -$ntp_servers{Asia} = { - N_("Bangladesh") => "bd.pool.ntp.org", - N_("China") => "cn.pool.ntp.org", - N_("Hong Kong") => "hk.pool.ntp.org", - N_("India") => "in.pool.ntp.org", - N_("Indonesia") => "id.pool.ntp.org", - N_("Iran") => "ir.pool.ntp.org", - N_("Israel") => "il.pool.ntp.org", - N_("Japan") => "jp.pool.ntp.org", - N_("Korea") => "kr.pool.ntp.org", - N_("Malaysia") => "my.pool.ntp.org", - N_("Philippines") => "ph.pool.ntp.org", - N_("Singapore") => "sg.pool.ntp.org", - N_("Taiwan") => "tw.pool.ntp.org", - N_("Thailand") => "th.pool.ntp.org", - N_("Turkey") => "tr.pool.ntp.org", - N_("United Arab Emirates") => "ae.pool.ntp.org", -}; -$ntp_servers{Europe} = { - N_("Austria") => "at.pool.ntp.org", - N_("Belarus") => "by.pool.ntp.org", - N_("Belgium") => "be.pool.ntp.org", - N_("Bulgaria") => "bg.pool.ntp.org", - N_("Czech Republic") => "cz.pool.ntp.org", - N_("Denmark") => "dk.pool.ntp.org", - N_("Estonia") => "ee.pool.ntp.org", - N_("Finland") => "fi.pool.ntp.org", - N_("France") => "fr.pool.ntp.org", - N_("Germany") => "de.pool.ntp.org", - N_("Greece") => "gr.pool.ntp.org", - N_("Hungary") => "hu.pool.ntp.org", - N_("Ireland") => "ie.pool.ntp.org", - N_("Italy") => "it.pool.ntp.org", - N_("Lithuania") => "lt.pool.ntp.org", - N_("Luxembourg") => "lu.pool.ntp.org", - N_("Netherlands") => "nl.pool.ntp.org", - N_("Norway") => "no.pool.ntp.org", - N_("Poland") => "pl.pool.ntp.org", - N_("Portugal") => "pt.pool.ntp.org", - N_("Romania") => "ro.pool.ntp.org", - N_("Russian Federation") => "ru.pool.ntp.org", - N_("Slovakia") => "sk.pool.ntp.org", - N_("Slovenia") => "si.pool.ntp.org", - N_("Spain") => "es.pool.ntp.org", - N_("Sweden") => "se.pool.ntp.org", - N_("Switzerland") => "ch.pool.ntp.org", - N_("Ukraine") => "ua.pool.ntp.org", - N_("United Kingdom") => "uk.pool.ntp.org", - N_("Yugoslavia") => "yu.pool.ntp.org", -}; -$ntp_servers{"North America"} = { - N_("Canada") => "ca.pool.ntp.org", - N_("Guatemala") => "gt.pool.ntp.org", - N_("Mexico") => "mx.pool.ntp.org", - N_("United States") => "us.pool.ntp.org", -}; -$ntp_servers{Oceania} = { - N_("Australia") => "au.pool.ntp.org", - N_("New Zealand") => "nz.pool.ntp.org", -}; -$ntp_servers{"South America"} = { - N_("Argentina") => "ar.pool.ntp.org", - N_("Brazil") => "br.pool.ntp.org", - N_("Chile") => "cl.pool.ntp.org", -}; +no Moose; +__PACKAGE__->meta->make_immutable; + 1; -=cut + + |