#!/usr/bin/perl # $maint{joinmail} = sub { # this needs to be resumeable, so that it can run once every 10 or 15 minutes to digest things # that are a day old but haven't been sent. also, the first query down there needs to include # the right authaction type in the WHERE clause, and NOT do a GROUP BY. print "Returning without running... I'm disabled right now.\n"; return 1; my $dbr = LJ::get_db_reader(); # get all information my $pending = $dbr->selectall_arrayref("SELECT userid, COUNT(arg1) FROM authactions " . "WHERE used = 'N' AND datecreate > DATE_SUB(NOW(), INTERVAL 1 DAY)" . "GROUP BY userid") || []; # get userids of communities my @commids; push @commids, $_->[0]+0 foreach @$pending; my $cus = LJ::load_userids(@commids); # now let's get the maintainers of these my $in = join ',', @commids; my $maintrows = $dbr->selectall_arrayref("SELECT userid, targetid FROM reluser WHERE userid IN ($in) AND type = 'A'") || []; my @maintids; my %maints; foreach (@$maintrows) { push @{$maints{$_->[0]}}, $_->[1]; push @maintids, $_->[1]; } my $mus = LJ::load_userids(@maintids); # tell the maintainers that they got new people. foreach my $row (@$pending) { my $cuser = $cus->{$row->[0]}{user}; print "$cuser: $row->[1] invites: "; my %email; # see who we emailed on this comm foreach my $mid (@{$maints{$row->[0]}}) { print "$mid "; next if $email{$mus->{$mid}{email}}++; LJ::load_user_props($mus->{$mid}, 'opt_communityjoinemail'); next unless $mus->{$mid}{opt_communityjoinemail} eq 'D'; # Daily or Digest my $body = "Dear $mus->{$mid}{user},\n\n" . "Over the past day or so, $row->[1] request(s) to join the \"$cuser\" community have " . "been received. To look at the currently pending membership requests, please visit the pending " . "membership page:\n\n" . "\t$LJ::SITEROOT/community/pending.bml?comm=$cuser\n\n" . "You may also ignore this email. Outstanding requests to join will expire after a period of 30 days.\n\n" . "If you wish to no longer receive these emails, visit the community management page and " . "set the relevant options:\n\n\t$LJ::SITEROOT/community/manage.bml\n\n" . "Regards,\n$LJ::SITENAME Team\n"; LJ::send_mail({ to => $mus->{$mid}{email}, from => $LJ::COMMUNITY_EMAIL, fromname => $LJ::SITENAME, charset => 'utf-8', subject => "$cuser Membership Requests", body => $body, wrap => 76, }); } print "\n"; } }; $maint{clean_spamreports} = sub { my $dbh = LJ::get_db_writer(); my $len = 86400 * 90; # 90 days my $ct = $dbh->do("DELETE FROM spamreports WHERE reporttime < UNIX_TIMESTAMP() - $len")+0; print "Deleted $ct reports.\n"; }; 1;