16 |
use lib '/srv/Sack/lib'; |
use lib '/srv/Sack/lib'; |
17 |
use Sack::Merge; |
use Sack::Merge; |
18 |
use Sack::Server::HTTP; |
use Sack::Server::HTTP; |
19 |
|
use Sack::Server::HTML; |
20 |
|
|
21 |
my @cloud; |
my @cloud; |
22 |
my $cloud_path = $ENV{CLOUD} || "etc/cloud"; |
my $cloud_path = $ENV{CLOUD} || "etc/cloud"; |
89 |
$session->{peerport}->{ $new->peerport } = $new; |
$session->{peerport}->{ $new->peerport } = $new; |
90 |
warn "[socket] connect\n"; |
warn "[socket] connect\n"; |
91 |
Storable::store_fd( { ping => 1 }, $new ); |
Storable::store_fd( { ping => 1 }, $new ); |
|
info 0 => 'ping', $new->peerport; |
|
92 |
} elsif ( $sock == $www ) { |
} elsif ( $sock == $www ) { |
93 |
my $client = $www->accept; |
my $client = $www->accept; |
94 |
Sack::Server::HTTP::request( $client, sub { |
Sack::Server::HTTP::request( $client, sub { |
|
warn "XXX callback ",dump( @_ ); |
|
95 |
my ( $send, $method, $param ) = @_; |
my ( $send, $method, $param ) = @_; |
96 |
|
|
97 |
if ( $method =~ m{views} ) { |
if ( $method =~ m{views} ) { |
100 |
Sack::Merge->clean; |
Sack::Merge->clean; |
101 |
to_all { view => $code, path => $method }; |
to_all { view => $code, path => $method }; |
102 |
print $send "HTTP/1.0 302 $method\r\nLocation: /\r\n\r\n"; |
print $send "HTTP/1.0 302 $method\r\nLocation: /\r\n\r\n"; |
103 |
return; |
return 1; |
104 |
} elsif ( $method =~ m{^/tmp/sack} ) { |
} elsif ( $method =~ m{^/tmp/sack} ) { |
105 |
@shard_paths = glob "$method/*"; |
@shard_paths = glob "$method/*"; |
106 |
warn "loading shard $method from ", dump( @shard_paths ); |
warn "loading shard $method from ", dump( @shard_paths ); |
107 |
to_all { load => $method }; |
to_all { load => $method }; |
108 |
print $send "HTTP/1.0 302 $method\r\nLocation: /\r\n\r\n"; |
print $send "HTTP/1.0 302 $method\r\nLocation: /\r\n\r\n"; |
109 |
return; |
return 1; |
110 |
|
} elsif ( $method =~ m{^/out/(.+)} ) { |
111 |
|
print $send "HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n"; |
112 |
|
Sack::Server::HTML::send_out( $send, Sack::Merge->out, $1, $param ); |
113 |
|
return 1; |
114 |
} |
} |
115 |
|
|
116 |
print $send "HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n"; |
print $send "HTTP/1.0 200 OK\r\nContent-Type: text/html\r\n\r\n"; |
120 |
, qq|</ul>| |
, qq|</ul>| |
121 |
; |
; |
122 |
|
|
123 |
print $send '<h1>Info</h1><pre>' . dump( $info ) . '</pre>'; |
my $out = Sack::Merge->out; |
124 |
|
print $send qq|<h1>Results</h1><ul>| |
125 |
|
, join("\n", map { qq|<li><a href="/out/$_" target="$_">$_</a>| } keys %$out ) |
126 |
|
, qq|</ul>| |
127 |
|
; |
128 |
|
|
129 |
|
print $send qq|<h1>Nodes</h1> |
130 |
|
<style type="text/css"> |
131 |
|
.forked { |
132 |
|
color: #f00; |
133 |
|
} |
134 |
|
|
135 |
|
.ping { |
136 |
|
color: #0f0; |
137 |
|
} |
138 |
|
</style> |
139 |
|
|, join("\n", map { |
140 |
|
my $class = join(' ', map { $_->[0] } @{ $info->{node}->{$_} }); |
141 |
|
qq|<span class="$class">$_</span>|; |
142 |
|
} sort keys %{ $info->{node} } ); |
143 |
|
|
144 |
print $send qq|<h1>Data</h1><ul>| |
print $send qq|<h1>Data</h1><ul>| |
145 |
, join("\n", map { qq|<li><a href="$_">$_</a>| } glob '/tmp/sack/*' ) |
, join("\n", map { qq|<li><a href="$_">$_</a>| } glob '/tmp/sack/*' ) |
146 |
, qq|</ul>| |
, qq|</ul>| |
147 |
; |
; |
148 |
|
|
149 |
|
print $send '<pre>', dump($info), '</pre>'; |
150 |
|
|
151 |
} ); |
} ); |
152 |
} else { |
} else { |
153 |
my $data = eval { Storable::fd_retrieve( $sock ) }; |
my $data = eval { Storable::fd_retrieve( $sock ) }; |