Qvitter/actions/apiqvitterupdatelinkcolor.php

93 lines
4.1 KiB
PHP
Raw Normal View History

2013-08-19 22:30:57 +09:00
<?php
2016-01-18 09:24:37 +09:00
/* · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
2013-08-19 22:30:57 +09:00
· ·
· ·
· Q V I T T E R ·
· ·
2016-01-18 09:24:37 +09:00
· https://git.gnu.io/h2p/Qvitter ·
2013-08-19 22:30:57 +09:00
· ·
· ·
· <o) ·
· /_//// ·
· (____/ ·
· (o< ·
· o> \\\\_\ ·
· \\) \____) ·
· ·
2016-01-18 09:24:37 +09:00
· ·
2013-08-19 22:30:57 +09:00
· ·
· 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. ·
2016-01-18 09:24:37 +09:00
· ·
2013-08-19 22:30:57 +09:00
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · */
2016-01-18 09:24:37 +09:00
if (!defined('GNUSOCIAL')) { exit(1); }
2013-08-19 22:30:57 +09:00
class ApiQvitterUpdateLinkColorAction extends ApiAuthAction
{
var $linkcolor = null;
2013-08-19 22:30:57 +09:00
protected $needPost = true;
2013-08-19 22:30:57 +09:00
/**
* Take arguments for running
*
* @param array $args $_REQUEST args
*
* @return boolean success flag
*/
protected function prepare(array $args=array())
{
parent::prepare($args);
2013-08-19 22:30:57 +09:00
2016-02-02 02:22:41 +09:00
$this->format = 'json';
$this->linkcolor = $this->trimmed('linkcolor');
2013-08-19 22:30:57 +09:00
return true;
}
2013-08-26 05:34:09 +09:00
/**
* Handle the request
*
* Try to save the user's colors in her design. Create a new design
* if the user doesn't already have one.
*
* @param array $args $_REQUEST data (unused)
*
* @return void
*/
protected function handle()
{
parent::handle();
2016-01-18 09:24:37 +09:00
$validhex = preg_match('/^[a-f0-9]{6}$/i',$this->linkcolor);
if ($validhex === false || $validhex == 0) {
$this->clientError(_('Not a valid hex color.'), 400);
}
2016-01-18 09:24:37 +09:00
// save the new color
Profile_prefs::setData($this->scoped, 'theme', 'linkcolor', $this->linkcolor);
2013-08-26 05:34:09 +09:00
$twitter_user = $this->twitterUserArray($this->scoped, true);
2013-08-19 22:30:57 +09:00
$this->initDocument('json');
$this->showJsonObjects($twitter_user);
$this->endDocument('json');
}
}