]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
move notices-rendered code into upgrade script
authorEvan Prodromou <evan@status.net>
Wed, 7 Sep 2011 16:10:26 +0000 (12:10 -0400)
committerEvan Prodromou <evan@status.net>
Wed, 7 Sep 2011 16:10:26 +0000 (12:10 -0400)
scripts/fixup_notices_rendered.php [deleted file]
scripts/upgrade.php [new file with mode: 0755]

diff --git a/scripts/fixup_notices_rendered.php b/scripts/fixup_notices_rendered.php
deleted file mode 100755 (executable)
index cfbdc74..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-#!/usr/bin/env php
-<?php
-/*
- * StatusNet - the distributed open-source microblogging tool
- * Copyright (C) 2008, 2009, StatusNet, Inc.
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program.  If not, see <http://www.gnu.org/licenses/>.
- */
-
-// Abort if called from a web server
-if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
-    print "This script must be run from the command line\n";
-    exit();
-}
-
-define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
-define('STATUSNET', true);
-define('LACONICA', true); // compatibility
-
-require_once(INSTALLDIR . '/lib/common.php');
-
-common_log(LOG_INFO, 'Starting to render old notices.');
-
-$start_at = ($argc > 1) ? $argv[1] : null;
-
-$notice = new Notice();
-if ($start_at) {
-    $notice->whereAdd('id >= ' . $start_at);
-}
-$cnt = $notice->find();
-
-while ($notice->fetch()) {
-    common_log(LOG_INFO, 'Pre-rendering notice #' . $notice->id);
-    $original = clone($notice);
-    $notice->rendered = common_render_content($notice->content, $notice);
-    $result = $notice->update($original);
-    if (!$result) {
-        common_log_db_error($notice, 'UPDATE', __FILE__);
-    }
-}
diff --git a/scripts/upgrade.php b/scripts/upgrade.php
new file mode 100755 (executable)
index 0000000..2c34ae0
--- /dev/null
@@ -0,0 +1,86 @@
+#!/usr/bin/env php
+<?php
+/*
+ * StatusNet - a distributed open-source microblogging tool
+ * Copyright (C) 2008-2011 StatusNet, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
+
+$shortoptions = 'x::';
+$longoptions = array('extensions=');
+
+$helptext = <<<END_OF_UPGRADE_HELP
+php upgrade.php [options]
+Upgrade database schema and data to latest software
+
+END_OF_UPGRADE_HELP;
+
+require_once INSTALLDIR.'/scripts/commandline.inc';
+
+function main()
+{
+    updateSchemaCore();
+    updateSchemaPlugins();
+
+    // These replace old "fixup_*" scripts
+
+    fixupNoticesRendered();
+}
+
+function tableDefs()
+{
+       $schema = array();
+       require INSTALLDIR.'/db/core.php';
+       return $schema;
+}
+
+function updateSchemaCore()
+{
+    printfnq("Upgrading core schema");
+
+    $schema = Schema::get();
+    $schemaUpdater = new SchemaUpdater($schema);
+    foreach (tableDefs() as $table => $def) {
+        $schemaUpdater->register($table, $def);
+    }
+    $schemaUpdater->checkSchema();
+}
+
+function updateSchemaPlugins()
+{
+    printfnq("Upgrading plugin schema");
+
+    Event::handle('CheckSchema');
+}
+
+function fixupNoticesRendered()
+{
+    printfnq("Ensuring all notices have rendered HTML");
+
+    $notice = new Notice();
+
+    $notice->whereAdd('rendered IS NULL');
+    $notice->find();
+
+    while ($notice->fetch()) {
+        $original = clone($notice);
+        $notice->rendered = common_render_content($notice->content, $notice);
+        $notice->update($original);
+    }
+}
+
+main();