192 lines
5.8 KiB
PHP
Raw Normal View History

2013-07-28 15:44:51 -04:00
<?php
2016-08-18 21:02:49 -04:00
require __DIR__.'/app/common.php';
2013-07-28 15:44:51 -04:00
2016-12-29 15:45:09 -05:00
use JsonRPC\Exception\AccessDeniedException;
use JsonRPC\Exception\AuthenticationFailureException;
use JsonRPC\MiddlewareInterface;
2013-07-28 15:44:51 -04:00
use JsonRPC\Server;
use Miniflux\Handler;
2016-08-24 21:17:58 -04:00
use Miniflux\Model;
use Miniflux\Session\SessionStorage;
2016-12-29 15:45:09 -05:00
use Miniflux\Validator;
class AuthMiddleware implements MiddlewareInterface
{
public function execute($username, $password, $procedureName)
{
$user = Model\User\get_user_by_token('api_token', $password);
if (empty($user)) {
throw new AuthenticationFailureException('Wrong credentials!');
}
2013-07-28 15:44:51 -04:00
SessionStorage::getInstance()->setUser($user);
}
}
2013-07-28 15:44:51 -04:00
$server = new Server();
$server->getMiddlewareHandler()->withMiddleware(new AuthMiddleware());
2016-08-05 20:27:09 -04:00
$procedureHandler = $server->getProcedureHandler();
2015-04-18 11:42:10 -04:00
// Get version
$procedureHandler->withCallback('getVersion', function () {
2016-12-29 15:45:09 -05:00
return APP_VERSION;
});
// Create user
$procedureHandler->withCallback('createUser', function ($username, $password, $is_admin = false) {
if (! SessionStorage::getInstance()->isAdmin()) {
throw new AccessDeniedException('Reserved to administrators');
}
$values = array(
'username' => $username,
'password' => $password,
'confirmation' => $password,
);
list($valid) = Validator\User\validate_creation($values);
if ($valid) {
return Model\User\create_user($username, $password, $is_admin);
}
return false;
});
// Get user
$procedureHandler->withCallback('getUserByUsername', function ($username) {
if (! SessionStorage::getInstance()->isAdmin()) {
throw new AccessDeniedException('Reserved to administrators');
}
return Model\User\get_user_by_username($username);
2015-04-18 11:42:10 -04:00
});
2017-01-02 17:40:53 -05:00
// Remove user
$procedureHandler->withCallback('removeUser', function ($user_id) {
if (! SessionStorage::getInstance()->isAdmin()) {
throw new AccessDeniedException('Reserved to administrators');
}
return Model\User\remove_user($user_id);
});
2013-07-28 15:44:51 -04:00
// Get all feeds
$procedureHandler->withCallback('getFeeds', function () {
$user_id = SessionStorage::getInstance()->getUserId();
$feeds = Model\Feed\get_feeds($user_id);
2016-05-08 15:53:45 -04:00
2015-12-24 17:34:55 +03:00
foreach ($feeds as &$feed) {
$feed['groups'] = Model\Group\get_feed_groups($feed['id']);
2015-12-24 17:34:55 +03:00
}
return $feeds;
2013-07-28 15:44:51 -04:00
});
// Get one feed
$procedureHandler->withCallback('getFeed', function ($feed_id) {
$user_id = SessionStorage::getInstance()->getUserId();
2016-12-29 15:45:09 -05:00
$feed = Model\Feed\get_feed($user_id, $feed_id);
if (! empty($feed)) {
$feed['groups'] = Model\Group\get_feed_groups($feed['id']);
}
return $feed;
2013-07-28 15:44:51 -04:00
});
// Add a new feed
2016-12-29 15:45:09 -05:00
$procedureHandler->withCallback('createFeed', function ($url, $download_content = false, $rtl = false, $group_name = null) {
$user_id = SessionStorage::getInstance()->getUserId();
2016-12-29 15:45:09 -05:00
list($feed_id,) = Handler\Feed\create_feed(
$user_id,
$url,
$download_content,
$rtl,
false,
array(),
$group_name
);
if ($feed_id > 0) {
return $feed_id;
}
2013-07-28 15:44:51 -04:00
return false;
2013-07-28 15:44:51 -04:00
});
// Delete a feed
2016-12-29 15:45:09 -05:00
$procedureHandler->withCallback('removeFeed', function ($feed_id) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Feed\remove_feed($user_id, $feed_id);
});
// Refresh a feed
$procedureHandler->withCallback('refreshFeed', function ($feed_id) {
$user_id = SessionStorage::getInstance()->getUserId();
return Handler\Feed\update_feed($user_id, $feed_id);
});
// Get all items
2016-12-29 15:45:09 -05:00
$procedureHandler->withCallback('getItems', function ($since_id = null, array $item_ids = array(), $limit = 50) {
$user_id = SessionStorage::getInstance()->getUserId();
2016-12-29 15:45:09 -05:00
return Model\Item\get_items($user_id, $since_id, $item_ids, $limit);
});
2017-04-02 08:17:15 +03:00
// Get items by status
$procedureHandler->withCallback('getItemsByStatus', function ($status, array $feed_ids = array(), $offset = null, $limit = 50, $order_column = 'updated', $order_direction = 'desc') {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Item\get_items_by_status($user_id, $status, $feed_ids, $offset, $limit, $order_column, $order_direction);
});
// Get one item
$procedureHandler->withCallback('getItem', function ($item_id) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Item\get_item($user_id, $item_id);
2013-07-28 15:44:51 -04:00
});
// Change items status
$procedureHandler->withCallback('changeItemsStatus', function (array $item_ids, $status) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Item\change_item_ids_status($user_id, $item_ids, $status);
2013-07-28 15:44:51 -04:00
});
// Add a bookmark
$procedureHandler->withCallback('addBookmark', function ($item_id) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Bookmark\set_flag($user_id, $item_id, 1);
2013-07-28 15:44:51 -04:00
});
// Remove a bookmark
$procedureHandler->withCallback('removeBookmark', function ($item_id) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Bookmark\set_flag($user_id, $item_id, 0);
2013-07-28 15:44:51 -04:00
});
// Get all groups
$procedureHandler->withCallback('getGroups', function () {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Group\get_all($user_id);
2013-07-28 15:44:51 -04:00
});
// Add a new group
$procedureHandler->withCallback('createGroup', function ($title) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Group\create_group($user_id, $title);
});
// Add/Update groups for a feed
2016-12-29 18:52:37 -05:00
$procedureHandler->withCallback('setFeedGroups', function ($feed_id, array $group_ids) {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Group\update_feed_groups($user_id, $feed_id, $group_ids);
});
// Get favicons
$procedureHandler->withCallback('getFavicons', function () {
$user_id = SessionStorage::getInstance()->getUserId();
return Model\Favicon\get_favicons_with_data_url($user_id);
});
echo $server->execute();