typecho-plugin-Access/Action.php

86 lines
2.3 KiB
PHP

<?php
require_once __DIR__ . '/Access_Bootstrap.php';
class Access_Action extends Typecho_Widget implements Widget_Interface_Do
{
private $access;
public function __construct($request, $response, $params = null)
{
parent::__construct($request, $response, $params);
$this->access = new Access_Core();
}
public function execute()
{}
public function action()
{}
public function writeLogs()
{
$image = base64_decode('R0lGODlhAQABAIAAAAAAAP///yH5BAQUAP8ALAAAAAABAAEAAAICRAEAOw==');
$this->response->setContentType('image/gif');
if ($this->access->config->writeType == 1) {
$this->access->writeLogs(null, $this->request->u, $this->request->cid, $this->request->mid);
}
echo $image;
}
public function deleteLogs()
{
try {
$this->checkAuth();
$data = @file_get_contents('php://input');
$data = Json::decode($data, true);
if (!is_array($data)) {
throw new Exception('params invalid');
}
$this->access->deleteLogs($data);
$response = array(
'code' => 0,
);
} catch (Exception $e) {
$response = array(
'code' => 100,
'data' => $e->getMessage(),
);
}
$this->response->throwJson($response);
}
protected function checkAuth()
{
if (!$this->access->isAdmin()) {
throw new Exception('Access Denied', 401);
}
}
public function statistic() {
try {
$this->checkAuth(); # 鉴权
if(!$this->request->isGet())
throw new Exception('Method Not Allowed', 405);
$rpcType = $this->request->get('rpc'); # 业务类型
$statistic = new Access_Statistic($this->request);
$data = $statistic->invoke($rpcType); # 进行业务分发并调取数据
$errCode = 0;
$errMsg = 'ok';
} catch (Exception $e) {
$data = null;
$errCode = $e->getCode();
$errMsg = $e->getMessage();
}
$this->response->throwJson([
'code' => $errCode,
'message' => $errMsg,
'data' => $data
]);
}
}