Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php namespace Widget\Contents\Post; use Typecho\Common; use Typecho\Widget\Exception; ..
Decoded Output download
<?php
namespace Widget\Contents\Post;
use Typecho\Common;
use Typecho\Widget\Exception;
use Widget\Base\Contents;
use Widget\Base\Metas;
use Widget\ActionInterface;
use Typecho\Db\Exception as DbException;
use Typecho\Date as TypechoDate;
use Widget\Contents\EditTrait;
use Widget\Contents\PrepareEditTrait;
use Widget\Notice;
use Widget\Service;
if (!defined('__TYPECHO_ROOT_DIR__')) {
exit;
}
/**
*
*
* @property-read array $draft
*/
class Edit extends Contents implements ActionInterface
{
use PrepareEditTrait;
use EditTrait;
/**
*
*
* @throws Exception|DbException
*/
public function execute()
{
/** */
$this->user->pass('contributor');
}
/**
*
*/
public function writePost()
{
$contents = $this->request->from(
'password',
'allowComment',
'allowPing',
'allowFeed',
'slug',
'tags',
'text',
'visibility'
);
$contents['category'] = $this->request->getArray('category');
$contents['title'] = $this->request->get('title', _t(''));
$contents['created'] = $this->getCreated();
if ($this->request->is('markdown=1') && $this->options->markdown) {
$contents['text'] = '<!--markdown-->' . $contents['text'];
}
$contents = self::pluginHandle()->call('write', $contents, $this);
if ($this->request->is('do=publish')) {
/** */
$contents['type'] = 'post';
$this->publish($contents);
//
self::pluginHandle()->call('finishPublish', $contents, $this);
/** ping */
$trackback = array_filter(
array_unique(preg_split("/(\r|\n|\r\n)/", trim($this->request->get('trackback', ''))))
);
Service::alloc()->sendPing($this, $trackback);
/** */
Notice::alloc()->set('post' == $this->type ?
_t(' "<a href="%s">%s</a>" ', $this->permalink, $this->title) :
_t(' "%s" ', $this->title), 'success');
/** */
Notice::alloc()->highlight($this->theId);
/** */
$pageQuery = $this->getPageOffsetQuery($this->cid);
/** */
$this->response->redirect(Common::url('manage-posts.php?' . $pageQuery, $this->options->adminUrl));
} else {
/** */
$contents['type'] = 'post_draft';
$draftId = $this->save($contents);
//
self::pluginHandle()->call('finishSave', $contents, $this);
/** */
Notice::alloc()->highlight($this->cid);
if ($this->request->isAjax()) {
$created = new TypechoDate();
$this->response->throwJson([
'success' => 1,
'time' => $created->format('H:i:s A'),
'cid' => $this->cid,
'draftId' => $draftId
]);
} else {
/** */
Notice::alloc()->set(_t(' "%s" ', $this->title), 'success');
/** */
$this->response->redirect(Common::url('write-post.php?cid=' . $this->cid, $this->options->adminUrl));
}
}
}
/**
* URL Query
*
* @param integer $cid id
* @param string|null $status
* @return string
* @throws DbException
*/
protected function getPageOffsetQuery(int $cid, ?string $status = null): string
{
return 'page=' . $this->getPageOffset(
'cid',
$cid,
'post',
$status,
$this->request->is('__typecho_all_posts=on') ? 0 : $this->user->uid
);
}
/**
*
*
* @throws DbException
*/
public function markPost()
{
$status = $this->request->get('status');
$statusList = [
'publish' => _t(''),
'private' => _t(''),
'hidden' => _t(''),
'waiting' => _t('')
];
if (!isset($statusList[$status])) {
$this->response->goBack();
}
$posts = $this->request->filter('int')->getArray('cid');
$markCount = 0;
foreach ($posts as $post) {
//
self::pluginHandle()->call('mark', $status, $post, $this);
$condition = $this->db->sql()->where('cid = ?', $post);
$postObject = $this->db->fetchObject($this->db->select('status', 'type')
->from('table.contents')->where('cid = ? AND (type = ? OR type = ?)', $post, 'post', 'post_draft'));
if ($this->isWriteable(clone $condition) && count((array)$postObject)) {
/** */
$this->db->query($condition->update('table.contents')->rows(['status' => $status]));
// Metas
if ($postObject->type == 'post') {
$op = null;
if ($status == 'publish' && $postObject->status != 'publish') {
$op = '+';
} elseif ($status != 'publish' && $postObject->status == 'publish') {
$op = '-';
}
if (!empty($op)) {
$metas = $this->db->fetchAll(
$this->db->select()->from('table.relationships')->where('cid = ?', $post)
);
foreach ($metas as $meta) {
$this->db->query($this->db->update('table.metas')
->expression('count', 'count ' . $op . ' 1')
->where('mid = ? AND (type = ? OR type = ?)', $meta['mid'], 'category', 'tag'));
}
}
}
//
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
if (!empty($draft)) {
$this->db->query($this->db->update('table.contents')->rows(['status' => $status])
->where('cid = ?', $draft['cid']));
}
//
self::pluginHandle()->call('finishMark', $status, $post, $this);
$markCount++;
}
unset($condition);
}
/** */
Notice::alloc()
->set(
$markCount > 0 ? _t('<strong>%s</strong>', $statusList[$status]) : _t(''),
$markCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
*
*
* @throws DbException
*/
public function deletePost()
{
$posts = $this->request->filter('int')->getArray('cid');
$deleteCount = 0;
foreach ($posts as $post) {
//
self::pluginHandle()->call('delete', $post, $this);
$condition = $this->db->sql()->where('cid = ?', $post);
$postObject = $this->db->fetchObject($this->db->select('status', 'type')
->from('table.contents')->where('cid = ? AND (type = ? OR type = ?)', $post, 'post', 'post_draft'));
if ($this->isWriteable(clone $condition) && count((array)$postObject) && $this->delete($condition)) {
/** */
$this->setCategories($post, [], 'publish' == $postObject->status
&& 'post' == $postObject->type);
/** */
$this->setTags($post, null, 'publish' == $postObject->status
&& 'post' == $postObject->type);
/** */
$this->db->query($this->db->delete('table.comments')
->where('cid = ?', $post));
/** */
$this->unAttach($post);
/** */
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
/** */
$this->deleteFields($post);
if ($draft) {
$this->deleteContent($draft['cid']);
$this->deleteFields($draft['cid']);
}
//
self::pluginHandle()->call('finishDelete', $post, $this);
$deleteCount++;
}
unset($condition);
}
//
if ($deleteCount > 0) {
Metas::alloc()->clearTags();
}
/** */
Notice::alloc()->set(
$deleteCount > 0 ? _t('') : _t(''),
$deleteCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
*
*
* @throws DbException
*/
public function deletePostDraft()
{
$posts = $this->request->filter('int')->getArray('cid');
$deleteCount = 0;
foreach ($posts as $post) {
/** */
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
if ($draft) {
$this->deleteContent($draft['cid']);
$this->deleteFields($draft['cid']);
$deleteCount++;
}
}
/** */
Notice::alloc()
->set(
$deleteCount > 0 ? _t('') : _t(''),
$deleteCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
* @return $this
* @throws DbException
* @throws Exception
*/
public function prepare(): self
{
return $this->prepareEdit('post', true, _t(''));
}
/**
*
*
* @throws Exception|DbException
*/
public function action()
{
$this->security->protect();
$this->on($this->request->is('do=publish') || $this->request->is('do=save'))
->prepare()->writePost();
$this->on($this->request->is('do=delete'))->deletePost();
$this->on($this->request->is('do=mark'))->markPost();
$this->on($this->request->is('do=deleteDraft'))->deletePostDraft();
$this->response->redirect($this->options->adminUrl);
}
/**
* @return string
*/
protected function getThemeFieldsHook(): string
{
return 'themePostFields';
}
}
?>
Did this file decode correctly?
Original Code
<?php
namespace Widget\Contents\Post;
use Typecho\Common;
use Typecho\Widget\Exception;
use Widget\Base\Contents;
use Widget\Base\Metas;
use Widget\ActionInterface;
use Typecho\Db\Exception as DbException;
use Typecho\Date as TypechoDate;
use Widget\Contents\EditTrait;
use Widget\Contents\PrepareEditTrait;
use Widget\Notice;
use Widget\Service;
if (!defined('__TYPECHO_ROOT_DIR__')) {
exit;
}
/**
*
*
* @property-read array $draft
*/
class Edit extends Contents implements ActionInterface
{
use PrepareEditTrait;
use EditTrait;
/**
*
*
* @throws Exception|DbException
*/
public function execute()
{
/** */
$this->user->pass('contributor');
}
/**
*
*/
public function writePost()
{
$contents = $this->request->from(
'password',
'allowComment',
'allowPing',
'allowFeed',
'slug',
'tags',
'text',
'visibility'
);
$contents['category'] = $this->request->getArray('category');
$contents['title'] = $this->request->get('title', _t(''));
$contents['created'] = $this->getCreated();
if ($this->request->is('markdown=1') && $this->options->markdown) {
$contents['text'] = '<!--markdown-->' . $contents['text'];
}
$contents = self::pluginHandle()->call('write', $contents, $this);
if ($this->request->is('do=publish')) {
/** */
$contents['type'] = 'post';
$this->publish($contents);
//
self::pluginHandle()->call('finishPublish', $contents, $this);
/** ping */
$trackback = array_filter(
array_unique(preg_split("/(\r|\n|\r\n)/", trim($this->request->get('trackback', ''))))
);
Service::alloc()->sendPing($this, $trackback);
/** */
Notice::alloc()->set('post' == $this->type ?
_t(' "<a href="%s">%s</a>" ', $this->permalink, $this->title) :
_t(' "%s" ', $this->title), 'success');
/** */
Notice::alloc()->highlight($this->theId);
/** */
$pageQuery = $this->getPageOffsetQuery($this->cid);
/** */
$this->response->redirect(Common::url('manage-posts.php?' . $pageQuery, $this->options->adminUrl));
} else {
/** */
$contents['type'] = 'post_draft';
$draftId = $this->save($contents);
//
self::pluginHandle()->call('finishSave', $contents, $this);
/** */
Notice::alloc()->highlight($this->cid);
if ($this->request->isAjax()) {
$created = new TypechoDate();
$this->response->throwJson([
'success' => 1,
'time' => $created->format('H:i:s A'),
'cid' => $this->cid,
'draftId' => $draftId
]);
} else {
/** */
Notice::alloc()->set(_t(' "%s" ', $this->title), 'success');
/** */
$this->response->redirect(Common::url('write-post.php?cid=' . $this->cid, $this->options->adminUrl));
}
}
}
/**
* URL Query
*
* @param integer $cid id
* @param string|null $status
* @return string
* @throws DbException
*/
protected function getPageOffsetQuery(int $cid, ?string $status = null): string
{
return 'page=' . $this->getPageOffset(
'cid',
$cid,
'post',
$status,
$this->request->is('__typecho_all_posts=on') ? 0 : $this->user->uid
);
}
/**
*
*
* @throws DbException
*/
public function markPost()
{
$status = $this->request->get('status');
$statusList = [
'publish' => _t(''),
'private' => _t(''),
'hidden' => _t(''),
'waiting' => _t('')
];
if (!isset($statusList[$status])) {
$this->response->goBack();
}
$posts = $this->request->filter('int')->getArray('cid');
$markCount = 0;
foreach ($posts as $post) {
//
self::pluginHandle()->call('mark', $status, $post, $this);
$condition = $this->db->sql()->where('cid = ?', $post);
$postObject = $this->db->fetchObject($this->db->select('status', 'type')
->from('table.contents')->where('cid = ? AND (type = ? OR type = ?)', $post, 'post', 'post_draft'));
if ($this->isWriteable(clone $condition) && count((array)$postObject)) {
/** */
$this->db->query($condition->update('table.contents')->rows(['status' => $status]));
// Metas
if ($postObject->type == 'post') {
$op = null;
if ($status == 'publish' && $postObject->status != 'publish') {
$op = '+';
} elseif ($status != 'publish' && $postObject->status == 'publish') {
$op = '-';
}
if (!empty($op)) {
$metas = $this->db->fetchAll(
$this->db->select()->from('table.relationships')->where('cid = ?', $post)
);
foreach ($metas as $meta) {
$this->db->query($this->db->update('table.metas')
->expression('count', 'count ' . $op . ' 1')
->where('mid = ? AND (type = ? OR type = ?)', $meta['mid'], 'category', 'tag'));
}
}
}
//
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
if (!empty($draft)) {
$this->db->query($this->db->update('table.contents')->rows(['status' => $status])
->where('cid = ?', $draft['cid']));
}
//
self::pluginHandle()->call('finishMark', $status, $post, $this);
$markCount++;
}
unset($condition);
}
/** */
Notice::alloc()
->set(
$markCount > 0 ? _t('<strong>%s</strong>', $statusList[$status]) : _t(''),
$markCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
*
*
* @throws DbException
*/
public function deletePost()
{
$posts = $this->request->filter('int')->getArray('cid');
$deleteCount = 0;
foreach ($posts as $post) {
//
self::pluginHandle()->call('delete', $post, $this);
$condition = $this->db->sql()->where('cid = ?', $post);
$postObject = $this->db->fetchObject($this->db->select('status', 'type')
->from('table.contents')->where('cid = ? AND (type = ? OR type = ?)', $post, 'post', 'post_draft'));
if ($this->isWriteable(clone $condition) && count((array)$postObject) && $this->delete($condition)) {
/** */
$this->setCategories($post, [], 'publish' == $postObject->status
&& 'post' == $postObject->type);
/** */
$this->setTags($post, null, 'publish' == $postObject->status
&& 'post' == $postObject->type);
/** */
$this->db->query($this->db->delete('table.comments')
->where('cid = ?', $post));
/** */
$this->unAttach($post);
/** */
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
/** */
$this->deleteFields($post);
if ($draft) {
$this->deleteContent($draft['cid']);
$this->deleteFields($draft['cid']);
}
//
self::pluginHandle()->call('finishDelete', $post, $this);
$deleteCount++;
}
unset($condition);
}
//
if ($deleteCount > 0) {
Metas::alloc()->clearTags();
}
/** */
Notice::alloc()->set(
$deleteCount > 0 ? _t('') : _t(''),
$deleteCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
*
*
* @throws DbException
*/
public function deletePostDraft()
{
$posts = $this->request->filter('int')->getArray('cid');
$deleteCount = 0;
foreach ($posts as $post) {
/** */
$draft = $this->db->fetchRow($this->db->select('cid')
->from('table.contents')
->where('table.contents.parent = ? AND table.contents.type = ?', $post, 'revision')
->limit(1));
if ($draft) {
$this->deleteContent($draft['cid']);
$this->deleteFields($draft['cid']);
$deleteCount++;
}
}
/** */
Notice::alloc()
->set(
$deleteCount > 0 ? _t('') : _t(''),
$deleteCount > 0 ? 'success' : 'notice'
);
/** */
$this->response->goBack();
}
/**
* @return $this
* @throws DbException
* @throws Exception
*/
public function prepare(): self
{
return $this->prepareEdit('post', true, _t(''));
}
/**
*
*
* @throws Exception|DbException
*/
public function action()
{
$this->security->protect();
$this->on($this->request->is('do=publish') || $this->request->is('do=save'))
->prepare()->writePost();
$this->on($this->request->is('do=delete'))->deletePost();
$this->on($this->request->is('do=mark'))->markPost();
$this->on($this->request->is('do=deleteDraft'))->deletePostDraft();
$this->response->redirect($this->options->adminUrl);
}
/**
* @return string
*/
protected function getThemeFieldsHook(): string
{
return 'themePostFields';
}
}
Function Calls
None |
Stats
MD5 | e2b9b533e5a96760e8a3d89c56ea5da9 |
Eval Count | 0 |
Decode Time | 73 ms |