ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Coro/myhttpd/access.pl
(Generate patch)

Comparing Coro/myhttpd/access.pl (file contents):
Revision 1.4 by root, Tue Aug 14 04:33:58 2001 UTC vs.
Revision 1.28 by root, Thu Jan 3 01:20:17 2002 UTC

1package transferqueue;
1 2
3my @reserve = (
4 [ 1_200_000, 2],
5 [ 8_000_000, 1],
6 [ 75_000_000, 1],
7);
8
9sub new {
10 my $class = shift;
11 my $self = bless {
12 slots => 1,
13 maxsize => 0,
14 lastspb => 0,
15 avgspb => 0,
16 @_,
17 }, $class;
18 $self->{reschedule} = Event->timer(
19 after => 10,
20 interval => 3,
21 cb => sub { $self->wake_next },
22 );
23 $self;
24}
25
26sub start_transfer {
27 my $self = shift;
28 my $size = $_[0];
29
30 if ($self->{maxsize} && $self->{maxsize} < $size) {
31 $size = $self->{maxsize};
32 }
33
34 my $transfer = bless {
35 queue => $self,
36 time => $::NOW,
37 size => $size,
38 coro => $Coro::current,
39 started => 0,
40 }, transfer::;
41
42 push @{$self->{wait}}, $transfer;
43
44 $self->wake_next;
45
46 $transfer;
47}
48
49sub sort {
50 my @queue = grep $_, @{$_[0]{wait}};
51
52 $_->{spb} = ($::NOW-$_->{time}) / ($_->{size} || 1) for @queue;
53
54 $_[0]{wait} = [sort { $b->{spb} <=> $a->{spb} } @queue];
55
56 Scalar::Util::weaken $_ for @{$_[0]{wait}};
57}
58
59sub wake_next {
60 my $self = shift;
61
62 $self->sort;
63
64 while (@{$self->{wait}}) {
65 my $size = $self->{wait}[0]{size};
66 my $min = 0;
67 for (@reserve) {
68 last if $size <= $_->[0];
69 $min += $_->[1];
70 }
71 last unless $self->{slots} > $min;
72 my $transfer = shift @{$self->{wait}};
73 $self->{lastspb} = $transfer->{spb};
74 $self->{avgspb} = $self->{avgspb} * 0.99 + $transfer->{spb} * 0.01;
75 $self->{started}++;
76 $transfer->wake;
77 last;
78 }
79}
80
81sub waiters {
82 $_[0]->sort;
83 @{$_[0]{wait}};
84}
85
86sub DESTROY {
87 my $self = shift;
88
89 $self->{reschedule}->cancel;
90}
91
92package transfer;
93
94use Coro::Timer ();
95
96sub wake {
97 my $self = shift;
98
99 $self->{alloc} = 1;
100 $self->{queue}{slots}--;
101 $self->{wake} and $self->{wake}->ready;
102}
103
104sub try {
105 my $self = shift;
106
107 $self->{alloc} || do {
108 my $timeout = Coro::Timer::timeout $_[0];
109 local $self->{wake} = $self->{coro};
110
111 Coro::schedule;
112
113 $self->{alloc};
114 }
115}
116
117sub DESTROY {
118 my $self = shift;
119
120 if ($self->{alloc}) {
121 $self->{queue}{slots}++;
122 $self->{queue}->wake_next;
123 }
124}
125
126package conn;
127
2our @blocklist; 128our %blockuri;
129our $blockref;
3 130
4sub read_blocklist { 131sub read_blockuri {
5 local *B; 132 local *B;
6 my %group; 133 my %group;
7 @blocklist = (); 134 %blockuri = ();
8 if (open B, "<blocklist") { 135 if (open B, "<blockuri") {
9 while (<B>) { 136 while (<B>) {
10 chomp; 137 chomp;
11 if (/^group\s+(\S+)\s+(.*)/i) { 138 if (/^group\s+(\S+)\s+(.*)/i) {
12 $group{$1} = [split /\s+/, $2]; 139 $group{$1} = [split /\s+/, $2];
13 } elsif (/^!([^\t]*)\t\s*(.*)/) { 140 } elsif (/^!([^\t]*)\t\s*(.*)/) {
15 my @r; 142 my @r;
16 for (split /\s+/, $2) { 143 for (split /\s+/, $2) {
17 push @r, $group{$_} ? @{$group{$_}} : $_; 144 push @r, $group{$_} ? @{$group{$_}} : $_;
18 } 145 }
19 print "not($g) => (@r)\n"; 146 print "not($g) => (@r)\n";
147 push @{$blockuri{$_}}, $g for @r;
20 push @blocklist, [qr/$g/i, \@r]; 148 push @blockuri, [qr/$g/i, \@r];
21 } elsif (/\S/) { 149 } elsif (/\S/) {
22 print "blocklist: unparsable line: $_\n"; 150 print "blockuri: unparsable line: $_\n";
23 } 151 }
24 } 152 }
153 for (keys %blockuri) {
154 my $qr = join ")|(?:", @{$blockuri{$_}};
155 $blockuri{$_} = qr{(?:$qr)}i;
156 }
25 } else { 157 } else {
26 print "no blocklst\n"; 158 print "no blockuri\n";
27 } 159 }
28} 160}
29 161
162sub read_blockref {
163 local *B;
164 my @blockref;
165 if (open B, "<blockreferer") {
166 while (<B>) {
167 chomp;
168 if (/^([^\t]*)\t\s*(.*)/) {
169 push @blockref, $1;
170 } elsif (/\S/) {
171 print "blockref: unparsable line: $_\n";
172 }
173 }
174 $blockref = join ")|(?:", @blockref;
175 $blockref = qr{^(?:$blockref)}i;
176 } else {
177 print "no blockref\n";
178 $blockref = qr{^x^};
179 }
180}
181
30read_blocklist; 182read_blockuri;
183read_blockref;
31 184
185use Tie::Cache;
186tie %whois_cache, Tie::Cache::, 32;
187
32sub conn::access_check { 188sub access_check {
33 my $self = shift; 189 my $self = shift;
34 190
191 my $ref = $self->{h}{referer};
35 my $uri = $self->{path}; 192 my $uri = $self->{path};
36 my %disallow; 193 my %disallow;
37 194
38 for (@blocklist) { 195 $self->err_block_referer
39 if ($uri =~ $_->[0]) { 196 if $self->{h}{referer} =~ $blockref;
40 $disallow{$_}++ for @{$_->[1]}; 197
41 }
42 }
43
44 my $whois = ::ip_request($self->{remote_addr}); 198 my $whois = $whois_cache{$self->{remote_addr}}
199 ||= netgeo::ip_request($self->{remote_addr});
45 200
46 my $country = "XX"; 201 my $country = "XX";
47 202
48 if ($whois =~ /^\*cy: (\S+)/m) { 203 if ($whois =~ /^\*cy: (\S+)/m) {
49 $country = uc $1; 204 $country = uc $1;
51 $self->slog(9, "no country($whois)"); 206 $self->slog(9, "no country($whois)");
52 } 207 }
53 208
54 $self->{country} = $country; 209 $self->{country} = $country;
55 210
56 if ($disallow{$country}) { 211 $self->err_block_country($whois)
57 $self->slog(6, "DISALLOW($uri,$country)"); 212 if $self->{path} =~ $blockuri{$country};
58
59 $whois =~ s/&/&amp;/g;
60 $whois =~ s/</&lt;/g;
61 $self->err(403, "forbidden", { "Content-Type" => "text/html" }, <<EOF);
62<html>
63<head>
64<title>This material is licensed in your country!</title>
65</head>
66<body bgcolor="#ffffff" text="#000000" link="#0000ff" vlink="#000080" alink="#ff0000">
67
68<h1>This material is licensed in your country!</h1>
69
70<p>My research has shown that your IP address
71(<b>$self->{remote_addr}</b>) most probably is located in this country:
72<b>$country</b> (ISO-3166-2 code, XX == unknown). The full record is:</p>
73
74<pre>
75$whois
76</pre>
77
78<p>My database says that the material you are trying to access is licensed
79in your country. If I would distribute these files to your country I would
80actively <em>hurt</em> the industry behind it, which includes the artists
81and authors of these videos/mangas. So I hope you understand that I try to
82avoid this.</p>
83
84<p>If you <em>really</em> think that this is wrong, i.e. the
85material you tried to access is <em>not</em> licensed in your
86country or your ip address was misdetected, you can write to <a
87href="mailto:licensed\@plan9.de">licensed\@plan9.de</a>. Please explain
88what happened and why you think this is wrong in as much detail as
89possible.</p>
90
91<div align="right">Thanks a lot for understanding.</div>
92
93</body>
94</html>
95EOF
96 }
97} 213}
98 214
991; 2151;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines