. /** * Action periodically pinged by a page to keep a channel alive * * @category Realtime * @package GNUsocial * @author Evan Prodromou * @copyright 2011 StatusNet, Inc. * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ defined('GNUSOCIAL') || die(); /** * Action periodically pinged by a page to keep a channel alive * * @category Realtime * @package GNUsocial * @author Evan Prodromou * @copyright 2011 StatusNet, Inc. * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ class KeepalivechannelAction extends Action { protected $channelKey = null; protected $channel = null; /** * For initializing members of the class. * * @param array $args misc. arguments * * @return bool true * @throws ClientException */ public function prepare(array $args = []): bool { parent::prepare($args); if (!$this->isPost()) { // TRANS: Client exception. Do not translate POST. throw new ClientException(_m('You have to POST it.')); } $this->channelKey = $this->trimmed('channelkey'); if (empty($this->channelKey)) { // TRANS: Client exception thrown when the channel key argument is missing. throw new ClientException(_m('No channel key argument.')); } $this->channel = Realtime_channel::getKV('channel_key', $this->channelKey); if (empty($this->channel)) { // TRANS: Client exception thrown when referring to a non-existing channel. throw new ClientException(_m('No such channel.')); } return true; } /** * Handler method * * @return void */ public function handle(): void { $this->channel->touch(); http_response_code(204); return; } /** * Return true if read only. * * MAY override * * @param array $args other arguments * * @return bool is read only action? */ public function isReadOnly($args): bool { return false; } }