Difference between revisions of "Caretaker.pl"

From Organic Design wiki
m
m (Don't do caretaking on mediawiki articles)
Line 8: Line 8:
  
 
# Get last article id
 
# Get last article id
my $sth = $dbh->prepare('SELECT cur_id FROM cur ORDER BY cur_id DESC');
+
my $sth = $dbh->prepare('SELECT cur_id FROM cur WHERE cur_namespace != 8 ORDER BY cur_id DESC');
 
$sth->execute();
 
$sth->execute();
 
my @row = $sth->fetchrow_array;
 
my @row = $sth->fetchrow_array;
Line 17: Line 17:
 
my $sth = $dbh->prepare('SELECT cur_namespace,cur_title FROM cur WHERE cur_id=?');
 
my $sth = $dbh->prepare('SELECT cur_namespace,cur_title FROM cur WHERE cur_id=?');
 
my $done = 0;
 
my $done = 0;
my @comments = ();
+
for ($first..$last) {
for (0..$last) {
 
 
$sth->execute($_);
 
$sth->execute($_);
 
@row = $sth->fetchrow_array;
 
@row = $sth->fetchrow_array;
 +
my @comments = ();
 
my $title = '';
 
my $title = '';
 
if ($title = $ns[$row[0]].$row[1]) {
 
if ($title = $ns[$row[0]].$row[1]) {

Revision as of 03:13, 24 October 2006

use DBI;

sub caretaker { my $dbh = DBI->connect('DBI:mysql:wiki',lc $::peer,$::pwd1) or die DBI->errstr; my @ns = (,'Talk:','User:','User talk:','Project:','Project talk:', 'Image:','Image talk:','Mediawiki:','Mediawiki talk:','Template:', 'Template talk:','Help:','Help talk:','Category:','Category talk:');

# Get last article id my $sth = $dbh->prepare('SELECT cur_id FROM cur WHERE cur_namespace != 8 ORDER BY cur_id DESC'); $sth->execute(); my @row = $sth->fetchrow_array; $sth->finish; my $last = $row[0];

# Loop through all articles one per second my $sth = $dbh->prepare('SELECT cur_namespace,cur_title FROM cur WHERE cur_id=?'); my $done = 0; for ($first..$last) { $sth->execute($_); @row = $sth->fetchrow_array; my @comments = (); my $title = ; if ($title = $ns[$row[0]].$row[1]) {

# Read the article content my $article = my $backup = wikiRawPage $::wiki, $title;

# Apply rules to Xml:Articles if ($title =~ /^Xml:/) { push @comments, 'removed empty elements' if $article =~ s/^\s*<(read|write|category|init|data|view|edit|save)>\s*<\/\w+>[\r\n]*//gms; }

# If article changed, write and comment wikiPageEdit $::wiki, $title, $article, join(', ',@comments) if $article ne $backup; } sleep(1); }

my $comment = "Daily caretaking tasks completed: $last articles examined, $done adjusted."; logAdd $comment; wikiLogin($::wiki, $::peer, $::pwd1); wikiPageAppend($::wiki, $::wikilog, "\n*".localtime()." : $comment", $comment); $sth->finish; $dbh->disconnect; }