/[smecontribs]/rpms/smeserver-ezmlm-web/contribs10/smeserver-ezmlm-web-1.1.3-bz6978-bz9468-bz11910-sme10next.patch
ViewVC logotype

Annotation of /rpms/smeserver-ezmlm-web/contribs10/smeserver-ezmlm-web-1.1.3-bz6978-bz9468-bz11910-sme10next.patch

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


Revision 1.1 - (hide annotations) (download)
Sun Mar 20 06:23:09 2022 UTC (2 years, 2 months ago) by jpp
Branch: MAIN
CVS Tags: smeserver-ezmlm-web-1_1_3-10_el7_sme, smeserver-ezmlm-web-1_1_3-11_el7_sme
* Sun Mar 20 2022 Jean-Philippe Pialasse <tests@pialasse.com> 1.1.3-10.sme
- fix only subscribers may post  [SME: 6978]
- fix cannot create archive [SME: 9468]
- add more ml properties in server-manager  [SME: 11910]

1 jpp 1.1 diff -Nur --no-dereference smeserver-ezmlm-web-1.1.3.old/createlinks smeserver-ezmlm-web-1.1.3/createlinks
2     --- smeserver-ezmlm-web-1.1.3.old/createlinks 2022-03-20 02:09:58.724000000 -0400
3     +++ smeserver-ezmlm-web-1.1.3/createlinks 2022-03-20 02:19:44.859000000 -0400
4     @@ -33,7 +33,7 @@
5     console-save
6     email-update
7     mailinglist-create
8     - mailinglist-update
9     + mailinglist-modify
10     mailinglist-assign
11     ));
12     templates2events("/home/e-smith/files/ezmlm/lists/webusers",
13     @@ -42,7 +42,7 @@
14     console-save
15     email-update
16     mailinglist-create
17     - mailinglist-update
18     + mailinglist-modify
19     mailinglist-assign
20     ));
21     my $event="smeserver-ezmlm-web-update";
22     diff -Nur --no-dereference smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/events/actions/ezmlm-update smeserver-ezmlm-web-1.1.3/root/etc/e-smith/events/actions/ezmlm-update
23     --- smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/events/actions/ezmlm-update 2014-06-16 11:54:25.000000000 -0400
24     +++ smeserver-ezmlm-web-1.1.3/root/etc/e-smith/events/actions/ezmlm-update 2022-03-20 02:11:36.623000000 -0400
25     @@ -38,7 +38,7 @@
26     die "event argument missing." unless defined ($event);
27    
28     my $listName = $ARGV[1];
29     -die "listName argument missing." unless defined ($listName);
30     +die "listName argument missing." unless defined ($listName) || $event eq "smeserver-ezmlm-web-update";
31    
32     # We really want to do all ezmlm functions as the user ezmlm - saves
33     # lots of permissions fixups later on
34     @@ -63,6 +63,47 @@
35     # XXX The permissions should be in the RPM spec file - just fix it for now
36     esmith::util::chownFile("ezmlm", "ezmlm", $ownerHome);
37    
38     +
39     +if ( $event eq "smeserver-ezmlm-web-update" )
40     +{
41     + my $ezmlm = new Mail::Ezmlm;
42     + # check default hostname
43     + my $thisdomain = $ezmlm->_getdefaultdomain;
44     + # fix perms
45     + my $listHomeBase="$ownerHome/lists";
46     + opendir(DIR, $listHomeBase)|| die "can't opendir $listHomeBase: $!";
47     + foreach my $listName ( grep { not /^\./ and -d "$listHomeBase/$_" } readdir(DIR) )
48     + {
49     + next unless $accounts->get($listName);
50     + my $listHost=$accounts->get($listName)->prop("Domain");
51     + my $listHome="$listHomeBase/$listName";
52     + my $dotQmail = ".qmail-${listName}";
53     + my $listAlias = "${ownerHome}/${dotQmail}";
54     + # fix file perms
55     + fixperms($listHost,$thisdomain,$listHome,$listName);
56     + # fix list version
57     + if (-f "$listHome/flags")
58     + {
59     + $ezmlm->setlist("$listHome");
60     + my $flags = $ezmlm->_getconfig_idx5();
61     + $flags =~ s/[CV]//ig;
62     + print "$flags\n";
63     + $ezmlm->update($flags);# or die $ezmlm->error();
64     + }
65     + }
66     + # delete broken .qmail links
67     + opendir(DIR, $ownerHome)|| die "can't opendir $ownerHome: $!";
68     + foreach my $link (readdir DIR) {
69     + next unless -l "$ownerHome/$link" and not -e readlink("$ownerHome/$link");
70     + print "Removing broken link $link\n";
71     + unlink "$ownerHome/$link" or die "Can't delete '$link': $!";;
72     + closedir(DIR);
73     + }
74     +
75     + exit 0
76     +}
77     +
78     +
79     $> = $pw->uid;
80     $) = $pw->gid;
81    
82     @@ -104,32 +145,85 @@
83     elsif ( $event eq "mailinglist-delete" )
84     {
85     # Remove the .qmail files for this list
86     - find(\&deleteWanted, $ownerHome);
87     -
88     + #$> = 0;
89     + #$) = 0;
90     + for ( readdir(DIR) )
91     + {
92     + unlink "$ownerHome/$_" if /^$dotQmail$/ ||
93     + /^$dotQmail-accept-default$/ ||
94     + /^$dotQmail-default$/ ||
95     + /^$dotQmail-digest-owner$/ ||
96     + /^$dotQmail-digest-return-default$/ ||
97     + /^$dotQmail-owner$/ ||
98     + /^$dotQmail-reject-default$/ ||
99     + /^$dotQmail-return-default$/;
100     + }
101     + closedir(DIR);
102     # And the list management directory
103     system( '/bin/rm', '-rf', $listHome ) ==0 or
104     die "Couldn't remove list directory $listHome";
105     }
106     +elsif ( $event eq "mailinglist-modify" )
107     +{
108     + my $ezmlm = new Mail::Ezmlm;
109     + # check default hostname
110     + my $thisdomain = $ezmlm->_getdefaultdomain;
111     + # update /create inlocal if needed.
112     + $> = 0;
113     + $) = 0;
114     + fixperms($listHost,$thisdomain,$listHome,$listName);
115     +
116     +}
117     else
118     {
119     die "Couldn't work out function to call for $0";
120     }
121    
122     -#----------------------------------------------------------------------
123     -# Called by File::Find
124     -#----------------------------------------------------------------------
125     -sub deleteWanted
126     +#==============================================================
127     +# fix ml perms and needed files
128     +#==============================================================
129     +our @content;
130     +our $search="";
131     +sub fixperms
132     {
133     - return unless
134     - /^$dotQmail$/ ||
135     - /^$dotQmail-accept-default$/ ||
136     - /^$dotQmail-default$/ ||
137     - /^$dotQmail-digest-owner$/ ||
138     - /^$dotQmail-digest-return-default$/ ||
139     - /^$dotQmail-owner$/ ||
140     - /^$dotQmail-reject-default$/ ||
141     - /^$dotQmail-return-default$/;
142     -
143     - unlink($_) || die "Couldn't unlink($_)";
144     + my $listHost = shift;
145     + my $thisdomain = shift;
146     + my $listHome = shift;
147     + my $listName = shift;
148     +
149     + if ( "$listHost" ne "$thisdomain")
150     + {
151     + open(INLOCAL, ">$listHome/inlocal");
152     + print INLOCAL "$listName\n";
153     + close INLOCAL;
154     + }
155     + # check all file in folder are "ezmlm", "admin"
156     + my @readread= qw(archnum inlocal mimeremove num prefix webnames);
157     + opendir(DIR, $listHome) || die "can't opendir $listHome: $!";
158     + for $a ( grep { not /^\./ } readdir(DIR) )
159     + {
160     + esmith::util::chownFile("ezmlm", "admin", "$listHome/$a");
161     + if ( -d "$listHome/$a" )
162     + {
163     + chmod 0700, "$listHome/$a";
164     + }
165     + elsif ( $a ~~ @readread)
166     + {
167     + chmod 0644, "$listHome/$a";
168     + }
169     + else
170     + {
171     + chmod 0600, "$listHome/$a";
172     + }
173     + }
174     + closedir DIR;
175     + # all archives subfolder and files "ezmlm", "ezmlm"
176     + @content=();
177     + $search="$listHome/archive"; find( \&wanted, $search);
178     + $search="$listHome/bounce"; find( \&wanted, $search);
179     + map {esmith::util::chownFile("ezmlm","ezmlm",$_) } @content;
180     +}
181     +sub wanted {
182     + push @content, $File::Find::name unless $File::Find::name eq $search;
183     + return;
184     }
185     -
186     diff -Nur --no-dereference smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/templates/opt/mailinglist/config.pm smeserver-ezmlm-web-1.1.3/root/etc/e-smith/templates/opt/mailinglist/config.pm
187     --- smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/templates/opt/mailinglist/config.pm 1969-12-31 19:00:00.000000000 -0500
188     +++ smeserver-ezmlm-web-1.1.3/root/etc/e-smith/templates/opt/mailinglist/config.pm 2022-03-20 02:11:36.056000000 -0400
189     @@ -0,0 +1,101 @@
190     +#---------------------------------------------------------------------------
191     +# ezmlm-www (configuration file - see README)
192     +#---------------------------------------------------------------------------
193     +
194     +#---------------------------------------------------------------------------
195     +#-- Mailing list configuration goes here:
196     +{
197     + use esmith::AccountsDB;
198     + my $adb = esmith::AccountsDB->open_ro();
199     + $OUT = "";
200     + my @sortings=('thread' , 'date' , 'subject' );
201     + foreach my $list ($adb->get_all_by_prop(type => 'mailinglist'))
202     + {
203     + next if (($list->prop('DisplayArchives') || 'disabled') ne 'enabled');
204     + my $key= $list->key;
205     + my $dompart=$list->prop('Domain');
206     + my $name = "$key\@$dompart" ;
207     + my $conceal_senders = ( ( $list->prop('conceal_senders') || 'enabled' ) eq 'enabled')? 1 : 0;
208     + my $Description = $list->prop('Description') || "no description";
209     + my $default_sorting = ( $list->prop('default_sorting') ~~ @sortings ) ? $list->prop('default_sorting') : 'thread';
210     + my $show_html = (( $list->prop('show_html') || 'enabled') eq 'enabled')? 1 : 0;
211     + my $highlight = (( $list->prop('highlight') ||'enabled') eq 'enabled')? 1 : 0;
212     + my $show_inline_images = (( $list->prop('show_inline_images') || 'enabled') eq 'enabled')? 1 : 0;
213     + my $subscription_info = (( $list->prop('subscription_info') || 'disabled') eq 'enabled') ? 1 : 0;
214     + my $descending_by_default = (( $list->prop('descending_by_default') || 'enabled') eq 'enabled')? 1 : 0;
215     + my $search = (( $list->prop('search') || 'disabled') eq 'enabled') ? 1 : 0;
216     +
217     + $OUT.=<<"END_TXT";
218     +push \@\$lists, {
219     + name => '$name',
220     + local_part => '$key',
221     + host_part => '$dompart',
222     + description => '$Description',
223     + archive => Mail::Ezmlm::Archive->new('/home/e-smith/files/ezmlm/lists/$key'),
224     + conceal_senders => $conceal_senders,
225     + subscription_info => $subscription_info ,
226     + descending_by_default => 1,
227     + default_sorting => '$default_sorting', #may be 'thread', 'date' or 'subject'
228     + show_html => $show_html,
229     + highlight => $highlight,
230     + show_inline_images => $show_inline_images,
231     + search => $search
232     +};
233     +END_TXT
234     + }
235     +
236     +}
237     +
238     +#---------------------------------------------------------------------------
239     +#-- This option specifies the language used for localized strings:
240     +
241     +$lang = '{
242     +my @langs = ('bg', 'de', 'en', 'es' , 'fr', 'it', 'no', 'pt' , 'tr', 'zh');
243     +my $syslang = (( substr($sysconfig{'Language'}, 0, 2) || 'unknown' ) ~~ @langs ) ? substr($sysconfig{'Language'}, 0, 2) : 'en' ;
244     +my $langu = (( $ezmlm{'lang'} || 'unknown') ~~ @langs) ? $ezmlm{'lang'} : $syslang;
245     +return $langu;
246     +}';
247     +
248     +#---------------------------------------------------------------------------
249     +#-- To enable vpopmail support just uncomment the following line:
250     +#-- (this will disable the configuration done with the "push @$lists"
251     +#-- syntax above, as all information will be taken from vpopmail local
252     +#-- database and the %Config defaults below.)
253     +
254     +#use vpopmail;
255     +
256     +
257     +#---------------------------------------------------------------------------
258     +#--Additional configuration options:
259     +{
260     + my $ListServerName = $ezmlm{'ListServerName'} || $DomainName ;
261     + $OUT.=<<"END_TXT";
262     +%Config = (
263     + ListServerName => '$ListServerName',
264     +
265     + #--These settings will be used for vpopmail-based mailing lists:
266     + # NOT IN USE WITH SME #
267     + DefaultVpopmailSettings => {
268     + conceal_senders => 1,
269     + subscription_info => 1,
270     + descending_by_default => 1,
271     + default_sorting => 'thread', #may be 'thread', 'date' or 'subject'
272     + show_html => 1,
273     + highlight => 1
274     + },
275     + VpopmailAccess => {
276     + default_policy => 'allow',
277     + allow_lists => [],
278     + deny_lists => [],
279     + allow_domains => [],
280     + deny_domains => []
281     + },
282     +
283     + #--CSS web path:
284     + CSSPath => 'style.css'
285     +);
286     +END_TXT
287     +
288     +}
289     +
290     +1;
291     diff -Nur --no-dereference smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/web/functions/mailinglists smeserver-ezmlm-web-1.1.3/root/etc/e-smith/web/functions/mailinglists
292     --- smeserver-ezmlm-web-1.1.3.old/root/etc/e-smith/web/functions/mailinglists 2022-03-20 02:09:58.725000000 -0400
293     +++ smeserver-ezmlm-web-1.1.3/root/etc/e-smith/web/functions/mailinglists 2022-03-20 02:20:41.660000000 -0400
294     @@ -49,6 +49,8 @@
295     sub performDeleteList ($);
296     sub performWebusersList ($);
297     sub webusersList ($);
298     +sub archivesConfig ($);
299     +sub performArchiveModify ($);
300    
301     BEGIN
302     {
303     @@ -117,6 +119,15 @@
304     webusersList ($q);
305     }
306    
307     +elsif ($q->param ('state') eq "archives")
308     +{
309     + archivesConfig ($q);
310     +}
311     +
312     +elsif ($q->param ('state') eq "performArchiveModify")
313     +{
314     + performArchiveModify ($q)
315     +}
316    
317     elsif ($q->param ('state') eq "performWebusers")
318     {
319     @@ -186,6 +197,7 @@
320     esmith::cgi::genSmallCell ($q, $q->b ('Description')),
321     $q->td ('&nbsp;'),
322     $q->td ('&nbsp;'),
323     + $q->td ('&nbsp;'),
324     $q->td ('&nbsp;')
325     );
326    
327     @@ -210,6 +222,12 @@
328     'Webusers...')),
329    
330     esmith::cgi::genSmallCell ($q,
331     + $q->a ( { href => $q->url (-absolute => 1) .
332     + "?state=archives&list=" .
333     + $list->key },
334     + 'Archives...')),
335     +
336     + esmith::cgi::genSmallCell ($q,
337     $q->a ({href => $q->url (-absolute => 1)
338     . "?state=delete&list="
339     . $list->key}, 'Remove...'))
340     @@ -255,6 +273,170 @@
341     #------------------------------------------------------------
342     #
343     #------------------------------------------------------------
344     +sub archivesConfig ($)
345     +{
346     + my ($q) = @_;
347     + my $members = "";
348     + my $listName = $q->param ('list');
349     + esmith::cgi::genHeaderNonCacheable
350     + ($q, undef, 'Manage Archives Display for ezmlm-www for the following mailinglist: '. $listName );
351     +
352     + print $q->startform (-method => 'POST',
353     + -action => $q->url (-absolute => 1));
354     +
355     + if ($listName eq "ALL") {
356     + return 0
357     + }
358     + elsif ($listName eq "ALLOW_CREATE") {
359     + return 0
360     + }
361     + return unless $accounts->get($listName);
362     + my $DisplayArchives = $accounts->get($listName)->prop('DisplayArchives') || 'disabled';
363     + my $conceal_senders = $accounts->get($listName)->prop('conceal_senders') || 'enabled';
364     + my $Description = $accounts->get($listName)->prop('Description') || '';
365     + my $default_sorting = $accounts->get($listName)->prop('default_sorting') || 'thread';
366     + my $show_html = $accounts->get($listName)->prop('show_html') || 'enabled';
367     + my $highlight = $accounts->get($listName)->prop('highlight') || 'enabled';
368     + my $show_inline_images = $accounts->get($listName)->prop('show_inline_images') || 'enabled';
369     + my $subscription_info = $accounts->get($listName)->prop('subscription_info') || 'disabled';
370     + my $descending_by_default = $accounts->get($listName)->prop('descending_by_default') || 'enabled';
371     + my $search = $accounts->get($listName)->prop('search') || 'disabled';
372     + my @sorting = qw(thread date subject);
373     + my @yesno = qw(enabled disabled);
374     +
375     + print $q->table ({border => 0, cellspacing => 0, cellpadding => 4},
376     +
377     + esmith::cgi::genTextRow ($q,
378     +
379     + $q->p ('The list name should contain only lower-case',
380     + 'letters, numbers, and hyphens and must start with ',
381     + 'a lower-case',
382     + 'letter. For example "betty", "hjohnson", and "abc-12" are',
383     + 'all valid account names, but "3friends", "John Smith"',
384     + 'and "Henry-Miller" are not.') . ' ' ),
385     +
386     + esmith::cgi::genWidgetRow ($q,
387     + "Display archives",
388     + $q->popup_menu (-name => 'DisplayArchives',
389     + -values => \@yesno,
390     + -default => $DisplayArchives)),
391     + esmith::cgi::genNameValueRow ($q,
392     + "Brief description",
393     + "Description",
394     + "$Description"),
395     + esmith::cgi::genWidgetRow ($q,
396     + "Conceal senders",
397     + $q->popup_menu (-name => 'conceal_senders',
398     + -values => \@yesno,
399     + -default => $conceal_senders)),
400     + esmith::cgi::genWidgetRow ($q,
401     + "Show HTML",
402     + $q->popup_menu (-name => 'show_html',
403     + -values => \@yesno,
404     + -default => $show_html)),
405     + esmith::cgi::genWidgetRow ($q,
406     + "Highlight parts of messages such as replies, signatures, URLs",
407     + $q->popup_menu (-name => 'highlight',
408     + -values => \@yesno,
409     + -default => $highlight)),
410     + esmith::cgi::genWidgetRow ($q,
411     + "Display inline images",
412     + $q->popup_menu (-name => 'show_inline_images',
413     + -values => \@yesno,
414     + -default => $show_inline_images)),
415     + esmith::cgi::genWidgetRow ($q,
416     + "Display subscription information",
417     + $q->popup_menu (-name => 'subscription_info',
418     + -values => \@yesno,
419     + -default => $subscription_info)),
420     + esmith::cgi::genWidgetRow ($q,
421     + "Default sorting of list",
422     + $q->popup_menu (-name => 'default_sorting',
423     + -values => \@sorting,
424     + -default => $default_sorting)),
425     + esmith::cgi::genWidgetRow ($q,
426     + "Sorting descending by default",
427     + $q->popup_menu (-name => 'descending_by_default',
428     + -values => \@yesno,
429     + -default => $descending_by_default)),
430     +
431     + esmith::cgi::genWidgetRow ($q,
432     + "Display search box (need search indexing)",
433     + $q->popup_menu (-name => 'search',
434     + -values => \@yesno,
435     + -default => $search)),
436     +
437     +
438     +
439     + esmith::cgi::genButtonRow ($q,
440     + $q->submit (-name => 'action',
441     + -value => 'Create')));
442     +
443     + print '</table>';
444     +
445     + print $q->hidden (-name => 'list',
446     + -override => 1,
447     + -default => $listName);
448     +
449     + print $q->hidden (-name => 'state',
450     + -override => 1,
451     + -default => 'performArchiveModify');
452     +
453     + print $q->endform;
454     +
455     + esmith::cgi::genFooter ($q);
456     + return;
457     +
458     +}
459     +
460     +#------------------------------------------------------------
461     +#
462     +#------------------------------------------------------------
463     +sub performArchiveModify ($)
464     +{
465     + my $q = shift;
466     +
467     + my $listName = $q->param('list');
468     + # Untaint groupName before use in system()
469     + ($listName) = ($listName =~ /^([a-zA-Z][\-\_\.a-zA-Z0-9]*)$/);
470     + my %sorting = qw(thread thread
471     + date date
472     + subject subject);
473     + my %yesno = qw(enabled enabled
474     + disabled disabled);
475     +
476     + my $DisplayArchives = $yesno{$q->param('DisplayArchives')}||""; #;
477     + $accounts->get($listName)->set_prop('DisplayArchives', $DisplayArchives) unless $DisplayArchives eq "";
478     + my $conceal_senders = $yesno{$q->param('conceal_senders')}||"";
479     + $accounts->get($listName)->set_prop('conceal_senders',$conceal_senders) unless $conceal_senders eq "";
480     + my $Description = $q->param('Description')||"";
481     + ($Description) = ($Description=~ /^([a-zA-Z][\-_.a-zA-Z0-9 ]*)$/);
482     + $accounts->get($listName)->set_prop('Description',$Description) unless $Description eq "";
483     + my $default_sorting = $sorting{$q->param('default_sorting')}||"";
484     + $accounts->get($listName)->set_prop('default_sorting',$default_sorting) unless $default_sorting eq "";;
485     + my $show_html = $yesno{$q->param('show_html')}||"";
486     + $accounts->get($listName)->set_prop('show_html', $show_html) unless $show_html eq "";
487     + my $highlight = $yesno{$q->param('highlight')}||"";
488     + $accounts->get($listName)->set_prop('highlight',$highlight ) unless $highlight eq "";
489     + my $show_inline_images = $yesno{$q->param('show_inline_images')}||"";
490     + $accounts->get($listName)->set_prop('show_inline_images', $show_inline_images) unless $show_inline_images eq "";
491     + my $subscription_info = $yesno{$q->param('subscription_info')}||"";
492     + $accounts->get($listName)->set_prop('subscription_info', $subscription_info) unless $subscription_info eq "";
493     + my $descending_by_default = $yesno{$q->param('descending_by_default')}||"";
494     + $accounts->get($listName)->set_prop('descending_by_default',$descending_by_default ) unless $descending_by_default eq "";
495     + my $search = $yesno{$q->param('search')}||"";
496     + $accounts->get($listName)->set_prop('search', $search ) unless $search eq "";
497     +
498     + return ( system ('/sbin/e-smith/signal-event', 'mailinglist-modify', $listName) == 0 ) ?
499     + showInitial ($q, "Error: updating Archive for $listName") : showInitial ($q, "Successfully updated Archive for $listName.");
500     + #return;
501     +
502     +
503     +}
504     +
505     +#------------------------------------------------------------
506     +#
507     +#------------------------------------------------------------
508     sub webusersList ($)
509     {
510     my ($q) = @_;
511     @@ -474,8 +656,7 @@
512    
513     my $listOwner = $q->param ('listOwner');
514     $listOwner = "admin" if ($listOwner eq "Administrator");
515     - my @users = sort { $a->key() cmp $b->key() } ( $accounts->users() , $accounts->get('admin') );
516     -
517     + my $webusers = ($listOwner eq "admin") ? $listOwner : "admin,$listOwner";
518     #------------------------------------------------------------
519     # Looks good. Find out if this account has been taken
520     #------------------------------------------------------------
521     @@ -499,7 +680,7 @@
522     Domain => $listDomain,
523     Description => $listDescription,
524     Owner => $listOwner,
525     - webusers => $webusers,
526     + webusers => $webusers,
527     } );
528    
529     system ('/sbin/e-smith/signal-event', 'mailinglist-create', $listName) == 0

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