/[smecontribs]/rpms/smeserver-geneweb/contribs9/smeserver-geneweb-2.1.0-proxypass_services.patch
ViewVC logotype

Annotation of /rpms/smeserver-geneweb/contribs9/smeserver-geneweb-2.1.0-proxypass_services.patch

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.1 - (hide annotations) (download)
Tue Jul 14 18:57:37 2020 UTC (4 years, 4 months ago) by michel
Branch: MAIN
CVS Tags: smeserver-geneweb-2_1_0-4_el6_sme, smeserver-geneweb-2_1_0-5_el6_sme, smeserver-geneweb-2_1_0-3_el6_sme, HEAD
make: « clog » est à jour.

1 michel 1.1 diff -aurN smeserver-geneweb-2.1.0.old/createlinks smeserver-geneweb-2.1.0/createlinks
2     --- smeserver-geneweb-2.1.0.old/createlinks 2019-10-05 19:30:02.000000000 +0400
3     +++ smeserver-geneweb-2.1.0/createlinks 2020-07-13 00:28:21.560000000 +0400
4     @@ -1,37 +1,34 @@
5     #!/usr/bin/perl -w
6    
7     use esmith::Build::CreateLinks qw(:all);
8     -use File::Basename;
9     -use File::Path;
10    
11     # Panel Link
12     panel_link('geneweb', 'manager');
13    
14     my $gw = "/opt/geneweb/gw/gw";
15     +my $srv = "/var/service";
16    
17     -for my $event (qw(
18     - geneweb-modify
19     - ))
20     -{
21     templates2events("$gw/only.txt",
22     - qw(geneweb-modify bootstrap-console-save console-save));
23     -
24     -templates2events("/etc/rc.d/init.d/gwd",
25     - qw(geneweb-modify bootstrap-console-save console-save));
26     -
27     -}
28     -
29     -for my $event (qw(geneweb-modify))
30     -{
31     - safe_symlink("sigusr1",
32     - "root/etc/e-smith/events/$event/services2adjust/httpd-e-smith");
33     - safe_symlink("restart",
34     - "root/etc/e-smith/events/$event/services2adjust/geneweb");
35     -
36     -}
37     -
38     -for my $event (qw(post-upgrade))
39     -{
40     - event_link("geneweb-restart", $event, "05");
41     + qw( geneweb-modify bootstrap-console-save console-save ));
42     +templates2events("$srv/geneweb/run",
43     + qw( geneweb-modify bootstrap-console-save console-save ));
44     +templates2events("$srv/gwsetup/run",
45     + qw( geneweb-modify bootstrap-console-save console-save ));
46     +templates2events("/etc/rc.d/init.d/geneweb",
47     + qw( geneweb-modify bootstrap-console-save console-save ));
48     +templates2events("/etc/rc.d/init.d/gwsetup",
49     + qw( geneweb-modify bootstrap-console-save console-save));
50     +templates2events("/etc/httpd/conf/httpd.conf",
51     + qw( geneweb-modify bootstrap-console-save console-save));
52     +
53     +safe_symlink("sigusr1",
54     + "root/etc/e-smith/events/geneweb-modify/services2adjust/httpd-e-smith");
55     +safe_symlink("restart",
56     + "root/etc/e-smith/events/geneweb-modify/services2adjust/geneweb");
57     +safe_symlink("restart",
58     + "root/etc/e-smith/events/geneweb-modify/services2adjust/gwsetup");
59     +
60     +for my $event (qw(post-upgrade)) {
61     + event_link("geneweb-restart", $event, "05");
62     + event_link("gwsetup-restart", $event, "05");
63     }
64     -
65     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/access smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/access
66     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/access 1970-01-01 04:00:00.000000000 +0400
67     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/access 2020-07-13 12:39:09.219000000 +0400
68     @@ -0,0 +1 @@
69     +private
70     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/domain smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/domain
71     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/domain 1970-01-01 04:00:00.000000000 +0400
72     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/domain 2020-05-01 21:53:37.000000000 +0400
73     @@ -0,0 +1 @@
74     +geneweb
75     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/only smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/only
76     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/only 2007-04-07 15:07:11.000000000 +0400
77     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/only 1970-01-01 04:00:00.000000000 +0400
78     @@ -1 +0,0 @@
79     -127.0.0.1
80     \ Pas de fin de ligne à la fin du fichier
81     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/status smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/status
82     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/status 2007-04-07 15:13:42.000000000 +0400
83     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/status 2020-07-13 12:39:28.644000000 +0400
84     @@ -1 +1 @@
85     -disabled
86     \ Pas de fin de ligne à la fin du fichier
87     +disabled
88     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/TCPPort smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/TCPPort
89     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/TCPPort 1970-01-01 04:00:00.000000000 +0400
90     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/TCPPort 2020-05-01 21:53:37.000000000 +0400
91     @@ -0,0 +1 @@
92     +2317
93     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/type smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/type
94     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/geneweb/type 2007-03-05 00:27:09.000000000 +0400
95     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/geneweb/type 2020-07-13 12:39:35.108000000 +0400
96     @@ -1 +1 @@
97     -service
98     \ Pas de fin de ligne à la fin du fichier
99     +service
100     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/access smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/access
101     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/access 1970-01-01 04:00:00.000000000 +0400
102     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/access 2020-07-13 12:39:47.427000000 +0400
103     @@ -0,0 +1 @@
104     +private
105     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/domain smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/domain
106     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/domain 1970-01-01 04:00:00.000000000 +0400
107     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/domain 2020-05-01 21:53:37.000000000 +0400
108     @@ -0,0 +1 @@
109     +gwsetup
110     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/only smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/only
111     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/only 1970-01-01 04:00:00.000000000 +0400
112     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/only 2020-07-13 12:39:56.699000000 +0400
113     @@ -0,0 +1 @@
114     +127.0.0.1
115     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/status smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/status
116     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/status 1970-01-01 04:00:00.000000000 +0400
117     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/status 2020-07-13 12:40:02.260000000 +0400
118     @@ -0,0 +1 @@
119     +disabled
120     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/TCPPort smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/TCPPort
121     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/TCPPort 1970-01-01 04:00:00.000000000 +0400
122     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/TCPPort 2020-05-01 21:53:37.000000000 +0400
123     @@ -0,0 +1 @@
124     +2316
125     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/type smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/type
126     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/defaults/gwsetup/type 1970-01-01 04:00:00.000000000 +0400
127     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/defaults/gwsetup/type 2020-07-13 12:40:07.732000000 +0400
128     @@ -0,0 +1 @@
129     +service
130     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/migrate/20geneweb smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/migrate/20geneweb
131     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/db/configuration/migrate/20geneweb 1970-01-01 04:00:00.000000000 +0400
132     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/db/configuration/migrate/20geneweb 2020-07-13 12:55:13.523000000 +0400
133     @@ -0,0 +1,30 @@
134     +# create status and access for geneweb and gwsetup if not existing
135     +# set domain if empty
136     +
137     +my $rec;
138     +
139     +for my $service ( qw( geneweb gwsetup ) ) {
140     + if ( $rec = $DB->get($service) ) {
141     + if ( ! $rec->prop('status') ) {
142     + $rec->set_prop('status', 'disabled');
143     + }
144     + if ( ! $rec->prop('access') ) {
145     + $rec->set_prop('access', 'private');
146     + }
147     + if ( ! $rec->prop('domain') ) {
148     + $rec->set_prop('domain', $service . '.' .
149     + ($DB->get('DomainName')->value() || ''));
150     + }
151     + }
152     +}
153     +
154     +# move only IP from geneweb to gwsetup if existing
155     +
156     +my $ip = $DB->get_prop('geneweb', 'only');
157     +my $ip2 = $DB->get_prop('gwsetup', 'only');
158     +
159     +if ( $ip and ! $ip2 ) {
160     + $DB->delete_prop('geneweb','only');
161     + ($DB->get('gwsetup'))->set_prop('only', $ip);
162     +}
163     +
164     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/locale/en-us/etc/e-smith/web/functions/geneweb smeserver-geneweb-2.1.0/root/etc/e-smith/locale/en-us/etc/e-smith/web/functions/geneweb
165     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/locale/en-us/etc/e-smith/web/functions/geneweb 2019-10-05 19:30:02.000000000 +0400
166     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/locale/en-us/etc/e-smith/web/functions/geneweb 2020-07-14 22:29:08.521000000 +0400
167     @@ -38,7 +38,7 @@
168     <entry>
169     <base>SUCCESS</base>
170     <trans><![CDATA[
171     - Successful change... now browse <br/>to port 2316 from your client
172     + Successful change... now browse <br/> enabled services from your client
173     ]]>
174     </trans>
175     </entry>
176     @@ -46,7 +46,7 @@
177     <entry>
178     <base>DESC_GENEWEB_ADMIN_IP_DESCRIPTION</base>
179     <trans>
180     - This IP must be on your local network and be a valid IP (i.e. 192.168.24.244)
181     + This IP must be on your local network and be a valid IP (i.e. 192.168.0.244)
182     </trans>
183     </entry>
184    
185     @@ -82,21 +82,106 @@
186     <base>LABEL_DBDIR_STATUS</base>
187     <trans>Current assigned Geneweb Database(s) directory:</trans>
188     </entry>
189     +
190     <entry>
191     <base>ERR_DIR_NOT_EXIST</base>
192     <trans>Directory not found.</trans>
193     </entry>
194     +
195     <entry>
196     <base>DESC_GENEWEB_BASE_DIR_DESCRIPTION</base>
197     - <trans>This directory must exist on server and be writeable for Geneweb. (geneweb:geneweb 770)</trans>
198     + <trans>This directory must exist on server and be writeable for Geneweb. (geneweb:geneweb 770)
199     + - default is '/opt/geneweb/bases -
200     + </trans>
201     </entry>
202     +
203     <entry>
204     <base>LABEL_GENEWEB_BASE_DIR</base>
205     <trans>New directory for Geneweb database(s). :</trans>
206     </entry>
207     +
208     <entry>
209     <base>NO_CHANGE</base>
210     <trans>No change... no update !
211     </trans>
212     </entry>
213     +
214     + <entry>
215     + <base>GENEWEB_STATUS</base>
216     + <trans>Geneweb server
217     + </trans>
218     + </entry>
219     +
220     + <entry>
221     + <base>GENEWEB_ACCESS</base>
222     + <trans>Geneweb server access
223     + </trans>
224     + </entry>
225     +
226     + <entry>
227     + <base>DESC_GENEWEB</base>
228     + <trans><![CDATA[<br><hr class="sectionbar" /><br><p><b>Geneweb server</b> (geneweb) is generally enabled and publicly accessible.<br>
229     + Geneweb databases can be found in the <b>directory</b> shown below. This location can be changed. <br>
230     + </p>]]>
231     + </trans>
232     + </entry>
233     +
234     + <entry>
235     + <base>GWSETUP_STATUS</base>
236     + <trans>Geneweb administration
237     + </trans>
238     + </entry>
239     +
240     + <entry>
241     + <base>GWSETUP_ACCESS</base>
242     + <trans>Geneweb administration access
243     + </trans>
244     + </entry>
245     +
246     + <entry>
247     + <base>DESC_GWSETUP</base>
248     + <trans> <![CDATA[<p><b>Geneweb administration service</b> (gwsetup) is generally intended for private access.<br>
249     + It is used during <b>setup only</b>.
250     + </p> ]]>
251     + </trans>
252     + </entry>
253     +
254     + <entry>
255     + <base>ERROR_STATUS_GENEWEB</base>
256     + <trans><![CDATA[ <font color="red">GENEWEB service is <b>inactive</b></font> (geneweb) ]]></trans>
257     + </entry>
258     +
259     + <entry>
260     + <base>ERROR_STATUS_GWSETUP</base>
261     + <trans><![CDATA[ <font color="red">GENEWEB administration service is <b>inactive</b></font> (gwsetup) ]]></trans>
262     + </entry>
263     +
264     + <entry>
265     + <base>ERROR2_STATUS_GENEWEB</base>
266     + <trans><![CDATA[ <font color="orange">GENEWEB service should <b>not be active</b></font> (gwd) ]]></trans>
267     + </entry>
268     +
269     + <entry>
270     + <base>ERROR2_STATUS_GWSETUP</base>
271     + <trans><![CDATA[ <font color="orange">GENEWEB administration service should <b>not be active</b></font> (gwsetup) ]]></trans>
272     + </entry>
273     +
274     + <entry>
275     + <base>PRIVATE</base>
276     + <trans>Private</trans>
277     + </entry>
278     +
279     + <entry>
280     + <base>PUBLIC</base>
281     + <trans>Public</trans>
282     + </entry>
283     +
284     + <entry>
285     + <base>DESC_GWSETUP_ACCESS</base>
286     + <trans> <![CDATA[<p> The 'public' access mode is possible but <font color="red"><b>not recommended</b></font> for security reason. <br>
287     + It is even advisable to place it in the <font color="orange">'disabled '</font> state when it is not used.
288     + </p> ]]>
289     + </trans>
290     + </entry>
291     +
292     </lexicon>
293     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/86GwsetupAlias smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/86GwsetupAlias
294     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/86GwsetupAlias 1970-01-01 04:00:00.000000000 +0400
295     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/86GwsetupAlias 2020-05-13 19:14:04.000000000 +0400
296     @@ -0,0 +1,41 @@
297     +{
298     +# gwsetup ( verify settings!)
299     + my $status = $gwsetup{'status'} || 'disabled';
300     +
301     + if ($status eq 'enabled')
302     + {
303     + $OUT .="#-------------------------------------------------\n";
304     + $OUT .="# gwsetup settings from smeserver-gwsetup\n";
305     + $OUT .="#-------------------------------------------------\n";
306     + $OUT .="\n";
307     +
308     + $OUT .= qq(
309     +<LocationMatch ^/(gwsetup|gwd)>
310     + SSLRequireSSL
311     + order deny,allow
312     + deny from all
313     + );
314     +
315     + my $access = ($gwsetup{'access'} || 'private');
316     + if ("$access" eq "private")
317     + {
318     + $OUT .= " allow from $localAccess $externalSSLAccess";
319     + }
320     + elsif ("$access" eq "public")
321     + {
322     + $OUT .= " allow from all";
323     + }
324     + $OUT .= qq(
325     + AuthName "gwsetup"
326     + AuthType Basic
327     + AuthBasicProvider external
328     + AuthExternal pwauth
329     + require user admin
330     +</LocationMatch>
331     + );
332     + }
333     + else
334     + {
335     + $OUT .= "# gwsetup is disabled";
336     + }
337     +}
338     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/VirtualHosts/28gwd_gwsProxyPass smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/VirtualHosts/28gwd_gwsProxyPass
339     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/VirtualHosts/28gwd_gwsProxyPass 1970-01-01 04:00:00.000000000 +0400
340     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/httpd/conf/httpd.conf/VirtualHosts/28gwd_gwsProxyPass 2020-07-13 14:50:01.992000000 +0400
341     @@ -0,0 +1,23 @@
342     +{
343     + # vim: ft=perl:
344     +# proxypass for geneweb and gwsetup
345     +
346     + $haveSSL = (exists ${modSSL}{status} and ${modSSL}{status} eq "enabled") ? 'yes' : 'no';
347     + $plainPort = ${'httpd-e-smith'}{TCPPort} || '80';
348     + $sslPort = ${modSSL}{TCPPort} || '443';
349     +
350     + $OUT = '';
351     + foreach $place ('geneweb','gwsetup') {
352     + if ((${$place}{'status'} || 'disabled') eq 'enabled'){
353     + if (($port eq $plainPort) && ($haveSSL eq 'yes')) {
354     + $OUT .= ' RewriteCond %{REMOTE_ADDR} !^127\.0\.0\.1$' . "\n";
355     + $OUT .= " RewriteRule ^/$place(/.*|\$) https://%{HTTP_HOST}/$place\$1 [L,R]\n\n";
356     + }
357     + $OUT .= " ProxyPass /$place/ http://127.0.0.1:${$place}{TCPPort}/\n";
358     + $OUT .= " ProxyPassReverse /$place/ http://127.0.0.1:${$place}{TCPPort}/\n";
359     +
360     + } else {
361     + $OUT .= " # $place disabled\n";
362     + }
363     + }
364     +}
365     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/geneweb/geneweb_ALL smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/geneweb/geneweb_ALL
366     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/geneweb/geneweb_ALL 1970-01-01 04:00:00.000000000 +0400
367     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/geneweb/geneweb_ALL 2020-05-18 20:45:56.000000000 +0400
368     @@ -0,0 +1,59 @@
369     +#!/bin/sh
370     +# chkconfig: 345 99 01
371     +#
372     +# geneweb: Starts the genealogy Server
373     +#
374     +# Version: @(#) /etc/rc.d/init.d/geneweb 1.0
375     +#
376     +# description: Starts and stops the genealogy Server at boot time and shutdown.
377     +#
378     +# processname: geneweb
379     +# hide: true
380     +
381     +# Source function library.
382     +if [ -f /etc/rc.d/init.d/functions ]; then
383     + . /etc/rc.d/init.d/functions
384     +fi
385     +
386     +GWLANG=$(/sbin/e-smith/db configuration getprop sysconfig Language | sed -e 's/_.*$//')
387     +BD=$(/sbin/e-smith/db configuration getprop geneweb DBDir || echo "/opt/geneweb/bases")
388     +HD="/opt/geneweb/gw/gw"
389     +BIN=$HD/gwd
390     +
391     +start() \{
392     + echo -n "Starting GeneWeb Services (geneweb):"
393     + $BIN -daemon -hd $HD -bd $BD -lang $GWLANG
394     +# daemon $BIN -daemon -lang $GWLANG -log /var/log/geneweb.log -hd $HD -bd $BD
395     + touch /var/lock/subsys/geneweb
396     +\}
397     +
398     +stop() \{
399     + echo -n "Shutting down GeneWeb Service (geneweb): "
400     + killproc $BIN
401     + rm -f /var/lock/subsys/geneweb
402     + echo ""
403     +\}
404     +
405     +restart() \{
406     + echo "Restarting GeneWeb Service (geneweb): "
407     + stop
408     + sleep 1
409     + start
410     +\}
411     +
412     +# See how we were called.
413     +cd $BD
414     +
415     +case "$1" in
416     + start|stop|restart)
417     + $1
418     + ;;
419     + status)
420     + status $BIN
421     + ;;
422     + *)
423     + echo "*** Usage: geneweb \{start|stop|status|restart\}"
424     + exit 1
425     +esac
426     +
427     +exit 0
428     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/gwd/gwd_ALL smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/gwd/gwd_ALL
429     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/gwd/gwd_ALL 2019-10-05 19:30:02.000000000 +0400
430     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/gwd/gwd_ALL 1970-01-01 04:00:00.000000000 +0400
431     @@ -1,64 +0,0 @@
432     -#!/bin/sh
433     -# chkconfig: 345 99 01
434     -#
435     -# gwd: Starts the genealogy Server
436     -#
437     -# Version: @(#) /etc/rc.d/init.d/gwd 1.0
438     -#
439     -# description: Starts and stops the genealogy Server at boot time and shutdown.
440     -#
441     -# processname: gwd
442     -# hide: true
443     -
444     -# Source function library.
445     -if [ -f /etc/rc.d/init.d/functions ]; then
446     - . /etc/rc.d/init.d/functions
447     -fi
448     -
449     -{
450     - my $db_dir = ${'geneweb'}{'DBDir'} || "/opt/geneweb/bases";
451     - $OUT .= <<END_BD;
452     -BD="$db_dir"
453     -END_BD
454     -}
455     -#BD="/opt/geneweb/bases" (default)
456     -HD="/opt/geneweb/gw/gw"
457     -
458     -start() \{
459     - echo "Starting GeneWeb Services:"
460     - $HD/gwd -log /var/log/gwd.log -daemon -hd $HD -bd $BD -setup_link
461     - $HD/gwsetup -daemon -gd $HD 2>> /var/log/gwsetup.log
462     - touch /var/lock/subsys/gwd
463     -\}
464     -
465     -stop() \{
466     - echo -n "Shutting down GeneWeb Services: "
467     - killproc $HD/gwd
468     - killproc $HD/gwsetup
469     - rm -f /var/lock/subsys/gwd
470     - echo
471     -\}
472     -
473     -restart() \{
474     - echo -n "Restarting GeneWeb Services: "
475     - stop
476     - sleep 1
477     - start
478     -\}
479     -
480     -# See how we were called.
481     -cd $BD
482     -
483     -case "$1" in
484     - start|stop|restart)
485     - $1
486     - ;;
487     - status)
488     - status gwd
489     - ;;
490     - *)
491     - echo "*** Usage: gwd \{start|stop|status|restart\}"
492     - exit 1
493     -esac
494     -
495     -exit 0
496     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/gwsetup/gwsetup_ALL smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/gwsetup/gwsetup_ALL
497     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/gwsetup/gwsetup_ALL 1970-01-01 04:00:00.000000000 +0400
498     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/gwsetup/gwsetup_ALL 2020-05-18 20:46:17.000000000 +0400
499     @@ -0,0 +1,68 @@
500     +#!/bin/sh
501     +# chkconfig: 345 99 01
502     +#
503     +# gwsetup: Starts the genealogy Server Administration service
504     +#
505     +# Version: @(#) /etc/rc.d/init.d/gwsetup 1.0
506     +#
507     +# description: Starts and stops the genealogy Server Administration service at boot time and shutdown.
508     +#
509     +# processname: gwsetup
510     +# hide: true
511     +
512     +# Source function library.
513     +if [ -f /etc/rc.d/init.d/functions ]; then
514     + . /etc/rc.d/init.d/functions
515     +fi
516     +
517     +HD="/opt/geneweb/gw/gw"
518     +BIN="$\{HD\}/gwsetup"
519     +
520     +USER="root" #geneweb"
521     +GWLANG=$(/sbin/e-smith/db configuration getprop sysconfig Language | sed -e 's/_.*$//')
522     +
523     +BD=$(/sbin/e-smith/db configuration getprop geneweb DBDir || echo "/opt/geneweb/bases")
524     +TcpPort=$(/sbin/e-smith/db configuration getprop gwsetup TCPPort)
525     +
526     +#OPTIONS="-lang $GWLANG -gd $HD -bindir $HD -p $TcpPort"
527     +
528     +start() \{
529     + echo -n "Starting GeneWeb Setup service (gwsetup):"
530     + $HD/gwsetup -daemon -gd $HD -bindir $HD -p $TcpPort -lang $GWLANG
531     +# daemon --user $USER $BIN -daemon -lang $GWLANG -gd $HD -bindir $HD -p $TcpPort
532     +# daemon --user $USER $BIN $OPTIONS
533     +# 1>> /var/log/gwsetup.log 2>&1
534     +# daemon --check $servicename --user $USER $BIN $OPTIONS
535     + touch /var/lock/subsys/gwsetup
536     +\}
537     +
538     +stop() \{
539     + echo -n "Shutting down GeneWeb Setup service (gwsetup):"
540     + killproc $BIN
541     + rm -f /var/lock/subsys/gwsetup
542     + echo ""
543     +\}
544     +
545     +restart() \{
546     + echo "Restarting GeneWeb Setup service (gwsetup): "
547     + stop
548     + sleep 1
549     + start
550     +\}
551     +
552     +# See how we were called.
553     +cd $BD
554     +
555     +case "$1" in
556     + start|stop|restart)
557     + $1
558     + ;;
559     + status)
560     + status $BIN
561     + ;;
562     + *)
563     + echo "*** Usage: gwsetup \{start|stop|status|restart\}"
564     + exit 1
565     +esac
566     +
567     +exit 0
568     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/masq/45AllowGeneWeb smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/masq/45AllowGeneWeb
569     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/etc/rc.d/init.d/masq/45AllowGeneWeb 2019-10-05 19:30:02.000000000 +0400
570     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/etc/rc.d/init.d/masq/45AllowGeneWeb 1970-01-01 04:00:00.000000000 +0400
571     @@ -1,10 +0,0 @@
572     -# Template fragment at the suggestion of Luiz Zaidan <luiz@zaidan.eng.br> after observing that
573     -# the access to GeneWeb was not consistently being allowed remotely
574     -{
575     - my $status = ${'httpd-e-smith'}{status} || "disabled";
576     - my $access = ${'httpd-e-smith'}{access} || "public";
577     -
578     - $OUT = allow_tcp_in(2317,
579     - ($status eq "enabled") && ($access eq "public"));
580     -}
581     -
582     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/01run_ALL smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/01run_ALL
583     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/01run_ALL 1970-01-01 04:00:00.000000000 +0400
584     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/01run_ALL 2020-07-13 14:32:56.719000000 +0400
585     @@ -0,0 +1,14 @@
586     +exec 2>&1
587     +
588     +BD=$(/sbin/e-smith/db configuration getprop geneweb DBDir || echo '/opt/geneweb/bases')
589     +
590     +TcpPort=$(/sbin/e-smith/db configuration getprop geneweb TCPPort || echo '2317')
591     +
592     +GWLANG=$(/sbin/e-smith/db configuration getprop sysconfig Language | sed -e 's/_.*$//')
593     +
594     +HD="/opt/geneweb/gw/gw"
595     +
596     +BIN=$HD/gwd
597     +
598     +exec $BIN -hd $HD -bd $BD -lang $GWLANG -p $TcpPort -setup_link
599     +
600     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/template-begin smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/template-begin
601     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/template-begin 1970-01-01 04:00:00.000000000 +0400
602     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/template-begin 2020-07-13 00:22:18.029000000 +0400
603     @@ -0,0 +1 @@
604     +#!/bin/sh
605     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/template-end smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/template-end
606     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/geneweb/run/template-end 1970-01-01 04:00:00.000000000 +0400
607     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/geneweb/run/template-end 2020-07-13 00:22:46.501000000 +0400
608     @@ -0,0 +1,2 @@
609     +
610     +# end
611     \ Pas de fin de ligne à la fin du fichier
612     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/01run_ALL smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/01run_ALL
613     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/01run_ALL 1970-01-01 04:00:00.000000000 +0400
614     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/01run_ALL 2020-07-14 21:31:38.401000000 +0400
615     @@ -0,0 +1,14 @@
616     +
617     +exec 2>&1
618     +
619     +USER="root" #geneweb"
620     +
621     +BD=$(/sbin/e-smith/db configuration getprop geneweb DBDir || echo '/opt/geneweb/bases')
622     +TcpPort=$(/sbin/e-smith/db configuration getprop gwsetup TCPPort || echo '2316')
623     +GWLANG=$(/sbin/e-smith/db configuration getprop sysconfig Language | sed -e 's/_.*$//')
624     +
625     +HD="/opt/geneweb/gw/gw"
626     +BIN="$HD/gwsetup"
627     +
628     +cd $BD
629     +exec $BIN -gd $HD -bindir $HD -p $TcpPort -lang $GWLANG
630     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/template-begin smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/template-begin
631     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/template-begin 1970-01-01 04:00:00.000000000 +0400
632     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/template-begin 2020-07-13 00:22:18.000000000 +0400
633     @@ -0,0 +1 @@
634     +#!/bin/sh
635     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/template-end smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/template-end
636     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates/var/service/gwsetup/run/template-end 1970-01-01 04:00:00.000000000 +0400
637     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates/var/service/gwsetup/run/template-end 2020-07-13 00:22:46.000000000 +0400
638     @@ -0,0 +1,2 @@
639     +
640     +# end
641     \ Pas de fin de ligne à la fin du fichier
642     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/geneweb smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/geneweb
643     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/geneweb 1970-01-01 04:00:00.000000000 +0400
644     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/geneweb 2020-07-11 18:43:34.000000000 +0400
645     @@ -0,0 +1,3 @@
646     +UID="root"
647     +GID="root"
648     +PERMS=0755
649     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwd smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwd
650     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwd 2019-10-05 19:30:02.000000000 +0400
651     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwd 1970-01-01 04:00:00.000000000 +0400
652     @@ -1,3 +0,0 @@
653     -UID="root"
654     -GID="root"
655     -PERMS=0754
656     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwsetup smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwsetup
657     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwsetup 1970-01-01 04:00:00.000000000 +0400
658     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/etc/rc.d/init.d/gwsetup 2020-07-11 18:43:44.000000000 +0400
659     @@ -0,0 +1,3 @@
660     +UID="root"
661     +GID="root"
662     +PERMS=0755
663     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/var/service/geneweb/run smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/var/service/geneweb/run
664     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/var/service/geneweb/run 1970-01-01 04:00:00.000000000 +0400
665     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/var/service/geneweb/run 2020-07-12 11:45:24.000000000 +0400
666     @@ -0,0 +1,3 @@
667     +UID="root"
668     +GID="root"
669     +PERMS=0755
670     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/var/service/gwsetup/run smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/var/service/gwsetup/run
671     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/templates.metadata/var/service/gwsetup/run 1970-01-01 04:00:00.000000000 +0400
672     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/templates.metadata/var/service/gwsetup/run 2020-07-12 11:45:24.000000000 +0400
673     @@ -0,0 +1,3 @@
674     +UID="root"
675     +GID="root"
676     +PERMS=0755
677     diff -aurN smeserver-geneweb-2.1.0.old/root/etc/e-smith/web/functions/geneweb smeserver-geneweb-2.1.0/root/etc/e-smith/web/functions/geneweb
678     --- smeserver-geneweb-2.1.0.old/root/etc/e-smith/web/functions/geneweb 2019-10-05 19:30:02.000000000 +0400
679     +++ smeserver-geneweb-2.1.0/root/etc/e-smith/web/functions/geneweb 2020-07-14 22:11:28.506000000 +0400
680     @@ -60,6 +60,7 @@
681     =end testing
682    
683     =cut
684     +# <description>GENEWEB_ADMINACCESS_STATUS_DESCRIPTION</description>
685    
686     __DATA__
687     <form
688     @@ -69,28 +70,60 @@
689    
690     <page name="First"
691     pre-event="print_status_message()">
692     - <description>GENEWEB_ADMINACCESS_STATUS_DESCRIPTION</description>
693     -
694     - <field
695     - type="literal"
696     - id="only"
697     - value="get_only()">
698     - <label>LABEL_ONLY_STATUS</label>
699     - </field>
700     +
701     + <field
702     + type="literal"
703     + id="status_gwsetup"
704     + value="get_gwsetup_st()">
705     + <label>GWSETUP_STATUS</label>
706     + <description>DESC_GWSETUP</description>
707     + </field>
708     +
709     + <field
710     + type="literal"
711     + id="stat_gws"
712     + value="get_stat_gws()">
713     + <label> </label>
714     + </field>
715     +
716     + <field
717     + type="literal"
718     + id="access_gwsetup"
719     + value="get_gwsetup_ac()">
720     + <label>GWSETUP_ACCESS</label>
721     + <description>DESC_GWSETUP_ACCESS</description>
722     + </field>
723     +
724     + <field
725     + type="literal"
726     + id="st_geneweb"
727     + value="get_geneweb_st()">
728     + <label>GENEWEB_STATUS</label>
729     + <description>DESC_GENEWEB</description>
730     + </field>
731     +
732     + <field
733     + type="literal"
734     + id="stat_gwd"
735     + value="get_stat_gwd()">
736     + <label> </label>
737     + </field>
738    
739     - <field
740     - type="literal"
741     - id="dbdir"
742     + <field
743     + type="literal"
744     + id="ac_geneweb"
745     + value="get_geneweb_ac()">
746     + <label>GENEWEB_ACCESS</label>
747     + </field>
748     +
749     + <field
750     + type="literal"
751     + id="dbdir"
752     value="get_dbdir()">
753     - <label>LABEL_DBDIR_STATUS</label>
754     - </field>
755     -
756     - <field
757     - type="literal"
758     - id="button_admin"
759     - value="">
760     - <description>DESC_STATE_ADMIN_BUTTON</description>
761     - </field>
762     + <label>LABEL_DBDIR_STATUS</label>
763     + </field>
764     +
765     + <subroutine src="print_button('NEXT')" />
766    
767     </page>
768    
769     @@ -99,40 +132,53 @@
770     post-event="change_settings()">
771    
772     <field
773     - type="text"
774     - id="geneweb_only"
775     - size="15"
776     - validation="must_be_local">
777     - <label>LABEL_GENEWEB_ADMIN_IP</label>
778     - <description>DESC_GENEWEB_ADMIN_IP_DESCRIPTION</description>
779     - </field>
780     -
781     + type="select"
782     + id="gwsetup_st"
783     + options="'enabled' => 'ENABLED', 'disabled' => 'DISABLED'"
784     + value="get_gwsetup_st()">
785     + <label>GWSETUP_STATUS</label>
786     + <description>DESC_GWSETUP</description>
787     + </field>
788     +
789     <field
790     - type="literal"
791     - id="only"
792     - value="get_only()">
793     - <label>LABEL_ONLY_STATUS</label>
794     - </field>
795     + type="select"
796     + id="gwsetup_ac"
797     + options="'private' => 'PRIVATE', 'public' => 'PUBLIC'"
798     + value="get_gwsetup_ac()">
799     + <label>GWSETUP_ACCESS</label>
800     + <description>DESC_GWSETUP_ACCESS</description>
801     + </field>
802     +
803     + <field
804     + type="select"
805     + id="geneweb_st"
806     + options="'enabled' => 'ENABLED', 'disabled' => 'DISABLED'"
807     + value="get_geneweb_st()">
808     + <label>GENEWEB_STATUS</label>
809     + <description>DESC_GENEWEB</description>
810     + </field>
811     +
812     + <field
813     + type="select"
814     + id="geneweb_ac"
815     + options="'private' => 'PRIVATE', 'public' => 'PUBLIC'"
816     + value="get_geneweb_ac()">
817     + <label>GENEWEB_ACCESS</label>
818     + </field>
819    
820     <field
821     type="text"
822     id="geneweb_dbdir"
823     - size="64"
824     - validation="must_exist">
825     + size="64"
826     + validation="dir_must_exist"
827     + value="get_dbdir()">
828     <label>LABEL_GENEWEB_BASE_DIR</label>
829     <description>DESC_GENEWEB_BASE_DIR_DESCRIPTION</description>
830     </field>
831     -
832     - <field
833     - type="literal"
834     - id="dbdir"
835     - value="get_dbdir()">
836     - <label>LABEL_DBDIR_STATUS</label>
837     - </field>
838    
839     -
840     <subroutine src="print_button('SAVE')" />
841    
842     </page>
843     -
844     +
845     </form>
846     +
847     diff -aurN smeserver-geneweb-2.1.0.old/root/usr/share/perl5/vendor_perl/esmith/FormMagick/Panel/geneweb.pm smeserver-geneweb-2.1.0/root/usr/share/perl5/vendor_perl/esmith/FormMagick/Panel/geneweb.pm
848     --- smeserver-geneweb-2.1.0.old/root/usr/share/perl5/vendor_perl/esmith/FormMagick/Panel/geneweb.pm 2019-10-05 19:47:28.000000000 +0400
849     +++ smeserver-geneweb-2.1.0/root/usr/share/perl5/vendor_perl/esmith/FormMagick/Panel/geneweb.pm 2020-07-14 21:42:07.608000000 +0400
850     @@ -7,81 +7,30 @@
851     package esmith::FormMagick::Panel::geneweb;
852    
853     use strict;
854     -#use warnings;
855     +use warnings;
856     +
857     use esmith::FormMagick;
858     use esmith::ConfigDB;
859     -use esmith::NetworksDB;
860     +use esmith::HostsDB;
861     use esmith::util;
862     +
863     use File::Basename;
864     use Exporter;
865     -use Net::IPv4Addr;
866    
867     our @ISA = qw(esmith::FormMagick Exporter);
868    
869     our @EXPORT = qw(
870     - get_dbdir
871     - must_exist
872     get_prop
873     - get_value
874     - get_only
875     - change_settings
876     - must_be_local
877     );
878    
879     our $VERSION = sprintf '%d.%03d', q$Revision: 0.09 $ =~ /: (\d+).(\d+)/;
880    
881     -our $db = esmith::ConfigDB->open || die "Couldn't open ConfigDB\n";
882     -our $networks = esmith::NetworksDB->open || die "Couldn't open NetworksDB\n";
883     -
884     -=pod
885     -
886     -=head1 NAME
887     -
888     -esmith::FormMagick::Panels::geneweb - Panel providing exclusive single
889     -IP assignment for it's administrative access (:2316)
890     -
891     -=head1 SYNOPSYS
892     -
893     - use esmith::FormMagick::Panel::geneweb;
894     -
895     - my $panel = esmith::FormMagick::Panel::geneweb->new;
896     - $panel->display();
897     -
898     -=head1 DESCRIPTION
899     -
900     -Geneweb geneology server installs two separate server accesses, the database
901     -interface (accessed at $domain:2317/DBname); the administration interface
902     -(accessed at $domain:2316 but only by the single IP assigend by the file
903     -/opt/geneweb/gw/gw/only.txt which defaults to 127.0.0.1). This panel provides a
904     -'non-commandline' form to enter an alternative IP on the LAN from which to
905     -administer Geneweb.
906     -
907     -=cut
908     -
909     -# {{{ new
910     -
911     -=head2 new()
912     -
913     -Exactly as for esmith::FormMagick
914     -
915     -=begin testing
916     +our $cdb = esmith::ConfigDB->open || die "Couldn't open Configuration DB\n";
917    
918     -$ENV{ESMITH_CONFIG_DB} = "10e-smith-base/configuration.conf"
919     -$ENV{ESMITH_NETWORKS_DB} = "10e-smith-base/networks.conf"
920     +our $REGEXP_DOMAIN = qq([a-zA-Z0-9\-\.]+);
921    
922     -use_ok('esmith::FormMgick::Panel::geneweb');
923     -use vars qw($panel);
924     -ok($panel = esmith::FormMagick::Panel::geneweb->new(), "Create panel object");
925     -isa_ok($panel, 'esmith::FormMagick::Panel::geneweb');
926    
927     -=end testing
928     -
929     -=cut
930     -
931     -
932     -
933     -sub new
934     -{
935     +sub new {
936     shift;
937     my $self = esmith::FormMagick->new();
938     $self->{calling_package} = (caller)[0];
939     @@ -90,17 +39,13 @@
940     return $self;
941     }
942    
943     -=head2 get_prop
944    
945     -=cut
946     -
947     -sub get_prop
948     -{
949     +sub get_prop {
950     my $fm = shift if (ref($_[0]) );
951     my $item = shift;
952     my $prop = shift;
953    
954     - my $record = $db->get($item);
955     + my $record = $cdb->get($item);
956     if ($record) {
957     return $record->prop($prop);
958     }
959     @@ -109,124 +54,114 @@
960     }
961     }
962    
963     -=head2 get_value
964    
965     -=cut
966     +sub get_dbdir {
967     + return $cdb->get_prop("geneweb", "DBDir");
968     +}
969    
970     -sub get_value
971     -{
972     - my $fm = shift;
973     - my $item = shift;
974     - my $record = $db->get($item);
975     - #return ($db->get("geneweb")->prop($item));
976     - if ($record) {
977     - return $record->value();
978     - }
979     - else {
980     - return '';
981     - }
982     +
983     +sub get_geneweb_st {
984     + return $cdb->get_prop("geneweb", "status");
985     }
986     -
987     -=head2 get_only
988    
989     -method to retrieve the value of /opt/geneweb/gw/gw/only.txt for the form
990     -=cut
991    
992     -sub get_only
993     -{
994     - return $db->get_prop("geneweb", "only");
995     +sub get_geneweb_ac {
996     + return $cdb->get_prop("geneweb", "access");
997     }
998     -
999     -=head2 get_dbdir
1000    
1001     -method to retrieve the value of /opt/geneweb/bases or other location for the form
1002     -=cut
1003    
1004     -sub get_dbdir
1005     -{
1006     - return $db->get_prop("geneweb", "DBDir");
1007     +sub get_gwsetup_st {
1008     + return $cdb->get_prop("gwsetup", "status");
1009     }
1010    
1011     -=head2 change_settings
1012    
1013     -Sub to change settings as per user input in the panel
1014     -=cut
1015     +sub get_gwsetup_ac {
1016     + return $cdb->get_prop("gwsetup", "access");
1017     +}
1018     +
1019     +
1020     +sub change_settings {
1021    
1022     -sub change_settings
1023     -{
1024     my $self = shift;
1025     my $q = $self->{'cgi'};
1026     - my $n_gw_ip = $q->param("geneweb_only") || '';
1027     - my $n_gw_dbdir = $q->param("geneweb_dbdir") || '';
1028     - if (!($n_gw_ip || $n_gw_dbdir)) {
1029     - return $self->success("NO_CHANGE")
1030     - }
1031     - my $gw_ip = get_only();
1032     - my $gw_dbdir = get_dbdir();
1033     - if (($n_gw_ip eq $gw_ip) && ($n_gw_dbdir eq $gw_dbdir)) {
1034     - return $self->success("NO_CHANGE")
1035     - }
1036     - if ($n_gw_ip) { $db->set_prop("geneweb", "only", $n_gw_ip) }
1037     - if ($n_gw_dbdir) { $db->set_prop("geneweb", "DBDir", $n_gw_dbdir) }
1038     +
1039     + my $n_gw_dbdir = $q->param("geneweb_dbdir") || '';
1040     + my $n_gw_st = $q->param("geneweb_st");
1041     + my $n_gw_ac = $q->param("geneweb_ac");
1042    
1043     - unless ( system ( "/sbin/e-smith/signal-event", "geneweb-modify" ) == 0 )
1044     - {
1045     - $self->error("ERROR_UPDATING");
1046     - return undef;
1047     - }
1048     - return $self->success("SUCCESS");
1049     -}
1050     + my $n_gws_st = $q->param("gwsetup_st");
1051     + my $n_gws_ac = $q->param("gwsetup_ac");
1052    
1053     + my $gw_dbdir = get_dbdir();
1054     + my $gw_st = get_geneweb_st();
1055     + my $gw_ac = get_geneweb_ac();
1056    
1057     -=head2 valid_ip_number
1058     + my $gws_st = get_gwsetup_st();
1059     + my $gws_ac = get_gwsetup_ac();
1060    
1061     -subroutine to validate IP input.
1062     -=cut
1063     + if ( ($n_gw_dbdir eq $gw_dbdir) && ($n_gw_st eq $gw_st)
1064     + && ($n_gw_ac eq $gw_ac) && ($n_gws_st eq $gws_st) && ($n_gws_ac eq $gws_ac) ) {
1065     + return $self->success("NO_CHANGE");
1066     + }
1067     + if ($n_gw_dbdir) { $cdb->set_prop("geneweb", "DBDir", $n_gw_dbdir) };
1068    
1069     -sub must_be_local
1070     -{
1071     - my $self = shift;
1072     - my $q = $self->{cgi};
1073     - my $gw_ip = $q->param("geneweb_only" || '');
1074     - if (!($gw_ip)) { return 'OK'}
1075     - if (!( $gw_ip =~ /^((([01]?[0-9]{1,2}|[2][0-5]{1,2}).){3}([01]?[0-9]{1,2}|[2][0-5]{1,2}))$/ ))
1076     - {
1077     - return 'NOT_VALID_IP';
1078     - }
1079     - # Make sure that the IP is indeed local.
1080     - my $ndb = esmith::NetworksDB->open_ro;
1081     - my @local_list = $ndb->local_access_spec;
1082     -
1083     - foreach my $spec (@local_list)
1084     - {
1085     - if (Net::IPv4Addr::ipv4_in_network($spec, $gw_ip))
1086     - {
1087     - return 'OK';
1088     - }
1089     - }
1090     - # Not OK. The IP is not on any of our local networks.
1091     - return 'ERR_IP_NOT_LOCAL';
1092     + $cdb->set_prop("geneweb", "status", $n_gw_st);
1093     + $cdb->set_prop("geneweb", "access", $n_gw_ac);
1094     +
1095     + $cdb->set_prop("gwsetup", "status", $n_gws_st);
1096     + $cdb->set_prop("gwsetup", "access", $n_gws_ac);
1097     +
1098     + return ( system ( "/sbin/e-smith/signal-event", "geneweb-modify" ) ) ?
1099     + $self->error("ERROR_UPDATING") : $self->success("SUCCESS");
1100     }
1101    
1102     -
1103     -=head2 valid_base_directory
1104    
1105     -subroutine to validate base directory.
1106     -=cut
1107     +sub dir_must_exist {
1108    
1109     -sub must_exist
1110     -{
1111     my $self = shift;
1112     my $q = $self->{cgi};
1113     +
1114     my $gw_dbdir = $q->param("geneweb_dbdir") || '';
1115     + $gw_dbdir = $1 if ($gw_dbdir =~ /^($REGEXP_DOMAIN)$/);
1116     + return 'ERR_DIR_NOT_EXIST' unless ($gw_dbdir);
1117     +
1118     if ($gw_dbdir) {
1119     - if (! -d "$gw_dbdir") { return 'ERR_DIR_NOT_EXIST' }
1120     - # system("su geneweb -c 'touch $gw_dbdir/toto'") == 0
1121     - # or return 'DIR_NOT_WRITEABLE';
1122     - # system("su geneweb -c 'rm -f $gw_dbdir/toto'")
1123     - # return 'DIR_EXIST_AND_WRITEABLE';
1124     + if ( ! -d "$gw_dbdir" ) {
1125     + return $self->localise('ERR_DIR_NOT_EXIST');
1126     + }
1127     }
1128     return 'OK';
1129     }
1130    
1131     +
1132     +sub get_stat_gwd {
1133     +
1134     + my $fm = shift;
1135     + if ( get_geneweb_st() eq 'enabled'
1136     + && system ( "/bin/ps cax | /bin/grep 'gwd' > /dev/null") != 0 ) {
1137     + return $fm->localise('ERROR_STATUS_GENEWEB');
1138     + }
1139     + if ( get_geneweb_st() eq 'disabled'
1140     + && system ( "/bin/ps cax | /bin/grep 'gwd' > /dev/null") == 0 ) {
1141     + return $fm->localise('ERROR2_STATUS_GENEWEB');
1142     + }
1143     + return '';
1144     +}
1145     +
1146     +
1147     +sub get_stat_gws {
1148     +
1149     + my $fm = shift;
1150     + if ( get_gwsetup_st() eq 'enabled'
1151     + && system ( "/bin/ps cax | /bin/grep 'gwsetup' > /dev/null") != 0 ) {
1152     + return $fm->localise('ERROR_STATUS_GWSETUP');
1153     + }
1154     + if ( get_gwsetup_st() eq 'disabled'
1155     + && system ( "/bin/ps cax | /bin/grep 'gwsetup' > /dev/null") == 0 ) {
1156     + return $fm->localise('ERROR2_STATUS_GWSETUP');
1157     + }
1158     + return '';
1159     +}
1160     +
1161     +
1162     1;
1163     diff -aurN smeserver-geneweb-2.1.0.old/root/var/service/geneweb/log/run smeserver-geneweb-2.1.0/root/var/service/geneweb/log/run
1164     --- smeserver-geneweb-2.1.0.old/root/var/service/geneweb/log/run 1970-01-01 04:00:00.000000000 +0400
1165     +++ smeserver-geneweb-2.1.0/root/var/service/geneweb/log/run 2015-05-18 20:08:47.000000000 +0400
1166     @@ -0,0 +1,6 @@
1167     +#!/bin/sh
1168     +
1169     +exec \
1170     + /usr/local/bin/setuidgid smelog \
1171     + /usr/local/bin/multilog t s5000000 \
1172     + /var/log/geneweb
1173     diff -aurN smeserver-geneweb-2.1.0.old/root/var/service/gwsetup/log/run smeserver-geneweb-2.1.0/root/var/service/gwsetup/log/run
1174     --- smeserver-geneweb-2.1.0.old/root/var/service/gwsetup/log/run 1970-01-01 04:00:00.000000000 +0400
1175     +++ smeserver-geneweb-2.1.0/root/var/service/gwsetup/log/run 2020-07-11 19:53:22.699000000 +0400
1176     @@ -0,0 +1,6 @@
1177     +#!/bin/sh
1178     +
1179     +exec \
1180     + /usr/local/bin/setuidgid smelog \
1181     + /usr/local/bin/multilog t s5000000 \
1182     + /var/log/gwsetup

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed