/[suikacvs]/messaging/suikawari/module/RisuukaDentatsu.sb
Suika

Contents of /messaging/suikawari/module/RisuukaDentatsu.sb

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (show annotations) (download)
Wed Jul 24 12:13:21 2002 UTC (22 years, 3 months ago) by wakaba
Branch: MAIN
CVS Tags: HEAD
2002-07-24  Wakaba <w@suika.fam.cx>

	* RisuukaDentatsu.sb: New module.

1
2 =head1 NAME
3
4 Suikawari::RisuukaDentatsu --- Suikawari module for Risuuka Keijiban
5
6 =cut
7
8 ## This file is written in EUC-japan encoding.
9
10 package Suikawari::RisuukaDentatsu;
11 use strict;
12 use vars qw/$VERSION/;
13 $VERSION=do{my @r=(q$Revision: 1.1 $=~/\d+/g);sprintf "%d."."%02d" x $#r,@r};
14 use Message::MIME::Charset::Jcode 'jcode.pl';
15
16 sub msg_regex ($) {
17 <<'EOH',
18 <td[^>]*>
19 <font[^>]*>
20 (\d+).(\d+).(\d+) [A-Za-z]+<!---->day (\d+):(\d+):(\d+) (.*?)<br>
21 <hr size=1>
22 (?:<IMG SRC="([^"]+)"[^>]*>)?<BR>
23 (.*?)<BR>
24 <BR>
25 </font>
26 </td>
27 EOH
28 qw (date_year date_month date_day date_hour date_minute date_second
29 subject misc_image_uri body);
30 }
31
32 sub meta_regex ($) {
33 my $r = <<'EOH';
34 <title>([^<]+)</title>
35 EOH
36 $r =~ s/\n$//s;
37 $r, qw (list_name);
38 }
39
40 sub on_load_source ($$) {shift;
41 my $b = shift;
42 $b->set_hook_function (code_conversion => sub { jcode::euc ($_[1]) });
43 }
44
45 sub source ($) {
46 if ($Bunshin::DEBUG) {
47 (file => 'RisuukaDentatsu.tmp');
48 (uri => 'http://yapeus.com/users/fuyudentatsu/');
49 } else {
50 (uri => 'http://yapeus.com/users/fuyudentatsu/');
51 }
52 }
53
54 sub face ($) {
55 # my %face;
56 # (faces => \%face);
57 }
58
59 sub on_make ($$) {
60 my $self = shift;
61 my $b = shift;
62 $b->default_parameter (date_zone => '+0900');
63 $b->default_parameter (DEFAULT_subject => '(無題)');
64 $b->default_parameter (newsgroups => 'suika.chuubu.r.55');
65 $b->default_parameter (list_name => '理数科伝達事項');
66 $b->default_parameter (list_id => 'dentatsu.2000e.risuu.chuubu.suika.fam.cx');
67 my $http = $b->meta_information;
68 if (ref $http) {
69 $b->default_parameter (misc_http_server => $http->field ('server'));
70 }
71 $b->set_hook_function (msg_header_add => sub {
72 my $self = shift;
73 my ($msg, $p) = @_;
74 my $hdr = $msg->header;
75 ## Newsgroups
76 my $group = $p->{newsgroups};
77 $group = 'suika.test' if $Bunshin::DEBUG;
78 $hdr->replace (newsgroups => $group);
79 });
80 $b->set_hook_function (msg_body => sub {
81 shift;
82 my ($msg, $body, $p) = @_;
83 $body =~ s#<BR>#\x0D\x0A#g;
84 $body =~ s#(?:\x0D\x0A)+$#\x0D\x0A#s;
85 unless ($p->{misc_image_uri}) {
86 $msg->body->value ($body);
87 } else {
88 require URI::WithBase;
89 my $uri = URI::WithBase->new ($p->{misc_image_uri}, $p->{base_uri})->abs;
90 my ($img, $http) = $b->_get_resource (uri => $uri);
91 $msg->header->field ('content-type')->media_type ('multipart/mixed');
92 my $text = $msg->body->item (0, -by => 'index');
93 $text->body->value ($body);
94 my $image = $msg->body->item (1, -by => 'index');
95 $image->header->field ('content-type')->media_type ('image/png');
96 $image->header->field ('content-location')->value ($uri);
97 $http->scan (sub {shift;
98 my $item = shift;
99 next unless $item->{ns} eq $Message::Header::NS_phname2uri{content};
100 $image->header->field ($item->{name} => $item->{body}, -ns => $item->{ns});
101 });
102 $image->body->value ($img);
103 }
104 });
105 }
106
107 =head1 SEE ALSO
108
109 Suikawari, Bunshin
110
111 =head1 LICENSE
112
113 Copyright 2002 wakaba E<lt>w@suika.fam.cxE<gt>.
114
115 This program is free software; you can redistribute it and/or modify
116 it under the terms of the GNU General Public License as published by
117 the Free Software Foundation; either version 2 of the License, or
118 (at your option) any later version.
119
120 This program is distributed in the hope that it will be useful,
121 but WITHOUT ANY WARRANTY; without even the implied warranty of
122 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
123 GNU General Public License for more details.
124
125 You should have received a copy of the GNU General Public License
126 along with this program; see the file COPYING. If not, write to
127 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
128 Boston, MA 02111-1307, USA.
129
130 =head1 CHANGE
131
132 See F<ChangeLog>.
133 $Date: 2002/06/25 09:34:42 $
134
135 =cut
136
137 1;
138 ### Suikawari::TomikouKeijiban ends here

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24