. /** * Action to close a channel * * @category Realtime * @package GNUsocial * @author Evan Prodromou * @copyright 2011-2019 Free Software Foundation, Inc http://www.fsf.org * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ defined('GNUSOCIAL') || die(); /** * Action to close a channel * * @category Realtime * @package GNUsocial * @author Evan Prodromou * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ class ClosechannelAction extends Action { protected $channelKey = null; protected $channel = null; /** * For initializing members of the class. * * @param array $args misc. arguments * * @return boolean true * @throws ClientException */ public function prepare(array $args = []) { 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->decrement(); 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; } }