3caebb3b20
* Add feed widget * add feed render * Add CommentPage widget * New theme (#1390) * 调整忽略目录 * add theme * fix theme scss build Co-authored-by: fen <f3nb0x@gmail.com> * s/is_writeable/is_writable/g * New upgrade method * merge new fixes from master * add pgsql ssl mode support (ref #1600) (#1623) * Feat/code refactor (#1626) * remove all magic methods, add type for class properties * refactor codes * fix all * refactor code * fix type * fix all * fix request is method * fix all * fix router * fix get page * fix 1.3.0 upgrade * [feat] support high resolution avatar * fix types in i18n component * Implement Ctrl+S or Command+S for save draft (#1628) * Implement Ctrl+S or Command+S for save draft * rename * add Typecho.savePost * fix upload file size * add new uploader * replace new uploader * fix textarea change * fix preview * refactor post edit * fix issue * fix page edit --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * fix #1632 * Add svg to image types * Feat/tree pages (#1646) * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Support IDN (#1629) * Support IDN * use js * Optimize code * Optimize code * fix URL script * remove unnecessary use --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * fix input element * fix #1651, close #1653 * Use json instead of serialize (#1624) * Use json instead of serialize * Fix Upgrade code * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Fix typo * remove proxy methods * remove unnecessary useage --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * Fix Prevent XSS vulnerability in default theme (#1654) * Fix Prevent XSS vulnerability in default theme * Update var/Typecho/Db/Adapter/Pdo.php * fix the getter --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * add throwCallback to widget response * fix: cut down fields when selecting recent posts * fix typo errors * fix typo errors * fix http client cookie * add throw finish * fix theme lang * fix default theme * fix query * add open graph and twitter card support add canonical link * fix canonical link meta * fix theme classic-22 * remove unnecessary scss file when packaging * init plugin signal * improve: remove feather-icon js file * fix: typo * improve: post detail layout * fix tags saving * improve: nav search * fix: theme screenshot * fix: theme page layout * remove php 7.2/7.3 env --------- Co-authored-by: fen <f3nb0x@gmail.com> Co-authored-by: Lu Fei <52o@qq52o.cn>
99 lines
2.9 KiB
PHP
99 lines
2.9 KiB
PHP
<?php
|
|
|
|
namespace Utils;
|
|
|
|
use Typecho\Db;
|
|
use Widget\Options;
|
|
|
|
/**
|
|
* 升级程序
|
|
*
|
|
* @category typecho
|
|
* @package Upgrade
|
|
* @copyright Copyright (c) 2008 Typecho team (http://www.typecho.org)
|
|
* @license GNU General Public License 2.0
|
|
*/
|
|
class Upgrade
|
|
{
|
|
/**
|
|
* @param Db $db
|
|
* @param Options $options
|
|
*/
|
|
public static function v1_3_0(Db $db, Options $options)
|
|
{
|
|
$routingTable = $options->routingTable;
|
|
|
|
$routingTable['comment_page'] = [
|
|
'url' => '[permalink:string]/comment-page-[commentPage:digital]',
|
|
'widget' => '\Widget\CommentPage',
|
|
'action' => 'action'
|
|
];
|
|
|
|
$routingTable['feed'] = [
|
|
'url' => '/feed[feed:string:0]',
|
|
'widget' => '\Widget\Feed',
|
|
'action' => 'render'
|
|
];
|
|
|
|
unset($routingTable[0]);
|
|
|
|
$db->query($db->update('table.options')
|
|
->rows(['value' => json_encode($routingTable)])
|
|
->where('name = ?', 'routingTable'));
|
|
|
|
// fix options->commentsRequireURL
|
|
$db->query($db->update('table.options')
|
|
->rows(['name' => 'commentsRequireUrl'])
|
|
->where('name = ?', 'commentsRequireURL'));
|
|
|
|
// fix draft
|
|
$db->query($db->update('table.contents')
|
|
->rows(['type' => 'revision'])
|
|
->where('parent <> 0 AND (type = ? OR type = ?)', 'post_draft', 'page_draft'));
|
|
|
|
// fix attachment serialize
|
|
$lastId = 0;
|
|
do {
|
|
$rows = $db->fetchAll(
|
|
$db->select('cid', 'text')->from('table.contents')
|
|
->where('cid > ?', $lastId)
|
|
->where('type = ?', 'attachment')
|
|
->order('cid', Db::SORT_ASC)
|
|
->limit(100)
|
|
);
|
|
|
|
foreach ($rows as $row) {
|
|
if (strpos($row['text'], 'a:') !== 0) {
|
|
continue;
|
|
}
|
|
|
|
$value = @unserialize($row['text']);
|
|
if ($value !== false) {
|
|
$db->query($db->update('table.contents')
|
|
->rows(['text' => json_encode($value)])
|
|
->where('cid = ?', $row['cid']));
|
|
}
|
|
|
|
$lastId = $row['cid'];
|
|
}
|
|
} while (count($rows) === 100);
|
|
|
|
$rows = $db->fetchAll($db->select()->from('table.options'));
|
|
|
|
foreach ($rows as $row) {
|
|
if (
|
|
in_array($row['name'], ['plugins', 'actionTable', 'panelTable'])
|
|
|| strpos($row['name'], 'plugin:') === 0
|
|
|| strpos($row['name'], 'theme:') === 0
|
|
) {
|
|
$value = @unserialize($row['value']);
|
|
if ($value !== false) {
|
|
$db->query($db->update('table.options')
|
|
->rows(['value' => json_encode($value)])
|
|
->where('name = ?', $row['name']));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|