annotate after5.rb @ 2:1110baebe9a9 draft

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

yatex.org