2016-03-01 00:08:06 +09:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
· ·
|
|
|
|
· Silence a user ·
|
|
|
|
· ·
|
|
|
|
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
· ·
|
|
|
|
· ·
|
|
|
|
· Q V I T T E R ·
|
|
|
|
· ·
|
|
|
|
· https://git.gnu.io/h2p/Qvitter ·
|
|
|
|
· ·
|
|
|
|
· ·
|
|
|
|
· <o) ·
|
|
|
|
· /_//// ·
|
|
|
|
· (____/ ·
|
|
|
|
· (o< ·
|
|
|
|
· o> \\\\_\ ·
|
|
|
|
· \\) \____) ·
|
|
|
|
· ·
|
|
|
|
· ·
|
|
|
|
· ·
|
|
|
|
· Qvitter is free software: you can redistribute it and / or modify it ·
|
|
|
|
· under the terms of the GNU Affero General Public License as published by ·
|
|
|
|
· the Free Software Foundation, either version three of the License or (at ·
|
|
|
|
· your option) any later version. ·
|
|
|
|
· ·
|
|
|
|
· Qvitter is distributed in hope that it will be useful but WITHOUT ANY ·
|
|
|
|
· WARRANTY; without even the implied warranty of MERCHANTABILTY or FITNESS ·
|
|
|
|
· FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for ·
|
|
|
|
· more details. ·
|
|
|
|
· ·
|
|
|
|
· You should have received a copy of the GNU Affero General Public License ·
|
|
|
|
· along with Qvitter. If not, see <http://www.gnu.org/licenses/>. ·
|
|
|
|
· ·
|
|
|
|
· Contact h@nnesmannerhe.im if you have any questions. ·
|
|
|
|
· ·
|
|
|
|
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · */
|
|
|
|
|
|
|
|
|
|
|
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
|
|
|
|
|
|
|
class ApiQvitterSilenceCreateAction extends ApiAuthAction
|
|
|
|
{
|
|
|
|
|
2016-03-04 08:22:25 +09:00
|
|
|
protected $needPost = true;
|
2016-03-01 00:08:06 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Take arguments for running
|
|
|
|
*
|
|
|
|
* @param array $args $_REQUEST args
|
|
|
|
*
|
|
|
|
* @return boolean success flag
|
|
|
|
*/
|
|
|
|
protected function prepare(array $args=array())
|
|
|
|
{
|
|
|
|
parent::prepare($args);
|
|
|
|
|
2016-03-04 08:22:25 +09:00
|
|
|
$this->format = 'json';
|
|
|
|
|
2016-03-01 00:08:06 +09:00
|
|
|
$this->other = $this->getTargetProfile($this->arg('id'));
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle the request
|
|
|
|
*
|
|
|
|
* @param array $args $_REQUEST data (unused)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
protected function handle()
|
|
|
|
{
|
|
|
|
parent::handle();
|
|
|
|
|
|
|
|
if (!$this->other instanceof Profile) {
|
|
|
|
$this->clientError(_('No such user.'), 404);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->scoped->id == $this->other->id) {
|
|
|
|
$this->clientError(_("You cannot silence yourself!"), 403);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
$this->other->silenceAs($this->scoped);
|
2016-03-04 08:22:25 +09:00
|
|
|
} catch (AlreadyFulfilledException $e) {
|
|
|
|
// don't throw client error here, just return the user array like
|
|
|
|
// if we successfully silenced the user. the client is only interested
|
|
|
|
// in making sure the user is silenced.
|
2016-03-01 00:08:06 +09:00
|
|
|
} catch (Exception $e) {
|
|
|
|
$this->clientError($e->getMessage(), $e->getCode());
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->initDocument('json');
|
|
|
|
$this->showJsonObjects($this->twitterUserArray($this->other));
|
|
|
|
$this->endDocument('json');
|
|
|
|
}
|
|
|
|
}
|