5 # The following exit codes are defined and MUST BE CONSISTENT with the
6 # error codes the library uses:
7 $MR_DBMS_ERR = 47836421;
9 $outdir = '/moira/dcm/mailman';
14 $dbh = DBI->connect("dbi:Oracle:moira", "moira", "moira") || exit $MR_DBMS_ERR;
16 $sth0 = $dbh->prepare("SELECT m.name FROM machine m, serverhosts sh " .
17 "WHERE m.mach_id = sh.mach_id AND " .
18 "sh.service = 'MAILMAN' AND sh.enable = 1");
21 while (($hostname) = $sth0->fetchrow_array) {
22 open(OUT, ">$outdir/$hostname");
24 $sth1 = $dbh->prepare("SELECT l.name, l.memacl_type, l.memacl_id " .
25 "FROM list l, machine m WHERE ".
26 "l.mailman = 1 AND " .
27 "m.name = " . $dbh->quote($hostname) .
28 "AND m.mach_id = l.mailman_id AND l.active = 1" .
29 "AND l.memacl_type != 'KERBEROS'")
33 while (($listname, $memacl_type, $memacl_id) = $sth1->fetchrow_array) {
38 if ($memacl_type eq "USER") {
39 ($member) = $dbh->selectrow_array("SELECT login FROM users " .
41 $dbh->quote($memacl_id)) ||
43 $member = $member . "\@mit.edu";
47 $sth2 = $dbh->prepare("SELECT UNIQUE i.member_type, i.member_id " .
48 "FROM imembers i, list l " .
49 "WHERE l.list_id = " .
50 $dbh->quote($memacl_id) .
51 "AND i.list_id = l.list_id " .
52 "AND (i.member_type = 'USER' " .
53 "OR i.member_type = 'STRING')") ||
58 while (($type, $id) = $sth2->fetchrow_array) {
59 if ($type eq "USER") {
60 ($member) = $dbh->selectrow_array("SELECT login " .
65 $member = $member . "\@mit.edu";
67 elsif ($type eq "STRING") {
68 ($member) = $dbh->selectrow_array("SELECT string " .
70 "WHERE string_id = " .
74 $row = "$maybecomma$member";