annotate after5.rb @ 1:8145b15d3d6f draft

RCS-revision 1.2 date: 2003/12/29 17:01:20; author: yuuji; state: Exp; lines: +5 -5 *** empty log message ***
author HIROSE Yuuji <yuuji@gentei.org>
date Mon, 29 Dec 2003 17:01:20 +0859
parents 8f811f47ac60
children 1110baebe9a9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1 #!/usr/local/bin/ruby
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
3 # Associative Scheduling Table - after5
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
4 # (C)2003 by HIROSE Yuuji [yuuji@gentei.org]
1
8145b15d3d6f RCS-revision 1.2
HIROSE Yuuji <yuuji@gentei.org>
parents: 0
diff changeset
5 # $Id: after5.rb,v 1.2 2003/12/29 17:01:20 yuuji Exp $
8145b15d3d6f RCS-revision 1.2
HIROSE Yuuji <yuuji@gentei.org>
parents: 0
diff changeset
6 # Last modified Tue Dec 30 01:48:15 2003 on firestorm
0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
7 # See http://www.gentei.org/~yuuji/software/after5/
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
8 # このスクリプトはEUCで保存してください。
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
9
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
10 require 'kconv'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
11
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
12 $charset = 'EUC-JP'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
13
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
14 class HTMLout
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
15 def contenttype(type = "text/html", charset = $charset)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
16 sprintf "Content-type: %s; charset=%s\n\n", type, charset
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
17 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
18 def initialize(title = "Document")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
19 @title = title
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
20 @eltstack = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
21 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
22 def resetstack()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
23 @eltstack = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
24 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
25 def head(title = @title, css = "style.css")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
26 sprintf <<__EOS__, title, css
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
27 <html>
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
28 <head>
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
29 <title>%s</title>
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
30 <link rel="stylesheet" type="text/css" href="%s">
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
31 </head>
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
32 __EOS__
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
33 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
34
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
35 def startelement(elt, attrs = {}, nl = true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
36 attr = ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
37 if attrs.is_a?(Hash)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
38 for k in attrs.keys
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
39 attr += " %s=\"%s\"" % [k, attrs[k]]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
40 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
41 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
42 @eltstack.push(elt)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
43 sprintf "<%s%s>%s", elt, attr, nl ? "\n" : ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
44 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
45 def endelement(elt = nil, nl = true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
46 if elt
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
47 x = elt
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
48 @eltstack.pop
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
49 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
50 x = @eltstack.pop
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
51 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
52 sprintf "</%s>%s", x, nl ? "\n" : ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
53 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
54 def element(elt, attrs = nil, nl = nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
55 attr = ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
56 lf = nl ? "\n" : ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
57 if attrs.is_a?(Hash)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
58 for k in attrs.keys
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
59 attr += " %s=\"%s\"" % [k, attrs[k]]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
60 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
61 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
62 body = yield
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
63 sprintf "<%s%s>%s%s%s</%s>%s", elt, attr, lf, body, lf, elt, lf
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
64 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
65 def elementln(elt, attr=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
66 body = yield
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
67 element(elt, attr, true){body}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
68 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
69 def a(href, anchor = nil, attrs = {})
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
70 attr = attrs
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
71 attr['href'] = href
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
72 element("a", attr){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
73 anchor or href
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
74 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
75 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
76 def p(msg, attrs=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
77 element("p", attrs){msg}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
78 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
79 def text(name, value='', size=nil, maxlength=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
80 sprintf "<input type=\"text\" name=\"%s\" value=\"%s\"%s%s>",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
81 name, value,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
82 size ? " size=\"%s\""%size.to_s : '',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
83 maxlength ? " maxlength=\"%s\""%maxlength.to_s : ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
84 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
85 def hidden(name, value='')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
86 sprintf "<input type=\"hidden\" name=\"%s\" value=\"%s\">", name, value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
87 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
88 def radio(name, value, text='', checked=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
89 sprintf "<input type=\"radio\" name=\"%s\" value=\"%s\"%s>%s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
90 name, value, checked ? " checked" : "", text
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
91 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
92 def checkbox(name, value, text='', checked=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
93 sprintf "<input type=\"checkbox\" name=\"%s\" value=\"%s\"%s>%s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
94 name, value, checked ? " checked" : "", text
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
95 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
96 def submit(name, value, text='')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
97 sprintf "<input type=\"submit\" name=\"%s\" value=\"%s\">%s\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
98 name, value, text
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
99 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
100 def reset(name, value, text='')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
101 sprintf "<input type=\"reset\" name=\"%s\" value=\"%s\">\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
102 name, value, text
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
103 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
104 def submit_reset(name)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
105 submit(name, "GO")+reset(name, "Reset")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
106 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
107
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
108 def select_integer(name, b, e, selected=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
109 start = (b<e ? b : e)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
110 last = (b>e ? b : e)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
111 "<select name=\"#{name}\">\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
112 (start..last).collect{|i|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
113 sprintf "<option%s>%d%s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
114 (selected.to_s==i.to_s) ? " selected" : "",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
115 i,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
116 i%6==0 ? "\n" : ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
117 }.join + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
118 "\n</select>\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
119 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
120 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
121
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
122 class PasswdMgr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
123 def initialize(name, mode=0640)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
124 require 'dbm'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
125 @pdb = DBM.open(name, mode)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
126 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
127 def checkpasswd(user, passwd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
128 if @pdb[user] then
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
129 @pdb[user] == passwd.crypt(@pdb[user])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
130 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
131 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
132 def setpasswd(user, passwd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
133 salt = [rand(64),rand(64)].pack("C*").tr("\x00-\x3f","A-Za-z0-9./")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
134 @pdb[user] = passwd.crypt(salt)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
135 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
136 def userexist?(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
137 @pdb[user] ? true : false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
138 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
139 def getpasswd(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
140 @pdb[user]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
141 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
142 def delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
143 @pdb.delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
144 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
145 def close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
146 @pdb.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
147 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
148 def newpasswd(length)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
149 srand(Time.now.to_i)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
150 left = "qazxswedcvfrtgb12345"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
151 right = "yhnmjuik.lop;/67890-"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
152 array = [left, right]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
153 (1..length).collect{|i|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
154 a = array[i%array.length]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
155 a[rand(a.length), 1]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
156 }.join('')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
157 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
158 def users()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
159 @pdb.keys
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
160 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
161 private :newpasswd
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
162 def setnewpasswd(user, length=8)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
163 newp = newpasswd(length)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
164 setpasswd(user, newp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
165 newp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
166 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
167 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
168
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
169 class ScheduleDir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
170 def initialize(dir = "s")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
171 @dir = dir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
172 @schedulefile = "sched"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
173 @usermapdir = File.join(@dir, "usermap")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
174 @usermap = mkusermap()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
175 @groupmapdir = File.join(@dir, "groupmap")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
176 @groupmap = mkgroupmap()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
177 @crondir = File.join(@dir, "crondir")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
178
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
179 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
180 def mkusermap()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
181 map = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
182 unless test(?d, @usermapdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
183 mkdir_p(@usermapdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
184 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
185 Dir.foreach(@usermapdir){|u|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
186 next if /^\./ =~ u
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
187 newu = ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
188 u.split('').each{|c| # for security wrapping
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
189 newu << c[0].chr if /[-A-Z_.@]/i =~ c
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
190 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
191 u = newu
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
192 map[u] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
193 d = File.join(@usermapdir, u)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
194 next unless test(?d, d)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
195 Dir.foreach(d){|attr|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
196 next if /^\./ =~ attr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
197 attr.untaint if /^[A-Za-z]+$/ =~ attr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
198 file = File.join(@usermapdir, u, attr)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
199 next unless test(?s, file) && test(?r, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
200 map[u][attr] = IO.readlines(file).join().strip
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
201 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
202 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
203 map
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
204 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
205 def putuserattr(user, attr, text)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
206 # if text==nil, remove it
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
207 d = File.join(@usermapdir, user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
208 Dir.mkdir(d) unless test(?d, d)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
209 file = File.join(d, attr)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
210 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
211 @usermap[user][attr] = text
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
212 if text==nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
213 File.unlink(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
214 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
215 open(file, "w"){|w| w.puts @usermap[user][attr]}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
216 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
217 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
218 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
219 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
220 return {attr => text}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
221 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
222 def getuserattr(user, attr)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
223 # Should we distinguish between attribute is nil and "" ?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
224 if @usermap.has_key?(user) && @usermap[user][attr].is_a?(String) &&
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
225 @usermap[user][attr] > ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
226 return @usermap[user][attr]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
227 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
228 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
229 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
230 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
231
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
232 def nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
233 if @usermap.has_key?(user) && @usermap[user]['name'].is_a?(String) &&
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
234 @usermap[user]['name'] > ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
235 return @usermap[user]['name']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
236 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
237 return user.sub(/@.*/, '')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
238 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
239 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
240 def setnickname(user, nickname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
241 putuserattr(user, 'name', nickname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
242 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
243
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
244 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
245 # make group map
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
246 def collectmembers(gname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
247 @visitedgroup=[] unless @visitedgroup
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
248 return [] unless @visitedgroup.grep(gname).empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
249 @visitedgroup.push(gname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
250 mdir = File.join(@groupmapdir, gname, 'members')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
251 return [] unless test(?d, mdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
252 members = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
253 Dir.foreach(mdir){|item|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
254 next if /^\./ =~ item
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
255 item.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
256 next unless test(?f, File.join(mdir, item))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
257 if /.+@.+/ =~ item
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
258 members << item
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
259 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
260 members += collectmembers(item)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
261 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
262 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
263 @visitedgroup.pop
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
264 members
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
265 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
266 def mkgroupmap()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
267 map = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
268 return map unless test(?d, @groupmapdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
269 @visitedgroup = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
270 Dir.foreach(@groupmapdir){|g|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
271 next if /^\./ =~ g
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
272 newg = ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
273 next unless /^[-a-z0-9_.]+$/i =~ g
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
274 #g.untaint ## untaintじゃだめだ。map{g} のkeyがtaintedになっちゃうよ
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
275 gg = '' # for security wrapping
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
276 g.split('').each{|c| gg << c[0].chr if c != '`'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
277 g = gg
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
278 map[gg] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
279 d = File.join(@groupmapdir, g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
280 next unless test(?d, d)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
281 # get group name
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
282 gnf = File.join(d, 'name')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
283 if test(?r, gnf) && test(?s, gnf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
284 n = IO.readlines(gnf)[0].to_s.strip
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
285 map[g]['name'] = if n > '' then n else g end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
286 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
287 map[g]['name'] = g
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
288 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
289 # get administrators
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
290 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
291 gad = File.join(d, 'admin')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
292 map[g]['admin'] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
293 if test(?d, gad)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
294 Dir.foreach(gad){|a|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
295 # administrator should be a person (not group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
296 next unless /@/ =~ a
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
297 map[g]['admin'] << a
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
298 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
299 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
300 # collect members
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
301 #map[g]['members'] = collectmembers(g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
302 memd = File.join(d, 'members')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
303 map[g]['members'] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
304 if test(?d, memd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
305 Dir.foreach(memd){|a|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
306 next if /^\./ =~ a
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
307 map[g]['members'] << a
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
308 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
309 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
310 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
311 map
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
312 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
313 def groupmap()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
314 @groupmap
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
315 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
316 def groups()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
317 @groupmap.keys
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
318 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
319 def addgroup(grp, users, remove=nil, role='members')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
320 return nil unless @groupmap[grp]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
321 for u in users
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
322 next unless account_exists(u)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
323 mdir = File.join(@groupmapdir, grp, role)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
324 file = File.join(mdir, u)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
325 if remove
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
326 @groupmap[grp][role].delete(u)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
327 File.unlink(file) if test(?e, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
328 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
329 @groupmap[grp][role] << u
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
330 @groupmap[grp][role].uniq
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
331 Dir.mkdir(file) unless test(?d, mdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
332 open(file, "w"){|x|} # Touch it
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
333 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
334 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
335 grp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
336 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
337 def setgroupname(grp, name)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
338 return nil unless @groupmap[grp]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
339 mdir = File.join(@groupmapdir, grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
340 nfile = File.join(mdir, 'name')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
341 @groupmap[grp]['name'] = name
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
342 if grp == name
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
343 # remove the name file because it is default name
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
344 File.unlink(nfile) if test(?e, nfile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
345 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
346 Dir.mkdir(mdir) unless test(?d, mdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
347 open(nfile, "w"){|n| n.puts name.to_s.strip}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
348 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
349 name
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
350 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
351 def creategroup(grp, grpname="", admin=[])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
352 return nil unless /^[-A-Z0-9._:!$%,]+$/i =~ grp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
353 grp.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
354 gdir = File.join(@groupmapdir, grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
355 mkdir_p(gdir) # Should not care errors here
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
356 Dir.mkdir(File.join(gdir, "admin"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
357 Dir.mkdir(File.join(gdir, "members"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
358 @groupmap[grp] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
359 if grpname == ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
360 @groupmap[grp]['name'] = grp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
361 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
362 setgroupname(grp, grpname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
363 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
364 @groupmap[grp]['members'] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
365 @groupmap[grp]['admin'] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
366 addgroup(grp, admin)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
367 addgroup(grp, admin, nil, 'admin')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
368 return @groupmap[grp]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
369 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
370 def createuser(user, email = nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
371 return nil unless /@/ =~ user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
372 return nil if %r@[\/()\;|,$\%^!\#&\'\"]@ =~ user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
373 email = email || user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
374 @usermap[user] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
375 Dir.mkdir(File.join(@usermapdir, user))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
376 putuserattr(user, 'email', email)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
377 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
378 def deleteuser(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
379 return nil unless @usermap[user]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
380 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
381 @usermap[user] # return value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
382 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
383 @usermap.delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
384 rm_rf(File.join(@usermapdir, user))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
385 rm_rf(File.join(@groupmapdir, "*/members/#{user}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
386 rm_rf(File.join(@crondir, "[1-9]*-*-*/#{user}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
387 rm_rf(File.join(@dir, "[1-9]*/[0-9][0-9]/[0-9][0-9]/[0-9]???/#{user}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
388 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
389 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
390 def destroygroup(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
391 return nil unless @groupmap[grp]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
392 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
393 @groupmap[grp] # return value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
394 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
395 @groupmap.delete(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
396 rm_rf(File.join(@groupmapdir, grp))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
397 rm_rf(File.join(@groupmapdir, "*/members/#{grp}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
398 rm_rf(File.join(@crondir, "[1-9]*-*-*/#{grp}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
399 rm_rf(File.join(@dir, "[1-9]*/[0-9][0-9]/[0-9][0-9]/[0-9]???/#{grp}"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
400 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
401 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
402 def rm_rf(path)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
403 if (list = Dir.glob(path))[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
404 for p in list
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
405 system "/bin/rm -rf \"#{p}\""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
406 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
407 cleanup_files(list[0])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
408 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
409 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
410 def account_exists(instance)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
411 if /@/ =~ instance
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
412 true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
413 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
414 ! @groupmap.select{|k, v| k==instance}.empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
415 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
416 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
417 def ismember(user, grouporuser)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
418 return true if user==grouporuser
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
419 if @groupmap[grouporuser]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
420 @groupmap[grouporuser]['members'].grep(user)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
421 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
422 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
423 def isgroup(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
424 @groupmap[grp]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
425 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
426 def isadmin(user, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
427 @groupmap[group] and @groupmap[group]['admin'].grep(user)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
428 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
429 def members(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
430 @groupmap[grp] and ####################@groupmap[grp]['members']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
431 collectmembers(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
432 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
433 def admins(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
434 @groupmap[grp] and @groupmap[grp]['admin']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
435 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
436 def groupname(grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
437 @groupmap[grp] && @groupmap[grp]['name']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
438 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
439 def day_all(d, user=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
440 y, m, d = d.scan(%r,(\d\d\d\d+)/(\d+)/(\d+),)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
441 #daydir = File.join(@dir, "%04d"%y.to_i, "%02d"%m.to_i, "%02d"%d.to_i)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
442 daydir = File.join("s", "%04d"%y.to_i, "%02d"%m.to_i, "%02d"%d.to_i)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
443 sched = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
444 return sched unless test(?d, daydir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
445 Dir.foreach(daydir) {|time|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
446 next if /^\./ =~ time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
447 next unless /^\d\d\d\d$/ =~ time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
448 time.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
449 t = File.join(daydir, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
450 next unless test(?d, t)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
451 sched[time] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
452 Dir.foreach(t){|who|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
453 next if /^\./ =~ who
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
454
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
455 visible = false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
456 #next unless /@/ =~ who # user must be as user@do.ma.in
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
457 next unless account_exists(who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
458 who.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
459 dir = File.join(t, who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
460 next unless test(?d, dir) && test(?x, dir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
461 pub = File.join(dir, 'pub')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
462 if test(?f, pub) && test(?r, pub) && test(?s, pub)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
463 if IO.readlines(pub)[0].to_i > 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
464 visible = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
465 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
466 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
467
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
468
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
469 if ismember(user, who) || visible
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
470 sched[time][who] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
471 file = File.join(dir, @schedulefile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
472 if test(?s, file) && test(?r, file) && test(?s, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
473 sched[time][who]['sched'] = IO.readlines(file).join().chomp!
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
474 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
475 sched[time][who]['pub'] = visible
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
476 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
477 } #|who|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
478 sched.delete(time) if sched[time].empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
479 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
480 sched
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
481 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
482
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
483 def scheduledir(user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
484 sprintf("%s/%04d/%02d/%02d/%04d/%s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
485 @dir, y.to_i, m.to_i, d.to_i, time.to_i, user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
486 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
487 def schedulefile(user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
488 File.join(scheduledir(user, y, m, d, time), @schedulefile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
489 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
490 def mkdir_p(path, mode=0777)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
491 # Do not mkdir `path' for
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
492 # absolute paths
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
493 # those paths which contains `../'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
494 # for the sake of security reason
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
495 return false if %r,\.\./|^/, =~ path
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
496 p = 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
497 i=0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
498 while p=path.index("/", p)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
499 dir = path[0..p].chop
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
500 p += 1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
501 break if i > 10 # overprotecting
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
502 next if test(?d, dir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
503 Dir.mkdir(dir, mode)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
504 i += 1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
505 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
506 Dir.mkdir(path, mode) unless test(?d, path)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
507 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
508
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
509 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
510 # register schedule for user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
511 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
512 def register(user, year, month, day, time, text, replace=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
513 # return code: 0 = succesfull new registration
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
514 # 1 = succesfull appending registration
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
515 dir = scheduledir(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
516 file = schedulefile(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
517 ret = 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
518 um = File.umask(027)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
519 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
520 if !replace && test(?s, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
521 ret = 1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
522 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
523 mkdir_p(dir, 0777)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
524 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
525 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
526 File.umask(um)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
527 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
528 open(file, replace ? "w" : "a"){|out|out.print text}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
529 return ret
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
530 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
531 def getschedule(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
532 file = schedulefile(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
533 if test(?r, file) && test(?s, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
534 return IO.readlines(file).join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
535 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
536 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
537 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
538 def remove(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
539 file = schedulefile(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
540 dir = File.dirname(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
541 if test(?r, file) && test(?s, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
542 File.unlink(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
543 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
544 for f in Dir.glob(File.join(dir, "*"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
545 f.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
546 File.unlink(f)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
547 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
548 Dir.rmdir(dir) if test(?d, dir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
549 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
550 Dir.rmdir(File.dirname(dir))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
551 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
552 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
553 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
554 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
555 # register file
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
556 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
557 def putfile(user, year, month, day, time, file, contents)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
558 scback = @schedulefile
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
559 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
560 @schedulefile = File.basename(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
561 register(user, year, month, day, time, contents, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
562 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
563 @schedulefile = scback
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
564 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
565 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
566 def getfile(user, year, month, day, time, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
567 scback = @schedulefile
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
568 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
569 @schedulefile = File.basename(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
570 getschedule(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
571 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
572 @schedulefile = scback
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
573 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
574 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
575 def removefile(user, year, month, day, time, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
576 dir = scheduledir(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
577 file = File.join(dir, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
578 if test(?e, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
579 File.unlink(file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
580 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
581 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
582 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
583 # registration to crondir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
584 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
585 def cronlink_file(nt_time, user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
586 subdir = nt_time.strftime("%Y-%m-%d-%H%M/#{user}")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
587 cdir = File.join(@crondir, subdir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
588 File.join(cdir, sprintf("%04d-%02d-%02d-%04d", y, m, d, time))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
589 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
590 def register_crondir(nt_time, user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
591 linkfile = cronlink_file(nt_time, user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
592 mkdir_p(File.dirname(linkfile))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
593 scfile = schedulefile(user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
594 if test(?s, scfile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
595 sclink = File.join("../../..", scfile.sub!(Regexp.quote(@dir+'/'), ''))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
596 File.symlink(sclink, linkfile) unless test(?e, linkfile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
597 return linkfile
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
598 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
599 return false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
600 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
601 def remove_crondir(nt_time, user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
602 linkfile = cronlink_file(nt_time, user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
603 scfile = schedulefile(user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
604 if test(?e, linkfile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
605 File.unlink(linkfile)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
606 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
607 dir = linkfile
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
608 2.times {|x|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
609 dir = File.dirname(dir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
610 if Dir.open(dir).collect.length <= 2 # is empty dir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
611 Dir.rmdir(dir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
612 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
613 break
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
614 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
615 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
616 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
617 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
618 return linkfile
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
619 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
620 return false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
621 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
622
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
623 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
624 # return the Hash of crondir {user => files}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
625 def notify_list(asof)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
626 slack = 5*60
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
627 gomifiles = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
628 ntl = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
629 return ntl unless test(?d, @crondir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
630 Dir.foreach(@crondir){|datedir|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
631 dd = File.join(@crondir, datedir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
632 next unless test(?d, dd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
633 next unless /(\d\d\d\d+)-(\d+)-(\d+)-(\d\d\d\d)/ =~ dd
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
634 y, m, d, hm = $1.to_i, $2.to_i, $3.to_i, $4.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
635 hh = hm/100 % 60
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
636 mm = (hm%100) % 60
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
637 t = Time.mktime(y, m, d, hh, mm)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
638 next if t-slack > asof
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
639 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
640 # collect them
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
641 Dir.foreach(dd){|user|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
642 next unless /@/ =~ user || isgroup(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
643 ud = File.join(dd, user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
644 next unless test(?d, ud)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
645 ntl[user] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
646 Dir.foreach(ud){|date|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
647 next if /^\./ =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
648 unless /(\d\d\d\d+)-(\d+)-(\d+)-(\d\d\d\d)/ =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
649 gomifiles << File.join(ud, date)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
650 next
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
651 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
652 f = File.join(ud, date)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
653 if test(?s, f)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
654 ntl[user][date] = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
655 ntl[user][date]['file'] = f
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
656 ntl[user][date]['text'] = IO.readlines(f)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
657 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
658 File.unlink(f) # symlink points to nonexistent file
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
659 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
660 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
661 if ntl[user].empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
662 # if ud does not contain valid cron symlinks,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
663 # ud had been left badly. Remove it.
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
664 ntl.delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
665 cleanup_files(gomifiles)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
666 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
667 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
668 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
669 ntl
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
670 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
671 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
672 # cleanup file and directories
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
673 def cleanup_crondir(time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
674 Dir.foreach(@crnondir){|datedir|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
675 dd = File.join(@crondir, datedir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
676 next unless test(?d, dd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
677 next unless /(\d\d\d\d+)-(\d+)-(\d+)-(\d\d\d\d)/ =~ dd
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
678 y, m, d, hm = $1.to_i, $2.to_i, $3.to_i, $4.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
679 hh = hm/100 % 60
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
680 mm = (hm%100) % 60
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
681 t = Time.mktime(y, m, d, hh, mm)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
682 if t < time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
683 system "rm -rf #{dd}"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
684 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
685 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
686 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
687 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
688 # remove files in FILES, and remove parent directory if possible
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
689 def cleanup_files(files)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
690 sentinel = File.stat(@dir).ino
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
691 for f in files
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
692 File.unlink(f) if test(?e, f)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
693 d = f
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
694 loop {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
695 d = File.dirname(d)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
696 break if d.length < 2
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
697 break if File.stat(d).ino == sentinel
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
698 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
699 puts "rmdir #{d}" if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
700 Dir.rmdir(d)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
701 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
702 break
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
703 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
704 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
705 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
706 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
707 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
708
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
709 class StringIO<IO
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
710 def initialize()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
711 @str=""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
712 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
713 def foo=(str)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
714 @str = str
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
715 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
716 def print(str)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
717 @str << str
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
718 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
719 def puts(str)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
720 @str << str+"\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
721 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
722 def printf(*args)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
723 @str << sprintf(*args)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
724 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
725 def write(bytes)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
726 print(bytes)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
727 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
728 def gets()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
729 return nil if @str == ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
730 p = @str.index(?\n)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
731 if p
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
732 r = @str[0..p]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
733 @str=@str[p+1..-1]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
734 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
735 r = @str
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
736 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
737 return r
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
738 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
739 def readline()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
740 this.gets()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
741 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
742 def readlines()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
743 r = @str
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
744 @str=''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
745 r
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
746 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
747
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
748 def p(*obj)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
749 STDOUT.p(*obj)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
750 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
751 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
752
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
753 class CMDTimeout < Exception
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
754 def initialize()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
755 @pw = IO.pipe
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
756 @pr = IO.pipe
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
757 @pe = IO.pipe
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
758 @timeout = false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
759 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
760 def start(cmd, timeout, mixstderr=false)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
761 if @pid=fork
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
762 @pw[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
763 @pr[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
764 @pe[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
765 # puts "parent!"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
766 if @tk=fork
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
767 # main
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
768 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
769 @pw[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
770 @pr[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
771 @pe[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
772 trap(:INT){exit 0}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
773 sleep timeout
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
774 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
775 @timeout = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
776 STDERR.puts "TIMEOUT"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
777 Process.kill :INT, @pid
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
778 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
779 #puts "Already done"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
780 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
781 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
782 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
783 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
784 # Running this block with pid=@pid
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
785 trap(:INT){@timeout = true; exit 0}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
786 @pw[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
787 STDIN.reopen(@pw[0])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
788 @pw[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
789
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
790 @pr[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
791 STDOUT.reopen(@pr[1])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
792 if mixstderr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
793 STDERR.reopen(@pr[1])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
794 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
795 STDERR.reopen(@pe[1])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
796 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
797 @pr[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
798 @pe[0].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
799 @pe[1].close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
800
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
801 exec *cmd
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
802 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
803 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
804 return [@pw[1], @pr[0], @pe[0]]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
805 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
806 def wait()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
807 Process.waitpid(@pid, nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
808 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
809 def close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
810 @pr.each{|p| p.close unless p.closed?}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
811 @pw.each{|p| p.close unless p.closed?}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
812 @pe.each{|p| p.close unless p.closed?}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
813 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
814 Process.kill :INT, @tk
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
815 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
816 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
817 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
818 def timeout()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
819 @timeout
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
820 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
821 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
822
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
823 class Holiday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
824 def initialize(dir = ".")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
825 @@dir = dir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
826 defined?(@@holiday) || setupHoliday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
827 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
828 def setupHoliday(file = "holiday")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
829 @@holiday = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
830 return unless test(?f, file) && test(?s, file)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
831 IO.foreach(file){|line|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
832 line.strip
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
833 next if /^#/ =~ line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
834 date, what = line.scan(/(\S+)\s+(.*)/)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
835 if %r,(\d+)/(\d+)/(\d+), =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
836 cdate = sprintf("%d/%d/%d", $1.to_i, $2.to_i, $3.to_i)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
837 @@holiday[cdate] || @@holiday[cdate] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
838 @@holiday[cdate] << what
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
839 elsif %r,(\d+)/(\d+), =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
840 cdate = sprintf("%d/%d", $1.to_i, $2.to_i)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
841 @@holiday[cdate] || @@holiday[cdate] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
842 @@holiday[cdate] << what
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
843 elsif %r,(\d+)/(\w+), =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
844 cdate = sprintf("%d/%s", $1.to_i, $2.downcase)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
845 @@holiday[cdate] || @@holiday[cdate] = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
846 @@holiday[cdate] << what
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
847 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
848 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
849 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
850 def isHoliday(y, m, d, wday=nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
851 y, m, d = y.to_i, m.to_i, d.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
852 wname = %w[sun mon tue wed thu fri sat]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
853 holiday = @@holiday[sprintf("%d/%d/%d", y, m, d)] ||
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
854 @@holiday[sprintf("%d/%d", m, d)]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
855 unless holiday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
856 wday = wname[wday || Time.mktime(y, m, d).wday]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
857 nthweek = (d-1)/7+1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
858 holiday = @@holiday[sprintf("%d/w%d%s", m, nthweek, wday)]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
859 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
860 holiday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
861 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
862 def holidays()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
863 @@holiday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
864 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
865 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
866
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
867 class After5
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
868 def initialize()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
869 @me = File.expand_path($0)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
870 @mydir, @myname = File.dirname(@me), File.basename(@me)
1
8145b15d3d6f RCS-revision 1.2
HIROSE Yuuji <yuuji@gentei.org>
parents: 0
diff changeset
871 @mybase = @myname.sub(/\.\w+$/, '')
0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
872 @mydir.untaint
1
8145b15d3d6f RCS-revision 1.2
HIROSE Yuuji <yuuji@gentei.org>
parents: 0
diff changeset
873 @mybase.untaint
0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
874 Dir.chdir @mydir
1
8145b15d3d6f RCS-revision 1.2
HIROSE Yuuji <yuuji@gentei.org>
parents: 0
diff changeset
875 @myname='a5.cgi' if test(?f, "a5.cgi")
0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
876 @conf = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
877 @schedulearea = {'rows'=>'4', 'cols'=>'60', 'name'=>'schedule'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
878 @oldagent = (%r,Mozilla/4, =~ ENV['HTTP_USER_AGENT'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
879 @opt = {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
880 'conf' => @mybase+".cf",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
881 'css' => @mybase+".css",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
882 'logfile' => @mybase+".log",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
883 "sendmail" => "/usr/sbin/sendmail",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
884 'hostcmd' => '/usr/bin/host',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
885 'nslookup' => '/usr/sbin/nsookup',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
886 'bg' => 'ivory',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
887 'at_bsd' => '%H:%M %b %d %Y',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
888 'at_solaris' => '%H:%M %b %d,%Y',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
889 'schedir' => 's',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
890 'tdskip' => '<br>',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
891 'forgot' => 'wasureta',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
892 'size' => @oldagent ? '15' : '40',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
893 'morning' => '6',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
894 'night' => '22',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
895 'alldaydir' => '3000',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
896 'pswdlen' => 4,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
897 'pswddb' => 'a5pswd',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
898 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
899 @ntlist = [
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
900 ['nt10m', "10"+msg('minutes', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
901 ['nt30m', "30"+msg('minutes', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
902 ['nt60m', "60"+msg('minutes', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
903 ['nttoday', msg('theday')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
904 ['nt1d', "1"+msg('days', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
905 ['nt2d', "2"+msg('days', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
906 ['nt3d', "3"+msg('days', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
907 ['nt7d', "7"+msg('days', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
908 ['nt30d', "30"+msg('days', 'before')],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
909 ]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
910 ##@job = "today"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
911 @job = "login"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
912 @sc = ScheduleDir.new
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
913 @O = StringIO.new
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
914 @H = HTMLout.new()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
915 @umback = File.umask
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
916 @author = 'yuuji@gentei.org'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
917 @after5url = 'http://www.gentei.org/~yuuji/software/after5/'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
918 File.umask(007)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
919 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
920 def doit()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
921 @params = getarg()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
922 @cookie = getcookie()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
923 p @cookie if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
924 p @params if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
925
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
926 @O.print @H.contenttype()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
927 @O.print @H.head("After 5", @opt['css'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
928 @O.print @H.startelement("body", true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
929
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
930 ######### @O.puts @H.p(@cookie.inspect) #cookie check!
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
931
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
932 ## x = {"align"=>'center'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
933 ## @H.element("p", x, "hoge", nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
934 ## @H.element("p", nil, "buha", nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
935
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
936 if !@params['passwd'] && @cookie['passwd']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
937 @params['passwd'] = @cookie['passwd']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
938 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
939 if !@params['user'] && @cookie['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
940 @params['user'] = @cookie['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
941 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
942 @params['user'] = safecopy(@params['user'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
943 eval @job
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
944 # @job.call
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
945 @O.print @H.endelement(nil, true) # body
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
946 @O.print "</html>\n" # html
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
947 setcookie()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
948
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
949 print @O.readlines
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
950 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
951 def msg(*keyword)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
952 unless defined?(@msg)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
953 @msg = {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
954 'title' => ['みんなの予定表 <img src="after5.png" alt="「アフター5」" width="107" height="53">', 'Schedule table for us all <img src="after5.png" alt="After 5" width="107" height="53">'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
955 'login' => ['ログイン', 'Login'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
956 'loginfirst' => ['最初にログインすべし', 'Login first'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
957 'autherror' => ['認証エラーがあったと管理者に伝えてくれっす',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
958 'Unexpected authentication error. Please tell this to the administrator'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
959 'yourmail' => ['あなたのメイルアドレス', 'Your email address'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
960 'passwd' => ['パスワード<br>(初回時は空欄)',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
961 'Passowrd<br>Left blank, first time'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
962 'error' => ['エラー:', 'Error: '],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
963 'mailerror' => ['メイルアドレスが違います', 'Invalid email address'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
964 'pswderror' => ['パスワードが違います', 'Password incorrect'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
965 'fmtdaysschedule'=> ['%sの予定', 'Schedule on %s'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
966 'noplan' => ['登録されている予定はありません', 'No plans'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
967 'allday' => ['全日', 'whole day'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
968 'addsched' => ['新規予定項目の登録', 'Register new schedule'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
969 'defthisday' => ['デフォルトの日付はこの日になってま', ''],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
970 '24hour' => ['24時間制4桁でね<br>(0000〜2359)<br>%sは時刻指定なし', 'in 24-hour<br>(0000-2359)<br>%s for whole day'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
971 'reqnotify' => ['通知メイルいるけ?', 'Previous notification'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
972 'rightnow' => ['登録時にすぐ', 'Right now on registration'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
973 'immediatenote' => ['に以下の予定を登録しました',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
974 ", Your schedule has been registered as follows;"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
975 'registerer_is' => ['登録名義: ', 'Register as '],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
976 'registerer' => ['登録者: ', 'registerer: '],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
977 'about' => ['約', 'about'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
978 'minutes' => ['分', 'minutes'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
979 'hours' => ['時間', 'hour(s)'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
980 'days' => ['日', 'day(s)'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
981 'before' => ['前', 'before'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
982 'theday' => ['当日朝', "the day's morning"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
983 'night' => ['(夜)', '(night)'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
984 'publicok' => ['メンバーに<br>見せてもええね?',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
985 'visible from other members?'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
986 'public' => ['公', 'pub'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
987 'nonpublic' => ['非', 'sec'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
988 'yes' => ['はいな', 'yes'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
989 'no' => ['やだ', 'nope'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
990 'invaliddate' => ['日付指定が変みたい', 'Invalid time string'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
991 'past' => ['それはもう過去の話ね', 'It had Pasted'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
992 'putsomething' => ['何か書こうや', 'Write some message please'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
993 'appended' => ['既存の予定に追加しました', 'Appended'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
994 'append' => ['追加', 'append'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
995 'join' => ['参加', 'join'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
996 'regist' => ['登録', 'register'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
997 'remove' => ['削除', 'remove'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
998 'deletion' => ['完全消去', 'deletion'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
999 'deletionwarn' => ['OK押したら即消去。確認とらないぞ',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1000 'Hitting OK immediately delets this group, be carefully!'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1001 'deluser' => ['%s ユーザ消してええかの?', "Delete the user `%s'"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1002 'delgroup' => ['%s グループ消してええかの?', "Delete the group `%s'"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1003 'really?' => ['ほんまにええけ?', 'Really?'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1004 'chicken' => ['ふっ、腰抜けめ', 'Hey, chicken boy'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1005 'modify' => ['修正', 'modify'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1006 'done' => ['完了', 'done'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1007 'success' => ['成功', 'success'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1008 'failure' => ['失敗', 'failure'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1009 'tomonthlist' => ['%s の一覧', 'all %s table'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1010 'notifysubj' => @mybase+"'s reminder for your plan",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1011 'introduce' => ['はいこんにちは、'+@mybase+'ですよ〜。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1012 "Hi, this is #{@mybase}'s notification."],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1013 'notifymail' => ['こんな予定がありまっせ。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1014 "You have some eschedule below;"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1015 'notification' => ['の通知', 'notification'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1016 'newaccount' => ["新しいアカウントを作りました。\n"+
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1017 "パスワードは %s さん宛に送信しておきました。\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1018 "You got new account for #{@mybase}\n" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1019 "Password was sent to %s.\nThank you.\n"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1020 'accessfrom' => ["%s からのアクセスによる送信\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1021 "This mail was sent by the access from %s\n"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1022 'newpassword' => ["%s さんのパスワードは %s です。\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1023 "The password of %s is %s\n"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1024 'mischief' => ["身に覚えのない場合はいたずらです。どうしましょ。",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1025 'If you have no idea for getting this message, '+
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1026 'it is mischief by someone else'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1027 'user' => ['ユーザ', 'user'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1028 'group' => ['グループ', 'group'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1029 'personal' => ['個人で', 'personal'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1030 'registas' => ['グループ予定として登録', 'Register as group'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1031 'joinquit' => ['入退', 'joining/quiting'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1032 'of' => ['の', "'s"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1033 'id' => ['ID(ローマ字1単語空白なしで)', 'ID(without spaces)'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1034 'name' => ['名前', 'name'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1035 'anystring' => ['(日本語OK)', '(any length, any characters)'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1036 'setto' => ['を設定 → ', 'set to '],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1037 'management' => ['管理', 'management'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1038 'administrator' => ['管理者', 'Administrator'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1039 'newgroup' => ['新規グループ作成', 'Create new group'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1040 'adminop' => ['管理<br>操作', "Administrative<br>operation"],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1041 'member' => ['メンバー', 'Member'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1042 'addedtogroup' => ['をグループに追加 →', 'added to the group:'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1043 'removedfromgp' => ['をグループから削除:', 'removed from the group:'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1044 'soleadmin' => ['%s は %s の唯一の管理者なのでやめられないのだ',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1045 "%s is sole administrator of %s. Cannot retire."],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1046 'recursewarn' => ['個人では加入してないが、別の加入グループがこのグループに入っているので実質参加していることになっている。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1047 'Though this member does not join to this group, it is assumed to be joining this group because other group where one joins is joined to this group.'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1048 'regaddress' => ['登録アカウント名', 'Account id'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1049 'existent' => ['既にあるんすよ → ', 'Already exists: '],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1050 'mailaddress' => ['通知送付先アドレス', 'Notification email address'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1051 'weburl' => ['ゲストブックとかURL<br><small>(予定への反応を書いて欲しい場所)</small>', 'Your guest book URL'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1052 'usermodwarn' => ['いちいち yes/no とか確認取らないから押したら最後、気いつけて。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1053 'This is the final decision. Make sure and sure.'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1054 'joinmyself' => ['自分自身が既存のグループに対して入る(IN)か出る(OUT)かを決めるのがここ。自分管理のグループに誰かを足すなら「管理操作」、新たにグループを作るなら',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1055 'In this page, you can decide put yourself IN or OUT of the existing groups. If you want to manage the member of your own group, go to'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1056 'groupwarn' => ['自分が参加してないグループAに、自分が参加しているグループBが含まれている場合、グループAにも加入していると見なされるので気をつけよう。管理者はグループのニックネームを変えられるよ。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1057 'Though you are not member of group A, you are treated as a member of A, if you join to the group B, which is a member of A. Think the nesting of groups carefully, please. Group administrator can change the group nickname.'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1058 'wholemembers' => ['グループ内グループを考慮した上で、現在グループ %s への通知は以下のメンバーに送られる。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1059 "Consiering the groups registered in another group, notification to the group `%s' is send to members as follows."],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1060 'noadmingroup' => ['管理できるグループはないっす',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1061 "'There's no groups under your administration."],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1062 'multiplemail' => ['複数の宛先に通知したいなら..',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1063 'Wanna send notify to multiple address...'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1064 'nickname' => ['ニックネーム', 'nickname'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1065 'shortnameplz' => ['表が崩れるほど長すぎるニックネームは嫌われるよ。短めにね。',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1066 'Because nickname is displayed many times in table, shorter name is prefered.'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1067 'nicknamenote' => ['ニックネームを消去するとデフォルト名になりんす.',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1068 'Default name is displayed if you remove nickname.'],
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1069 'nothingtodo' => ['って何もやることあらへんかったで',
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1070 'Nothing to do for this transaction.']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1071 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1072 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1073 lang=0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1074 keyword.collect{|k|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1075 if @msg[k].is_a?(Array)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1076 @msg[k][lang]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1077 elsif @msg[k].is_a?(String)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1078 @msg[k]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1079 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1080 ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1081 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1082 }.join(['', ' '][lang])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1083 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1084
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1085 def setcookie()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1086 cookievals = %w[user passwd ^nt]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1087 p = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1088 @params.keys.grep(/^(user$|passwd$|nt)/){|v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1089 p[v] = @params[v].to_s.strip
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1090 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1091 c = gencookie(p, 3600*6*1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1092 printf "Set-Cookie: %s\n", c if c
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1093 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1094
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1095 def encode(string) # borrowed from cgi.rb
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1096 string.gsub(/([^ a-zA-Z0-9_.-]+)/n) do
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1097 '%' + $1.unpack('H2' * $1.size).join('%').upcase
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1098 end.tr(' ', '+')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1099 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1100 def decode!(string)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1101 string.gsub!(/\+/, ' ')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1102 string.gsub!(/%(..)/){[$1.hex].pack("c")}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1103 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1104
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1105 def gencookie(a, expire)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1106 x = a.collect{|k, v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1107 sprintf("%s=%s", k, encode(v)) if v
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1108 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1109 x.delete(nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1110 return nil if x.empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1111 str = x.join('&')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1112 ex = (Time.new+expire).to_s
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1113 sprintf "value=%s; expires=%s", encode(str), ex
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1114 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1115
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1116 def login()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1117 @O.print @H.elementln("h1", nil){msg('title')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1118 @O.print @H.elementln("h2", nil){msg('login')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1119 format = {'method'=>'POST', 'action'=>@myname+"?-today"}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1120 @O.print @H.elementln("form", format){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1121 @H.elementln("table", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1122 @H.elementln("tr", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1123 @H.element("td", nil){msg('yourmail')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1124 @H.element("td", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1125 sprintf '<input type="text" size="%s" name="user">', @opt['size']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1126 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1127 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1128 @H.elementln("tr", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1129 @H.element("td", nil){msg('passwd')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1130 @H.element("td", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1131 sprintf '<input type="password" size="%s" name="passwd">', @opt['size']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1132 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1133 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1134 } + '<input type="submit" value="LOGIN">'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1135 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1136 @O.print footer2()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1137 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1138 def open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1139 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1140 PasswdMgr.new(@opt['pswddb'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1141 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1142 STDERR.printf "Cannot open pswd file [%s]\n", @opt['pswddb']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1143 STDERR.printf "euid=#{Process.euid}, uid=#{Process.uid}\n", @opt['pswddb']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1144 nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1145 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1146 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1147 def outputError(*msg)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1148 @O.print @H.p(msg('error')+sprintf(*msg))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1149 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1150 def mailaddress(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1151 email = @sc.getuserattr(user, "email")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1152 email || user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1153 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1154 def webpage(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1155 @sc.getuserattr(user, "webpage")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1156 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1157 def checkauth()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1158 auth = catch (:auth) {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1159 unless @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1160 outputError(@H.a(@myname, msg('loginfirst')))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1161 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1162 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1163 unless pm=open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1164 outputError(msg('autherror'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1165 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1166 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1167 user, passwd = @params['user'], @params['passwd']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1168 email = mailaddress(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1169 if !checkmail(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1170 outputError(msg('mailerror'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1171 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1172 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1173 if pm.userexist?(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1174 if pm.checkpasswd(user, passwd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1175 throw :auth, true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1176 elsif passwd == @opt['forgot']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1177 newp = pm.setnewpasswd(user, @opt['pswdlen'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1178 sendMail(email, "#{@mybase} password",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1179 "(#{ENV['REMOTE_ADDR']} からのアクセスによる送信)\n" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1180 "#{@mybase} 用の #{user} さんのパスワードは\n" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1181 (newp || "未定義") + "\nです。\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1182 @O.print @H.p("#{email} 宛に送信しておきました")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1183 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1184 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1185 outputError(msg('pswderror'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1186 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1187 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1188 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1189 newp = pm.setnewpasswd(user, @opt['pswdlen'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1190 @sc.createuser(user, user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1191 sendMail(email, "#{@mybase} new account",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1192 sprintf(msg('accessfrom'), ENV['REMOTE_ADDR']) +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1193 sprintf(msg('newpassword'), user, newp) +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1194 sprintf(msg('mischief')))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1195 @O.print @H.p(sprintf(msg('newaccount'), user))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1196 @O.print @H.p(@H.a(@myname, msg('login')))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1197 throw :auth, nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1198 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1199 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1200 if auth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1201 return true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1202 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1203 return false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1204 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1205 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1206 def safecopy(string)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1207 return nil unless string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1208 if $SAFE > 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1209 cpy=''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1210 string.split('').each{|c|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1211 cpy << c[0].chr if c[0] != ?` # `
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1212 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1213 cpy
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1214 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1215 string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1216 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1217 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1218 def checkmail(mail)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1219 account, domain = mail.scan(/(.*)@(.*)/)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1220 return false unless account != nil && domain != nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1221 return false unless /^[-0-9a-z_.]+$/oi =~ domain
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1222 domain = safecopy(domain)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1223 require 'socket'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1224 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1225 TCPSocket.gethostbyname(domain)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1226 return true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1227 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1228 if test(?x, @opt["hostcmd"])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1229 open("| #{@opt['hostcmd']} -t mx #{domain}.", "r") {|ns|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1230 #p ns.readlines.grep(/\d,\s*mail exchanger/)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1231 return ! ns.readlines.grep(/is handled .*(by |=)\d+/).empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1232 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1233 elsif test(?x, @opt["nslookup"])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1234 open("| #{@opt['nslookup']} -type=mx #{domain}.", "r") {|ns|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1235 #p ns.readlines.grep(/\d,\s*mail exchanger/)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1236 return ! ns.readlines.grep(/\d,\s*mail exchanger/).empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1237 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1238 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1239 return false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1240 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1241 end # checkmail
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1242
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1243 # Logging
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1244 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1245 def putLog(msg)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1246 msg += "\n" unless /\n/ =~ msg
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1247 open(@opt["logfile"], "a+") {|lp|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1248 lp.print Time.now.to_s + " " + msg
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1249 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1250 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1251
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1252 def sendnotify(whom, subj, body)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1253 users = users()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1254 if grepgroup(whom)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1255 recipients = @sc.members(whom)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1256 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1257 recipients=[whom]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1258 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1259 for u in recipients
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1260 if users.grep(u)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1261 sendMail(mailaddress(u), subj, body)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1262 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1263 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1264 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1265
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1266 def sendMail(to, subject, body)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1267 body = Kconv::tojis(body)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1268 subject = Kconv.tojis(subject)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1269 to = safecopy(to) # cleanup tainted address
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1270 if /\e/ =~ subject # If contains JIS chars...
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1271 subject = subject.split(//,1).pack('m')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1272 subject = "=?iso-2022-jp?B?#{subject}?="
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1273 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1274 subject.gsub!(/\n/, '')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1275 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1276 if (m=open("|-", "w"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1277 m.print "To: #{to}\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1278 m.print "Subject: #{subject}\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1279 m.print "Mime-Version: 1.0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1280 Content-Transfer-Encoding: 7bit
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1281 Content-Type: Text/Plain; charset=iso-2022-jp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1282
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1283 "
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1284 m.print body, "\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1285 m.close
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1286 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1287 # exec(@attr['mail'], "-s", subject, to)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1288 exec(@opt['sendmail'], to)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1289 exit 0;
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1290 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1291 putLog("Sent '#{subject}' to #{to}\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1292 return true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1293 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1294 putLog("FAILED! - Sent '#{subject}' to #{to}\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1295 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1296 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1297 end # sendMail
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1298
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1299 def today()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1300 today = Time.now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1301 showtable(today)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1302 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1303 def isleap?(y)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1304 if y%400 == 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1305 true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1306 elsif y%100 == 0 || y%4 != 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1307 false
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1308 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1309 true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1310 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1311 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1312 def daysofmonth(year, month)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1313 dl = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1314 if month != 2 || !isleap?(year)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1315 dl[month-1]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1316 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1317 29
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1318 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1319 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1320 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1321 # Return the Time object at the last day of last month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1322 def lastmonth(today)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1323 Time.at(Time.mktime(today.year, today.month)-3600*24)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1324 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1325 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1326 # Return the Time object at the first day of next month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1327 def nextmonth(today)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1328 y, m = today.year, today.month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1329 Time.at(Time.mktime(y, m, daysofmonth(y, m))+3600*24)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1330 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1331
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1332 def month(month)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1333 y, m = month.scan(%r,(\d\d\d\d+)/(\d+),)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1334 if y && m
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1335 showtable(Time.mktime(y, m, 1))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1336 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1337 outputError "%s %s", msg('invaliddate'), month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1338 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1339 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1340 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1341 def footer1()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1342 "<br>" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1343 @H.element("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1344 me = @myname+"?-"; delim = " / "
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1345 @H.a(me+'userman', msg('user', 'management')) + delim + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1346 @H.a(me+'groupman', msg('group', 'management'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1347 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1348 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1349
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1350 def footer2()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1351 "<hr>" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1352 @H.element("code") {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1353 "This " + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1354 @H.a(@after5url, "After5") + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1355 " board is maintained by " + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1356 @opt['maintainer'].sub('@', "&#x40;") + "."
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1357 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1358 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1359 def footer()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1360 footer1+footer2
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1361 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1362 def nickname(userORgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1363 if grepgroup(userORgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1364 @sc.groupname(userORgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1365 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1366 @sc.nickname(userORgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1367 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1368 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1369 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1370 # show specified month's calendar
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1371 def showtable(day)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1372 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1373 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1374 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1375
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1376 month = day.month.to_s
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1377 first = Time.mktime(day.year, day.month, 1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1378 last = daysofmonth(day.year, day.month)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1379 wday1 = first.wday
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1380 start = 1-wday1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1381 wname = %w[sun mon tue wed thu fri sat]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1382 today = Time.now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1383 todaym = today.month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1384 todayd = today.day
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1385 tdclass = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1386 tdclass["width"] = "64px" if @oldagent # workaround for NN4
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1387
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1388 holiday = Holiday.new
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1389 # create dayofweek header
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1390 @O.print @H.elementln("h1", nil){sprintf "%d/%d", day.year, day.month}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1391 @O.print @H.startelement("table", {'border'=>"1", 'class'=>'main'})
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1392
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1393 # day of week
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1394 @O.print @H.startelement("tr")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1395 for w in wname
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1396 @O.print @H.element("th", {'class'=>w}){w.capitalize}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1397 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1398 @O.print "\n"+@H.endelement(nil, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1399
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1400 # create day table
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1401 column = start
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1402 ## p day, last
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1403 while column <= last
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1404 @O.print @H.elementln("tr", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1405 (column..column+6).collect{|d|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1406 todayp = (day.month==todaym && d==todayd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1407 wd=d-column
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1408 hd = holiday.isHoliday(day.year, day.month, d, wd)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1409 tdclass['class'] = (hd ? 'holiday' : wname[wd])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1410 @H.element("td", tdclass){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1411 if d>0 && d <= last
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1412 date = "%d/%d/%d"%[day.year, day.month, d]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1413 @H.element("p", {'class'=>todayp ? 'todayline' : 'dayline'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1414 @H.a(@myname+"?-show+"+date, d.to_s)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1415 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1416 # isHoliday?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1417 if hd
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1418 @H.element("small"){hd.join("<br>")}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1419 end.to_s + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1420 @H.element("p", {'class'=>'topic'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1421 s = @sc.day_all(date, @params['user'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1422 if !s.empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1423 s.keys.sort.collect{|time|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1424 s[time].keys.sort.collect{|who|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1425 sprintf "%04s:%s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1426 time == @opt['alldaydir'] ? msg('allday') : time,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1427 nickname(who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1428 }.join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1429 }.join("<br>")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1430 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1431 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1432 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1433 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1434 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1435 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1436 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1437 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1438 }.join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1439 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1440 # ここ活かしてない
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1441 @H.elementln("tr", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1442 (column..column+6).collect{|d|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1443 wd=d%7
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1444 @H.element("td", {'class'=>wname[wd]}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1445 @H.element("div", {'class'=>'scline'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1446 if d>0 && d <= last
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1447 s = @sc.day_all("%d/%d/%d"%[day.year, day.month, d])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1448 unless s.empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1449 s.keys.sort.collect{|time|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1450 s[time].keys.sort.collect{|who|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1451 sprintf "%4s:%s", time, who.sub(/@.*/, '')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1452 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1453 }.join("<br>")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1454 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1455 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1456 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1457 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1458 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1459 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1460 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1461 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1462 }.join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1463 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1464 column += 7
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1465 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1466
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1467 # month-link
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1468 @O.print @H.elementln("tr", {'class'=>'monthlink'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1469 lm1 = lastmonth(day)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1470 lm2 = lastmonth(lm1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1471 lm3 = lastmonth(lm2)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1472 nm1 = nextmonth(day)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1473 nm2 = nextmonth(nm1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1474 nm3 = nextmonth(nm2)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1475 [lm3, lm2, lm1, nil, nm1, nm2, nm3].collect{|t|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1476 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1477 if t.is_a?(Time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1478 ym = sprintf("%d/%d", t.year, t.month)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1479 @H.a(sprintf("%s?-month+%s", @myname, ym), ym)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1480 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1481 sprintf "%d/%d", day.year, day.month
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1482 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1483 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1484 }.join("\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1485 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1486 @O.print "\n"+@H.endelement(nil, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1487
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1488 @O.print "showtable" if @params['user'] == @author
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1489 @O.print footer
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1490 ##schedule.day_all("2003/12/22")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1491 # @O.print @H.endelement()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1492 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1493
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1494 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1495 # Put carrying values
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1496 def hiddenvalues()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1497 h = %w[user].collect{|v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1498 if @params[v]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1499 sprintf "<input type=\"hidden\" name=\"%s\" value=\"%s\">\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1500 v, @params[v]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1501 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1502 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1503 h.delete(nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1504 h.join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1505 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1506 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1507 # Return the string of table
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1508 def dayTableString(s, user, date)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1509 r = ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1510 r << @H.startelement("table", {'border'=>'1'}, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1511 r << @H.element("tr", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1512 @H.element("th", {'class'=>'time'}){'TIME'} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1513 @H.element("th", nil){'Schedule'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1514 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1515 for time in s.keys
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1516 tstr = case time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1517 when @opt['alldaydir']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1518 msg('allday')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1519 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1520 sprintf "%02d:%02d", time.to_i/100, time.to_i%100
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1521 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1522 r << @H.startelement("tr", nil, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1523 r << @H.element("th", {'class'=>'time'}){tstr}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1524 r << @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1525 @H.elementln("table"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1526 s[time].keys.collect{|who|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1527 editable = (user==who || @sc.ismember(user, who))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1528 groupp = grepgroup(who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1529 @H.element("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1530 @H.element("td", {'class'=>groupp ? 'group' : 'who'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1531 if !groupp && webpage(who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1532 @H.a(webpage(who), nickname(who))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1533 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1534 nickname(who)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1535 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1536 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1537 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1538 if editable
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1539 s[time][who]['pub'] ? msg('public') :
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1540 msg('nonpublic')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1541 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1542 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1543 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1544 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1545 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1546 if editable
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1547 @H.a(@myname+"?-modify+#{date}/#{time}/#{who}",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1548 msg('modify'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1549 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1550 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1551 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1552 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1553 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1554 if editable
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1555 @H.a(@myname+"?-remove+#{date}/#{time}/#{who}",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1556 msg('remove'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1557 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1558 @opt['tdskip']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1559 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1560 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1561 @H.element("td"){s[time][who]['sched']}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1562 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1563 }.join("\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1564 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1565 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1566 r << @H.endelement()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1567 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1568 r << @H.endelement()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1569 r
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1570 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1571 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1572 # show the schedule list of specified date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1573 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1574 def show(date)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1575 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1576 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1577 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1578 border1 = {'border'=>'1'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1579 user = safecopy(@params['user'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1580 s = @sc.day_all(date, user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1581 mygroup = @sc.groups().select{|g|@sc.ismember(user, g)}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1582
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1583 @O.print @H.element("h1", nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1584 sprintf msg('fmtdaysschedule'), date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1585 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1586 if s.empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1587 @O.print @H.p(msg('noplan'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1588 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1589 @O.print dayTableString(s, user, date)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1590 end #is_empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1591 thisyear, thismonth, thisday = date.scan(%r,(\d\d\d\d+)/(\d+)/(\d+),)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1592 mstr = sprintf "%04d/%02d", thisyear.to_i, thismonth.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1593 @O.print @H.a(@myname+"?-month+"+mstr,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1594 sprintf(msg('tomonthlist'), mstr))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1595 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1596 # Link button to add new plan
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1597 #now = Time.now+3600*24
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1598 now = Time.mktime(thisyear, thismonth, thisday.to_i, Time.now.hour)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1599 y, m, d, h, min = now.year, now.month, now.day, now.hour, now.min
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1600 @O.print @H.element('h2', nil, true){msg('addsched')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1601 @O.print @H.element('p', nil){msg('defthisday')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1602 @O.print @H.element("form", {'action'=>@myname+"?-addsched", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1603 @H.elementln('table', border1){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1604 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1605 @H.element('th'){'Name'} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1606 @H.element('td'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1607 hiddenvalues() + @sc.nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1608 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1609 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1610 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1611 @H.element('th'){'Year'} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1612 @H.element('td'){@H.select_integer("year", y, y+5, y)}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1613 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1614 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1615 @H.element('th'){'Month'} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1616 @H.element('td'){@H.select_integer("month", 1, 12, m)}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1617 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1618 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1619 @H.element('th'){'Day'} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1620 @H.element('td'){@H.select_integer("day", 1, 31, d)}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1621 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1622 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1623 @H.element('th'){'Time<br>'+ \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1624 sprintf(msg('24hour'), @opt['alldaydir'])} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1625 @H.element('td'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1626 '<input type=text name="time" value="3000" size=8 maxlength="4">'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1627 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1628 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1629 @H.elementln('tr'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1630 @H.element('th'){msg('publicok')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1631 @H.element('td'){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1632 @H.radio('pub', 'yes', msg('yes')+'<br>', true) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1633 @H.radio('pub', 'no', msg('no'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1634 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1635 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1636 ## table
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1637 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1638 @H.elementln("p"){ # put notify mail checkbox
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1639 msg('reqnotify') + '<br>' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1640 @ntlist.collect{|n, v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1641 @H.checkbox(n, 'yes', v, @params[n])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1642 }.join("\n") + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1643 " " + @H.checkbox('rightnow', 'yes', msg('rightnow'), true) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1644 "\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1645 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1646 if mygroup[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1647 @H.elementln("p"){ # put "register as"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1648 msg('registas') + "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1649 mygroup.collect{|g|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1650 @H.radio('registas', g, @sc.groupname(g))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1651 }.join(' ') + "\n/ " + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1652 @H.radio('registas', 'no', msg('personal'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1653 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1654 end.to_s + "\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1655 @H.element("textarea", @schedulearea){} + "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1656 @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1657 } #form
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1658 @O.print "show" if user == @author
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1659 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1660
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1661 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1662 # call process
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1663 def call_process(cmd, input=nil, timeout=10)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1664 prc = CMDTimeout.new
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1665 fds = prc.start(cmd, timeout, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1666 if input
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1667 Thread.start {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1668 fds[0].sync = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1669 fds[0].print.input
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1670 fds[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1671 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1672 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1673 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1674 fds[1].readlines
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1675 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1676 prc.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1677 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1678 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1679 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1680 # notification registerer
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1681 def notify_time(year, month, day, time, symbol)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1682 if (t = time.to_i) > 2359
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1683 hh = mm = 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1684 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1685 hh, mm = t/100, t%100
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1686 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1687 base = Time.mktime(year.to_i, month.to_i, day.to_i, hh, mm)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1688 if /nt(\d+)([mh])$/ =~ symbol
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1689 return nil if t > 2359
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1690 num, unit = $1.to_i, $2.downcase
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1691 rate = {'h'=>3600, 'm'=>60}[unit] || 3600
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1692 return Time.at(base-rate*num)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1693 elsif /nt(\d+)d/ =~ symbol
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1694 seconds = $1.to_i*3600*24
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1695 targetday= Time.at(base-seconds).to_a
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1696 targetnight =
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1697 Time.mktime(*(targetday.indexes(5,4,3)+[@opt['night'].to_i]))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1698 elsif "nttoday" == symbol
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1699 Time.mktime(year.to_i, month.to_i, day.to_i, @opt['morning'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1700 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1701 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1702 def reg_notify(user, year, month, day, time, text, cancelall = nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1703 threshold = 5*60 # Omit notifycation within 30min future
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1704
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1705 y, m, d, t, = year.to_i, month.to_i, day.to_i, time.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1706 if t > 2359
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1707 hh = mm = 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1708 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1709 hh = t/100
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1710 mm = t%100
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1711 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1712 now = Time.now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1713
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1714 filearg = [user, year, month, day, t]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1715 @ntlist.each{|k, v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1716 nt_time = notify_time(year, month, day, t, k)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1717 if !nt_time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1718 # do nothing for allday schedule's notification before some minutes
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1719 elsif cancelall || nt_time < now+threshold ||
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1720 /yes|on|true|1/ !~ @params[k] || !@params[k]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1721 # cancel
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1722 uf = @sc.remove_crondir(nt_time, user, year, month, day, t)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1723 @sc.removefile(*(filearg+[k]))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1724 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1725 # register
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1726 lf = @sc.register_crondir(nt_time, user, year, month, day, t)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1727 @sc.putfile(*(filearg+[k, lf]))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1728 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1729 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1730 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1731 def cancel_notify(user, year, month, day, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1732 reg_notify(user, year, month, day, time, 'dummy', true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1733 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1734 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1735 # add or remove a schedule
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1736 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1737 def add_remove(remove = nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1738 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1739 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1740 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1741 user = registerer = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1742 as = @params['registas']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1743 if as && as > '' && /^no$/ !~ as && @sc.ismember(user, as)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1744 registerer = as
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1745 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1746 now = Time.now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1747 y, m, d, h, min = now.year, now.month, now.day, now.hour, now.min
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1748
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1749 $KCODE='e' if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1750 @O.print @params.inspect if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1751 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1752 # Check the validity of specified time
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1753 sy = @params['year'].to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1754 sm = @params['month'].to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1755 sd = @params['day'].to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1756 tm = @params['time'].to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1757 if tm > 2399
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1758 timedir=@opt['alldaydir']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1759 sh, smin = 23, 59
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1760 tmstr = msg('allday')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1761 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1762 sh = (tm/100).to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1763 smin = (tm%100).to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1764 timedir = sprintf("%04d", tm)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1765 tmstr = sprintf("%d:%02d", sh, smin)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1766 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1767 time = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1768 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1769 time = Time.mktime(sy, sm, sd, sh, smin)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1770 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1771 outputError "%s<br>\nyear=%s<br>month=%s<br>day=%s<br>time=%s\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1772 msg('invaliddate'),
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1773 @params['year'], @params['month'], @params['day'], @params['time']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1774 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1775 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1776 unless @params['schedule'] && @params['schedule'].strip > ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1777 outputError msg('putsomething')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1778 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1779 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1780
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1781 # do remove or addition
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1782 if remove
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1783 cancel_notify(registerer, sy, sm, sd, timedir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1784 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1785 @sc.remove(registerer, sy, sm, sd, timedir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1786 #########@O.print @H.p(msg('remove')+msg('done'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1787 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1788 outputError("Failed"+$!)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1789 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1790 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1791 if time < now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1792 outputError(msg('past'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1793 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1794 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1795 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1796 (text = @params['schedule'].strip.gsub(/\r+\n/, $/)) << "\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1797 replace = (/modify/i =~ @params['editmode'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1798 rc = @sc.register(registerer, sy, sm, sd, timedir, text, replace)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1799 if @params['pub'] && /yes/ =~ @params['pub']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1800 @sc.putfile(registerer, sy, sm, sd, timedir, 'pub', "1\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1801 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1802 @sc.removefile(registerer, sy, sm, sd, timedir, 'pub')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1803 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1804 ######## @O.print @H.p(msg('appended')) if rc == 1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1805 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1806 outputError("Failed"+$!)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1807 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1808 text = @sc.getschedule(registerer, sy, sm, sd, timedir)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1809 reg_notify(registerer, sy, sm, sd, timedir, text)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1810 if @params['rightnow'] && /yes/i =~ @params['rightnow']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1811 header = sprintf("%s/%s/%s %s %s\n%s%s%s\n%s\n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1812 sy, sm, sd, tmstr, msg('immediatenote'),
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1813 msg('registerer_is'), nickname(registerer),
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1814 if user!=registerer
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1815 sprintf(" (%s%s)",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1816 msg('registerer'), nickname(user))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1817 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1818 ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1819 end,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1820 "-"*70)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1821 sendnotify(registerer, "Registration completed", header+text)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1822 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1823 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1824 show(sprintf("%04d/%02d/%02d", sy, sm, sd))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1825 @O.print "add_remove" if user == @author
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1826 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1827
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1828 # add
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1829 def addsched()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1830 add_remove(/remove/i =~ @params['editmode'])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1831 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1832
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1833 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1834 # Display remove or modify screen
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1835 def remove_modify(datetime, remove)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1836 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1837 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1838 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1839
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1840 user = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1841 y, m, d, time, dummy, as =
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1842 datetime.scan(%r,(\d\d\d\d+)/(\d+)/(\d+)/(\d+)(/(.+))?,)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1843 # datetime always contains trailing slash generated by parsedate
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1844 # but if the trailing part is a user(not a group), it is removed
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1845 # because it filtered out by grepgroup() function
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1846 if ! (y && m && d && time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1847 outputError "Invalid time specification"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1848 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1849 elsif as && as > ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1850 unless @sc.ismember(user, as)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1851 outputError "You have no permission to edit group %s's schedule", as
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1852 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1853 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1854 user = as
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1855 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1856 unless text=@sc.getschedule(user, y, m, d, time)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1857 outputError "%s %s", datetime, msg('noplan')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1858 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1859 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1860 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1861 sprintf "%s %s", datetime, remove ? msg('remove') : msg('modify')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1862 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1863 @O.print @H.elementln("form", {'action'=>@myname+"?-addsched", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1864 pubp=(@sc.getfile(user, y, m, d, time, 'pub').to_i > 0)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1865 if as
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1866 @H.hidden("registas", as)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1867 end.to_s + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1868 "<input type=\"hidden\" name=\"year\" value=\"%04d\">\n" % y.to_i + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1869 "<input type=\"hidden\" name=\"month\" value=\"%02d\">\n" % m.to_i + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1870 "<input type=\"hidden\" name=\"day\" value=\"%02d\">\n" % d.to_i + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1871 "<input type=\"hidden\" name=\"time\" value=\"%04d\">\n" % time.to_i + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1872 msg('reqnotify') + "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1873 @ntlist.collect{|nt, v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1874 cronp = @sc.getfile(user, y, m, d, time, nt)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1875 sprintf "<input type=\"checkbox\" name=\"%s\"%s>%s \n",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1876 nt, (cronp ? " checked" : ""), v
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1877 }.join + "<br>" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1878 @H.element("textarea", @schedulearea) {text} + "<br>" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1879 @H.radio("editmode", "append", msg('append')) + ' / ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1880 @H.radio("editmode", "modify", msg('modify'), !remove) + ' / ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1881 @H.radio("editmode", "remove", msg('remove'), remove) + ' / ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1882 "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1883 msg('publicok') + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1884 @H.radio("pub", "yes", msg('yes'), pubp) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1885 @H.radio("pub", "no", msg('no'), !pubp) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1886 '<br>' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1887 @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1888 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1889 @O.print "remove_modify" if user == @author
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1890 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1891 def remove(datetime)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1892 remove_modify(datetime, true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1893 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1894 def modify(datetime)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1895 remove_modify(datetime, false)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1896 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1897
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1898 def prohibitviahttp()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1899 %w[REMOTE_ADDR REMOTE_HOST SERVER_NAME].each{|v|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1900 if ENV[v]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1901 print "Content-type: text/plain\n\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1902 print "Do not call this via CGI"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1903 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1904 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1905 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1906 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1907 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1908 # notify: call via cron
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1909 def notify()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1910 prohibitviahttp()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1911 unless @opt['maintainer']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1912 STDERR.printf "Set maintainer(email-address) in %s\n", @opt['conf']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1913 STDERR.print "(ex) maintainer=yuuji@gentei.org\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1914 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1915 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1916 Dir.chdir @mydir
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1917 line = "-"*25
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1918 indent = " "
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1919 now = Time.now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1920 p "notifylist", @sc.notify_list(now) if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1921 @sc.notify_list(now).each{|u, datehash|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1922 dellist = []
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1923 content = datehash.sort.collect{|date, filehash|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1924 next unless /(\d\d\d\d+)-(\d+)-(\d+)-(\d\d\d\d)/ =~ date
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1925 y, m, d, t = $1.to_i, $2.to_i, $3.to_i, $4.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1926 if t > 2359
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1927 hhmm = msg('allday')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1928 comment = msg('theday')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1929 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1930 hhmm = sprintf "%02d:%02d", t/100, t%100
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1931 diff = Time.mktime(y, m, d, t/100, 5%100) - now
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1932 if diff < 7200
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1933 comment = "%d%s" % [diff/60, msg('minutes', 'before')]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1934 elsif (ddiff=(Time.mktime(y, m, d)-Time.mktime(now.year, now.month, now.day))/3600/24) == 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1935 comment = "%s%d%s" %
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1936 [msg('about'), diff/3600, msg('hours', 'before')]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1937 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1938 comment = "%d%s" % [ddiff, msg('days', 'before')]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1939 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1940 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1941 dellist << filehash['file']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1942 sprintf("%s[[[%d/%d/%d %s]]]%s\n", line, y, m, d, hhmm, line) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1943 sprintf("(%s %s)\n", comment, msg('notification')) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1944 indent+filehash['text'].join(indent) + "\n\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1945 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1946 # content.delete(nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1947 if content
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1948 if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1949 print content
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1950 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1951 content.unshift(msg('introduce')+"\n"+msg('notifymail')+"\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1952 content.unshift(@opt['url'].to_s+"\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1953 if sendnotify(u, msg('notifysubj'), content.join)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1954 # send mail completed
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1955 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1956 @sc.cleanup_files(dellist)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1957 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1958 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1959 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1960 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1961 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1962 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1963 if !(list=@sc.notify_list(now)).empty?
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1964 subj = @mybase+": Undeleted old cron files detected"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1965 files = list.collect{|who, whash|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1966 whash.sort.collect{|date, fhash| fhash['file']}.join("\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1967 }.join("\n")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1968 sendMail(@opt['maintainer'], subj,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1969 "This is `#{@mybase}' in #{@mydir}\n" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1970 "You'd better check and remove these files.\n\n"+files)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1971 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1972
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1973 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1974 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1975
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1976 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1977 # user management
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1978 def userman()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1979 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1980 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1981 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1982 user=@params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1983 nickname = @sc.nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1984 tdclass = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1985 tdclass["width"] = "80px" if @oldagent # workaround for NN4
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1986
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1987 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1988 @mybase+' '+msg('user', 'management')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1989 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1990 @O.print @H.p(@sc.mkusermap.inspect) if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1991 @O.print @H.p(msg('usermodwarn'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1992 @O.print \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1993 @H.elementln("form", {'action'=>@myname+"?-usermod", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1994 @H.elementln("table"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1995 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1996 @H.element("td", tdclass) {msg('regaddress')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1997 @H.element("td") {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1998 @H.element("code"){user}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
1999 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2000 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2001 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2002 @H.element("td", tdclass) {msg('mailaddress')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2003 @H.element("td") {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2004 @H.text("newmail", mailaddress(user), @opt['size'], 80)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2005 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2006 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2007 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2008 @H.element("td", tdclass) {msg('weburl')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2009 @H.element("td") {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2010 @H.text("webpage", webpage(user), @opt['size'], 80)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2011 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2012 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2013 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2014 @H.element("td") {msg('nickname')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2015 @H.element("td") {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2016 @H.text("nickname", nickname, @opt['size'], 10)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2017 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2018 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2019 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2020 @H.elementln("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2021 msg('shortnameplz') + "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2022 @H.a(@after5url+"multiplenotify.html", msg('multiplemail'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2023 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2024 '<br>' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2025 @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2026 } # form
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2027
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2028 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2029 # Next section, REMOVE USER!
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2030 @O.print @H.elementln("h2"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2031 sprintf "%s %s %s", msg('user'), user, msg('deletion')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2032 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2033 @O.print @H.p(msg('deletionwarn'))+"\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2034 @O.print @H.elementln("form", {'action'=>@myname+"?-delusersub+#{user}", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2035 @H.hidden("user", user) + "\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2036 @H.elementln("table"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2037 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2038 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2039 sprintf msg('deluser'), user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2040 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2041 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2042 @H.radio("delete", "yes", msg('yes')) + ' ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2043 @H.radio("delete", "no", msg('no'), true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2044 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2045 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2046 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2047 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2048 sprintf msg('really?'), user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2049 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2050 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2051 @H.radio("delete2", "yes", msg('yes')) + ' ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2052 @H.radio("delete2", "no", msg('no'), true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2053 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2054 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2055 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2056 "<br>\n" + @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2057 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2058
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2059
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2060 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2061 def usermod()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2062 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2063 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2064 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2065 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2066 msg('user', 'management')+" "+msg('done')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2067 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2068 user=@params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2069 email = mailaddress(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2070 newmail = @params['newmail']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2071 nickname = @sc.nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2072 newnn = @params['nickname'].to_s.strip
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2073 webpage = webpage(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2074 newweb = @params['webpage']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2075 if email != newmail
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2076 # change user's address
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2077 if newmail == user
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2078 newvalue = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2079 elsif checkmail(newmail)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2080 newvalue = newmail
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2081 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2082 @O.print @H.elementln("pre"){"Invalid mail address"}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2083 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2084 @O.print @H.elementln("pre"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2085 if @sc.putuserattr(user, 'email', newvalue)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2086 sprintf "new mail address=\"%s\"", mailaddress(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2087 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2088 sprintf "Setting new mail address to \"%s\" failed", newvalue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2089 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2090 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2091 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2092 if nickname != newnn
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2093 if @sc.setnickname(user, newnn)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2094 @O.print @H.p(msg('success'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2095 @O.print @H.elementln("pre"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2096 sprintf "user=\"%s\"\nnickname=\"%s\"", user, @sc.nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2097 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2098 @O.print @H.p(msg('nicknamenote')) if newnn == ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2099 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2100 @O.print @H.p(msg('failure'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2101 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2102 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2103 if newweb > '' && webpage != newweb
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2104 if @sc.putuserattr(user, "webpage", newweb)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2105 @O.print @H.p(msg('success'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2106 @O.print @H.elementln("pre"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2107 sprintf "user=\"%s\"\nwebpage=\"%s\"", user, webpage(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2108 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2109 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2110 @O.print @H.p("Update webpage"+msg('failure'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2111 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2112 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2113 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2114 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2115 # Display form of group management
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2116 def groupman()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2117 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2118 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2119 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2120 user=@params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2121 nickname = @sc.nickname(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2122 tdclass = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2123 tdclass["width"] = "80px" if @oldagent # workaround for NN4
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2124 admclass = {'class'=>'admin'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2125 grmap = @sc.groupmap
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2126
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2127 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2128 @mybase+' '+msg('group', 'management')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2129 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2130 $KCODE='e' if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2131 @O.print grmap.inspect if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2132 @O.print @H.p(msg('joinmyself')+
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2133 @H.a(@myname+"?-newgroup", msg('newgroup')))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2134 @O.print @H.p(msg('usermodwarn'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2135 @O.print \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2136 @H.elementln("form", {'action'=>@myname+"?-groupmod", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2137 @H.elementln("table", {'border'=>'1', 'vertical-align'=>'top'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2138 grmap.collect{|g, ghash|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2139 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2140 @H.element("td", @sc.isadmin(user, g) ? admclass : nil){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2141 g
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2142 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2143 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2144 @H.element("div", {'class'=>'c'}) {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2145 if @sc.isadmin(user, g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2146 @H.a(@myname+"?-admgroup+#{g}", msg('adminop'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2147 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2148 '--'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2149 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2150 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2151 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2152 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2153 memberp = @sc.ismember(user, g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2154 if ghash['admin'].grep(user)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2155 @H.text("groupname-#{g}", ghash['name'], nil, 20)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2156 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2157 ghash['name']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2158 end + '<br>' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2159 @H.radio("groupadd-#{g}", "yes", "IN", memberp) + " / " + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2160 @H.radio("groupadd-#{g}", "no", "OUT", !memberp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2161 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2162 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2163 ghash['members'].collect{|u|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2164 @sc.nickname(u)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2165 }.join(", ")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2166 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2167 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2168 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2169 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2170 '' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2171 @H.p(msg('groupwarn', 'shortnameplz')) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2172 @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2173 } # form
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2174 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2175 def groupmod()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2176 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2177 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2178 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2179 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2180 msg('group', 'management')+" "+msg('done')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2181 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2182 user=@params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2183 @O.print @params.inspect if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2184
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2185 for grp in @sc.groups()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2186 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2187 # as a member, participate or retire
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2188 key = "groupadd-#{grp}"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2189 removep = (/no/i =~ @params[key])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2190 memberp = @sc.ismember(user, grp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2191 if @params[key]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2192 if (!removep) ^ memberp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2193 @sc.addgroup(grp, [user], removep)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2194 @O.print @H.elementln("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2195 sprintf "%s [%s] %s %s", msg('user'), user,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2196 removep ? msg('removedfromgp') : msg('addedtogroup'), grp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2197 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2198 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2199 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2200 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2201 # as a owner, change the name of group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2202 if @sc.isadmin(user, grp) &&
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2203 (newname = @params["groupname-#{grp}"]) &&
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2204 @sc.groupname(grp) != newname
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2205 @sc.setgroupname(grp, newname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2206 @O.print @H.elementln("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2207 sprintf "%s %s%s %s",
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2208 msg('group'), grp, msg('of', 'name', 'setto'), newname
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2209 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2210 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2211 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2212 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2213 def users()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2214 unless pm=open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2215 outputError(msg('autherror'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2216 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2217 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2218 pm.users
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2219 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2220 def grepgroup(gname)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2221 gr = @sc.groups.grep(gname)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2222 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2223 def admgroup(group = nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2224 # if group==nil, create new
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2225 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2226 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2227 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2228 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2229 msg('group', 'management')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2230 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2231 user=@params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2232
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2233 # Check the existent group's validity
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2234 if group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2235 unless (gr=grepgroup(group))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2236 @O.print @H.p("No such group #{group}")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2237 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2238 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2239 group = gr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2240 unless @sc.isadmin(user, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2241 @O.print @H.p("You are not administrator of #{group}.")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2242 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2243 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2244 @O.print @H.elementln("h2"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2245 msg('group')+" #{group}" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2246 if group != @sc.groupname(group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2247 " (#{@sc.groupname(group)})"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2248 end.to_s
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2249 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2250 actionmethod={'action'=>@myname+"?-admgroupsub", 'method'=>'POST'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2251 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2252 # New group creation
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2253 @O.print @H.elementln("h2"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2254 msg('newgroup')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2255 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2256 actionmethod={'action'=>@myname+"?-newgroupsub", 'method'=>'POST'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2257 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2258
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2259 userlist = ([user] + users()).uniq
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2260 myselfclass = {'class'=>'admin'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2261 colspan2 = {'colspan'=>'2'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2262 warnclass = {'class'=>'warn'}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2263 warnp = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2264
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2265 @O.print @H.elementln("form", actionmethod){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2266 @H.hidden('group', group) + "\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2267 if group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2268 ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2269 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2270 # new group creation
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2271 grps = @sc.groups()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2272 i=1
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2273 defname = "group%03d"%i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2274 while grps.grep(defname)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2275 defname = "group%03d"%(i+=1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2276 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2277 @H.element("pre"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2278 msg('group', 'of', 'id')+"\n"+@H.text("group", defname) + "\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2279 msg('group', 'of', 'name', 'anystring')+"\n"+ \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2280 @H.text("gname", '') + "\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2281 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2282 end + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2283 @H.elementln("table", {'border'=>'1'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2284 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2285 @H.element("th"){msg('join')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2286 @H.element("th"){msg('administrator')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2287 @H.element("th"){msg('member')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2288 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2289 userlist.collect{|u|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2290 recursememp = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2291 if group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2292 memberp = (@sc.ismember(u, group) && true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2293 adminp = (@sc.isadmin(u, group) && true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2294 if !memberp && @sc.members(group).grep(u)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2295 recursememp = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2296 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2297 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2298 memberp = adminp = (u == user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2299 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2300 @H.elementln("tr", (u==user ? myselfclass : nil)){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2301 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2302 @H.radio('mem-'+u, 'yes', 'YES / ', memberp) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2303 @H.radio('mem-'+u, 'no', 'NO', !memberp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2304 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2305 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2306 @H.radio('adm-'+u, 'yes', 'YES / ', adminp) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2307 @H.radio('adm-'+u, 'no', 'NO', !adminp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2308 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2309 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2310 @sc.nickname(u) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2311 if recursememp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2312 warnp = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2313 @H.element("span", warnclass){"(*)"}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2314 end.to_s
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2315 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2316 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2317 }.join + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2318 # group names
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2319 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2320 @H.element("th", colspan2){msg('join')} + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2321 @H.element("th"){msg('group')}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2322 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2323 @sc.groups().collect{|g|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2324 next if group == g
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2325 memberp = @sc.ismember(g, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2326 @H.element("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2327 @H.element("td", colspan2){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2328 @H.radio('mem-'+g, 'yes', 'YES / ', memberp) + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2329 @H.radio('mem-'+g, 'no', 'NO', !memberp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2330 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2331 @H.element("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2332 if @sc.isadmin(user, g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2333 @H.a(@myname+"?-admgroup+#{g}", @sc.groupname(g))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2334 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2335 @sc.groupname(g)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2336 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2337 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2338 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2339 }.join
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2340 } + "<br>\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2341 @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2342 } # form
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2343 @O.print @H.p(@H.element("span", warnclass){"(*)"}+
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2344 msg('recursewarn')) if warnp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2345 if group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2346 @O.print @H.p(sprintf(msg('wholemembers'), group))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2347 @O.print @H.elementln("p", {'class'=>'listup'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2348 @sc.members(group).collect{|u|@sc.nickname(u)}.join(", ")}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2349 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2350
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2351 #
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2352 # Next section, REMOVE GROUP!
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2353 return nil unless group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2354 @O.print @H.elementln("h2"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2355 sprintf "%s %s %s", msg('group'), group, msg('deletion')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2356 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2357 @O.print @H.p(msg('deletionwarn'))+"\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2358 @O.print @H.elementln("form", {'action'=>@myname+"?-delgroupsub+#{group}", 'method'=>'POST'}){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2359 @H.hidden("group", group) + "\n" + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2360 @H.elementln("table"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2361 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2362 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2363 sprintf msg('delgroup'), group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2364 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2365 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2366 @H.radio("delete", "yes", msg('yes')) + ' ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2367 @H.radio("delete", "no", msg('no'), true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2368 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2369 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2370 @H.elementln("tr"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2371 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2372 sprintf msg('really?'), group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2373 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2374 @H.elementln("td"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2375 @H.radio("delete2", "yes", msg('yes')) + ' ' + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2376 @H.radio("delete2", "no", msg('no'), true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2377 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2378 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2379 } + \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2380 "<br>\n" + @H.submit_reset("GO")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2381 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2382
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2383 @O.print footer()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2384 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2385 def newgroup()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2386 admgroup(nil)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2387 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2388
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2389 def delgroupsub(group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2390 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2391 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2392 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2393 user = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2394 if group != @params['group']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2395 @O.print @H.p("Group mismatch")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2396 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2397 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2398 unless (gr=grepgroup(group))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2399 @O.print @H.p("No such group #{group}")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2400 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2401 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2402 group = gr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2403 unless @sc.isadmin(user, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2404 @O.print @H.p("You are not administrator of #{group}.")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2405 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2406 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2407 unless @params['delete'] && /yes/i =~ @params['delete'] \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2408 && @params['delete2'] && /yes/i =~ @params['delete2']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2409 @O.print @H.p(msg('chicken'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2410 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2411 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2412 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2413 msg('group')+" #{group} "+msg('deletion')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2414 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2415 @O.print @H.p(@sc.destroygroup(group) ? msg("done") : msg("failure"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2416
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2417 @O.print footer()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2418 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2419
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2420 def deleteuser(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2421 @sc.deleteuser(user) &&
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2422 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2423 pm = open_pm
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2424 pm.delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2425 pm.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2426 true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2427 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2428 nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2429 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2430 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2431 def delusersub(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2432 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2433 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2434 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2435 user = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2436 if user != @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2437 @O.print @H.p("User mismatch")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2438 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2439 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2440 unless (us=users().grep(user)[0])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2441 @O.print @H.p("No such user #{user}")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2442 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2443 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2444 user = us
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2445 unless @params['delete'] && /yes/i =~ @params['delete'] \
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2446 && @params['delete2'] && /yes/i =~ @params['delete2']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2447 @O.print @H.p(msg('chicken'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2448 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2449 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2450 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2451 msg('user')+" #{user} "+msg('deletion')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2452 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2453 @O.print @H.p(deleteuser(user) ? msg("done") : msg("failure"))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2454
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2455 @O.print footer()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2456 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2457
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2458 def admgroupsub()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2459 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2460 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2461 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2462 user = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2463 group = @params['group']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2464 unless (gr=grepgroup(group))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2465 @O.print @H.element("pre"){"No such group #{group.inspect}"}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2466 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2467 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2468 unless @sc.isadmin(user, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2469 @O.print @H.p("You are not administrator of #{group}.")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2470 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2471 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2472 gorup = gr
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2473 @O.print @H.elementln("h1"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2474 msg('group', 'management', 'done')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2475 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2476 @O.print @H.elementln("h2"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2477 msg('group')+" #{group}" +
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2478 if group != @sc.groupname(group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2479 " (#{@sc.groupname(group)})"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2480 end.to_s
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2481 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2482 somethingdone = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2483 for u in users()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2484 for var, kind in {
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2485 "mem"=>['members', 'member'], 'adm'=>['admin', 'administrator']}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2486 memv = "#{var}-#{u}"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2487 if @params[memv]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2488 joinp = ((/^yes/i =~ @params[memv]) && true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2489 membp = if var=='mem'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2490 @sc.ismember(u, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2491 else # admin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2492 @sc.isadmin(u, group)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2493 end && true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2494 if var=='adm' && @sc.admins(group).length == 1 && membp && !joinp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2495 @O.print @H.p(sprintf(msg('soleadmin'), u, group))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2496 elsif joinp ^ membp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2497 somethingdone = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2498 @sc.addgroup(group, [u], !joinp, kind[0])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2499 @O.print @H.elementln("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2500 sprintf "%s [%s](%s) %s %s", msg('user'), u,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2501 msg(kind[1]),
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2502 joinp ? msg('addedtogroup'): msg('removedfromgp'), group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2503 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2504 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2505 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2506 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2507 end # users()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2508
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2509 # add or remove for group in groups
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2510 for g in @sc.groups()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2511 next if g == group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2512 memv = "mem-#{g}"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2513 if @params[memv]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2514 joinp = ((/^yes/i =~ @params[memv]) && true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2515 membp = (@sc.ismember(g, group) && true)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2516 if joinp ^ membp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2517 somethingdone = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2518 @sc.addgroup(group, [g], !joinp)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2519 @O.print @H.elementln("p"){
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2520 sprintf "%s [%s] %s %s", msg('group'), g,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2521 joinp ? msg('addedtogroup'): msg('removedfromgp'), group
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2522 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2523 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2524 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2525 end # groups
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2526 unless somethingdone
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2527 # @O.print @H.p(msg('nothingtodo'))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2528 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2529 @O.print footer()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2530 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2531 def newgroupsub()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2532 if !checkauth
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2533 nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2534 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2535 user = @params['user']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2536 newgroup = @params['group']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2537 newgname = @params['gname']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2538
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2539
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2540 if @sc.groups.grep(newgroup)[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2541 @O.print @H.p(msg('existent')+newgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2542 return nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2543 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2544 @sc.creategroup(newgroup, newgname, [user])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2545 admgroup(newgroup)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2546 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2547
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2548 def setpasswd(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2549 prohibitviahttp()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2550 pm = open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2551 exit 1 unless pm
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2552 if pm.userexist?(user) then
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2553 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2554 system "stty -echo"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2555 STDERR.print "New passwd: "
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2556 p1 = STDIN.gets
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2557 STDERR.print "\nAgain: "
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2558 p2 = STDIN.gets
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2559 ensure
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2560 system "stty echo"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2561 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2562 if (p1 == p2) then
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2563 pm.setpasswd(user, p1.chop!)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2564 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2565 STDERR.print "New password for #{user} set successfully\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2566 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2567 STDERR.print "User #{user} not found\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2568 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2569 pm.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2570 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2571 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2572 def adduser(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2573 prohibitviahttp()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2574 pm = open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2575 exit 1 unless pm
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2576 newpwd = pm.setnewpasswd(user, 4)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2577 print "#{user}'s password is #{newpwd}\n"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2578 pm.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2579 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2580 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2581 def deluser(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2582 prohibitviahttp()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2583 pm = open_pm()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2584 exit 1 unless pm
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2585 pm.delete(user)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2586 pm.close()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2587 exit 0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2588 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2589
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2590 # read configuratoin file
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2591 def readconf(conf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2592 cf = "after5.cf" #conf # || @opt['conf']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2593 cf = File.join(@mydir, cf) unless test(?s, cf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2594 cf = File.join(ENV["HOME"], cf) unless test(?s, cf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2595 return unless test(?s, cf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2596 begin
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2597 IO.foreach(cf){|line|
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2598 next if /^\s *#/ =~ line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2599 line.chop!
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2600 line.sub!(/^\s*#.*/, '')
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2601 next if /^$/ =~ line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2602 case line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2603 # title, type = line.split(/\t+/)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2604 when /^([a-z]+)=(.*)/oi
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2605 key, value = $1, $2
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2606 case value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2607 when /^(no|none|null|nil)$/io
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2608 @opt[key] = nil
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2609 else
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2610 @opt[key] = value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2611 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2612 print "#{key} set to #{value}\n" if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2613 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2614 }
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2615 rescue
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2616 STDERR.print "Configuration file %s not readable\n", cf
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2617 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2618 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2619
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2620 def parsedate(string)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2621 if %r,^(\d\d\d\d+)/(\d+)/(\d+)/(\d+)/([^/]+)$, =~ string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2622 sprintf "%04d/%02d/%02d/%04d/%s", $1.to_i, $2.to_i, $3.to_i, $4.to_i,
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2623 grepgroup($5)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2624 elsif %r,^(\d\d\d\d+)/(\d+)/(\d+)/(\d+), =~ string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2625 sprintf "%04d/%02d/%02d/%04d", $1.to_i, $2.to_i, $3.to_i, $4.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2626 elsif %r,^(\d\d\d\d+)/(\d+)/(\d+), =~ string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2627 sprintf "%04d/%02d/%02d", $1.to_i, $2.to_i, $3.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2628 elsif %r,^(\d\d\d\d+)/(\d+), =~ string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2629 sprintf "%04d/%02d", $1.to_i, $2.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2630 elsif %r,^(\d\d\d\d+)/(\d+), =~ string
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2631 sprintf "%04d", $1.to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2632 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2633 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2634
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2635 def getarg()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2636 argument = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2637
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2638 while /^-/ =~ ARGV[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2639 case ARGV[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2640 when '-f'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2641 conf = ARGV[1]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2642 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2643 when "-d"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2644 $DEBUG = true
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2645 when "-install"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2646 when "-addsched"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2647 @job = "addsched"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2648 when "-today"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2649 @job = "today"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2650 when "-remove"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2651 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2652 @job = 'remove "'+parsedate(ARGV[0])+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2653 when "-modify"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2654 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2655 @job = 'modify "'+parsedate(ARGV[0])+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2656 when "-month"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2657 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2658 @job = 'month "'+parsedate(ARGV[0])+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2659 when "-show"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2660 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2661 # @job = "show '"+ARGV[0]+"'"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2662 @job = "show '"+parsedate(ARGV[0])+"'"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2663 when "-login"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2664 @job = "login"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2665 when "-userman"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2666 @job = "userman"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2667 when "-usermod"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2668 @job = "usermod"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2669 when "-groupinout"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2670 @job = "groupinout"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2671 when "-groupsubmit"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2672 @job = "groupsubmit"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2673 when "-groupman"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2674 @job = "groupman"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2675 when "-groupmod"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2676 @job = "groupmod"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2677 when "-notify"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2678 @job = 'notify' # + exit
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2679 when "-newgroup"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2680 @job = 'newgroup'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2681 when "-admgroup"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2682 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2683 gr = safecopy(grepgroup(ARGV[0]))
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2684 ##gr.untaint
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2685 @job = 'admgroup "'+gr+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2686 when "-admgroupsub"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2687 @job = 'admgroupsub'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2688 when "-newgroupsub"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2689 @job = 'newgroupsub'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2690 when "-delusersub"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2691 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2692 usr = users().grep(ARGV[0])[0]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2693 @job = 'delusersub "'+usr+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2694 when "-delgroupsub"
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2695 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2696 gr = grepgroup(ARGV[0])
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2697 @job = 'delgroupsub "'+gr+'"'
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2698 when /-(setpasswd|deluser|adduser)$/
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2699 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2700 @job = $1+ " '#{ARGV[0]}'" # + exit
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2701 when ""
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2702 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2703 ARGV.shift
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2704 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2705
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2706 readconf(@conf)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2707
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2708 query = ''
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2709 method = ENV["REQUEST_METHOD"]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2710 if /POST/i =~ method then
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2711 length = ENV["CONTENT_LENGTH"].to_i
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2712 query = STDIN.read(length)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2713 elsif /GET/i =~ method then
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2714 query = ENV["QUERY_STRING"]
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2715 else # executed from command line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2716 query = ARGV.join("&")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2717 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2718
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2719 for unit in query.split(/\&/)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2720 if /^([a-z][-_0-9@%a-z.]*)=(.*)/i =~ unit
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2721 key, value = $1, $2
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2722 #value.gsub!(/%(..)/){[$1.hex].pack("c")} # これでURLデコードが一発
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2723 decode!(value)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2724 decode!(key)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2725 value = Kconv::toeuc(value) # EUCに変換
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2726 printf "[%s] = %s\n", key, value if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2727 argument[key] = value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2728 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2729 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2730 argument
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2731 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2732 def getcookie()
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2733 cookie = {}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2734 if /value=(.*)/ =~ ENV['HTTP_COOKIE']
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2735 # value=$1.gsub!(/%(..)/){[$1.hex].pack("c")}
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2736 value=decode!($1)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2737 for line in value.split("&")
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2738 if /(\w+)=(.*)/ =~ line
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2739 key, value = $1, $2
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2740 #value.gsub!(/%(..)/){[$1.hex].pack("c")} # これでURLデコードが一発
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2741 decode!(value)
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2742 value = Kconv::toeuc(value) # EUCに変換
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2743 printf "cookie[%s] = %s\n", key, value if $DEBUG
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2744 cookie[key] = value
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2745 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2746 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2747 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2748 cookie
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2749 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2750 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2751
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2752 After5.new.doit
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2753
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2754 if __FILE__ == $0
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2755 end
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2756
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2757
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2758 # Local variables:
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2759 # buffer-file-coding-system: euc-jp
8f811f47ac60 RCS-revision 1.1
HIROSE Yuuji <yuuji@gentei.org>
parents:
diff changeset
2760 # End:

yatex.org