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.5 by root, Thu Aug 16 16:40:07 2001 UTC vs.
Revision 1.23 by root, Mon Dec 3 15:16:42 2001 UTC

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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines