. * * @category API * @package GNUsocial * @author Hannes Mannerheim * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://www.gnu.org/software/social/ */ if (!defined('GNUSOCIAL')) { exit(1); } /** * Ouputs information for a user, specified by ID or screen name. * The user's most recent status will be returned inline. */ class ApiExternalUserShowAction extends ApiPrivateAuthAction { /** * Take arguments for running * * @param array $args $_REQUEST args * * @return boolean success flag * */ protected function prepare(array $args=array()) { parent::prepare($args); $profileurl = urldecode($this->arg('profileurl')); // if this is an instance/user/1234 type url, try to find real profile url if(strstr($profileurl, '/user/')) { $redrected_profileurl = $this->getRedirectUrl($profileurl); // if there's multiple redirects the _first_ redirect is most likely to be the real profileurl if(is_array($redrected_profileurl)) { $profileurl = $redrected_profileurl[0]; } // if only one redirect elseif($redrected_profileurl !== false) { $profileurl = $redrected_profileurl; } } // get local profile $local_profile = Profile::getKV('profileurl',$profileurl); if($local_profile) { $this->profile->local = $this->twitterUserArray($local_profile); } // get profile from external instance $instanceurl = substr($profileurl, 0, strrpos($profileurl, '/')); $username = substr($profileurl, strrpos($profileurl, '/')+1); $apicall = $instanceurl.'/api/users/show.json?id='.$username; stream_context_set_default(array('http' => array('method' => 'GET'))); $this->profile->external = json_decode(file_get_contents($apicall)); return true; } /** * Handle the request * * Check the format and show the user info * * @param array $args $_REQUEST data (unused) * * @return void */ protected function handle() { parent::handle(); $this->initDocument('json'); $this->showJsonObjects($this->profile); $this->endDocument('json'); } /** * Return true if read only. * * MAY override * * @param array $args other arguments * * @return boolean is read only action? */ function isReadOnly($args) { return true; } /** * Get redirect(s) for an url * */ function getRedirectUrl ($url) { stream_context_set_default(array( 'http' => array( 'method' => 'HEAD' ) )); $headers = get_headers($url, 1); if ($headers !== false && isset($headers['Location'])) { return $headers['Location']; } return false; } }