2016-03-28 14:45:00 +08:00
|
|
|
<?php
|
|
|
|
class Access_Action implements Widget_Interface_Do
|
|
|
|
{
|
|
|
|
|
|
|
|
private $response;
|
|
|
|
private $request;
|
2016-11-20 16:57:01 +08:00
|
|
|
private $access;
|
2016-03-28 14:45:00 +08:00
|
|
|
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
$this->response = Typecho_Response::getInstance();
|
|
|
|
$this->request = Typecho_Request::getInstance();
|
2016-11-20 16:57:01 +08:00
|
|
|
require_once __DIR__ . '/Access_Bootstrap.php';
|
|
|
|
$this->access = new Access_Core();
|
2016-03-28 14:45:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public function execute()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
public function action()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2016-12-11 18:55:12 +08:00
|
|
|
public function writeLogs()
|
|
|
|
{
|
|
|
|
$this->access->writeLogs($this->request->u);
|
|
|
|
$this->response->setStatus(206);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2016-08-01 15:00:23 +08:00
|
|
|
public function ip()
|
2016-03-28 14:45:00 +08:00
|
|
|
{
|
2016-11-08 13:27:19 +08:00
|
|
|
$this->response->setContentType('application/json');
|
|
|
|
try {
|
|
|
|
$this->checkAuth();
|
|
|
|
$ip = $this->request->get('ip');
|
2016-12-11 18:55:12 +08:00
|
|
|
$response = Access_Ip::find($ip);
|
|
|
|
if (is_array($response)) {
|
|
|
|
$response = array(
|
|
|
|
'code' => 0,
|
|
|
|
'data' => implode(' ', $response),
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$response = array(
|
|
|
|
'code' => 100,
|
|
|
|
'message' => '解析ip失败',
|
|
|
|
);
|
2016-11-08 13:27:19 +08:00
|
|
|
}
|
2016-12-11 18:55:12 +08:00
|
|
|
exit(Json::encode($response));
|
2016-11-08 13:27:19 +08:00
|
|
|
} catch (Exception $e) {
|
|
|
|
exit(Json::encode(array(
|
|
|
|
'code' => 100,
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function deleteLogs()
|
|
|
|
{
|
|
|
|
$this->response->setContentType('application/json');
|
|
|
|
try {
|
|
|
|
$this->checkAuth();
|
|
|
|
$data = @file_get_contents('php://input');
|
|
|
|
$data = Json::decode($data, true);
|
|
|
|
if (!is_array($data)) {
|
|
|
|
throw new Exception('params invalid');
|
|
|
|
}
|
2016-11-20 16:57:01 +08:00
|
|
|
$this->access->deleteLogs($data);
|
2016-11-08 13:27:19 +08:00
|
|
|
exit(Json::encode(array(
|
|
|
|
'code' => 0,
|
|
|
|
)));
|
|
|
|
|
|
|
|
} catch (Exception $e) {
|
|
|
|
exit(Json::encode(array(
|
|
|
|
'code' => 100,
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function checkAuth()
|
|
|
|
{
|
2016-11-20 16:57:01 +08:00
|
|
|
if (!$this->access->isAdmin()) {
|
2016-11-08 13:27:19 +08:00
|
|
|
throw new Exception('Access Denied');
|
|
|
|
}
|
2016-03-28 14:45:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|