AC-MrGamoo
view release on metacpan or search on metacpan
lib/AC/MrGamoo/Kibitz/Peers.pm view on Meta::CPAN
sub report_json {
my $all = peer_list_all();
my @fields = qw(hostname environment subsystem datacenter server_id status sort_metric);
return encode_json( [ map {
my %x;
@x{@fields} = @{$_}{@fields};
$x{ip} = [
map { {
ipv4 => inet_itoa($_->{ipv4}),
port => $_->{port},
natdom => $_->{natdom},
} } @{$_->{ip}}
];
\%x;
} @$all ] ) . "\n";
}
################################################################
sub _update_ok {
my $up = shift;
my $myself = my_server_id();
return if $up->{via} eq $myself;
return if $up->{server_id} eq $myself;
return if $up->{environment} ne conf_value('environment');
return if $up->{subsystem} ne 'mrgamoo';
return 1;
}
sub _remove {
my $id = shift;
my $d = $ALLPEER{$id};
my $lu = $^T - $d->{lastup};
my $lh = $^T - $d->{timestamp};
verbose("deleting peer: $id ($lu, $lh)");
delete $ALLPEER{$id};
}
sub _maybe_remove {
my $id = shift;
my $d = $ALLPEER{$id};
if( ($^T - $d->{lastup} > $KEEPDOWN) || ($^T - $d->{timestamp} > $KEEPLOST) ){
_remove($id);
}
}
################################################################
# pick best ip addr from array (ACPIPPort)
sub pick_best_addr_for_peer {
my $ipinfo = shift;
_nat_init() unless $natinit;
my $public;
my $private;
for my $i ( @$ipinfo ){
$public = $i unless $i->{natdom};
$private = $i if $i->{natdom} eq $natdom;
}
# prefer private addr if available (cheaper)
my $prefer = $private || $public;
return unless $prefer;
return ( inet_itoa($prefer->{ipv4}), $prefer->{port} );
}
sub _nat_init {
# determine my local NAT domain
my $nat = my_network_info();
for my $i (@$nat){
$natdom ||= $i->{natdom};
}
$natinit = 1;
}
################################################################
sub _random_peer {
my @peer;
# might be down? try again.
@peer = values %MAYBEDOWN;
# sceptical
@peer = values %SCEPTICAL unless @peer;
# known peer
unless(@peer){
@peer = values %ALLPEER;
# sometimes, randomly, use the seed peers
@peer = () unless int rand(@peer+1);
}
if( @peer ){
my $p = $peer[ rand(@peer) ];
debug("using peer $p->{server_id}");
return ($p->{server_id}, pick_best_addr_for_peer($p->{ip}));
}
# seed peer
my $seed = conf_value('seedpeer');
my $p = $seed->[ rand(@$seed) ];
my ($ip, $port) = split /:/, $p;
$port ||= my_port();
# don't talk to self. any of my addrs.
my $ipinfo = my_network_info();
for my $i (@$ipinfo){
return if $ip eq $i->{ipa} && $port == my_port();
}
debug("using seedpeer");
return("seed/$ip:$port", $ip, $port);
}
sub _kibitz_with_random_peer {
( run in 1.981 second using v1.01-cache-2.11-cpan-5735350b133 )