. /** * This plugin is used to access flickr pictures * * @since Moodle 2.0 * @package repository_flickr * @copyright 2010 Dongsheng Cai {@link http://dongsheng.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require_once($CFG->dirroot . '/repository/lib.php'); require_once($CFG->libdir.'/flickrlib.php'); /** * This plugin is used to access user's private flickr repository * * @since Moodle 2.0 * @package repository_flickr * @copyright 2009 Dongsheng Cai {@link http://dongsheng.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class repository_flickr extends repository { private $flickr; public $photos; /** * Stores sizes of images to prevent multiple API call */ static private $sizes = array(); /** * * @param int $repositoryid * @param object $context * @param array $options */ public function __construct($repositoryid, $context = SYSCONTEXTID, $options = array()) { global $SESSION, $CFG; $options['page'] = optional_param('p', 1, PARAM_INT); parent::__construct($repositoryid, $context, $options); $this->setting = 'flickr_'; $this->api_key = $this->get_option('api_key'); $this->secret = $this->get_option('secret'); $this->token = get_user_preferences($this->setting, ''); $this->nsid = get_user_preferences($this->setting.'_nsid', ''); $this->flickr = new phpFlickr($this->api_key, $this->secret, $this->token); $frob = optional_param('frob', '', PARAM_RAW); if (empty($this->token) && !empty($frob)) { $auth_info = $this->flickr->auth_getToken($frob); $this->token = $auth_info['token']; $this->nsid = $auth_info['user']['nsid']; set_user_preference($this->setting, $auth_info['token']); set_user_preference($this->setting.'_nsid', $auth_info['user']['nsid']); } } /** * * @return bool */ public function check_login() { return !empty($this->token); } /** * * @return mixed */ public function logout() { set_user_preference($this->setting, ''); set_user_preference($this->setting.'_nsid', ''); $this->token = ''; $this->nsid = ''; return $this->print_login(); } /** * * @param array $options * @return mixed */ public function set_option($options = array()) { if (!empty($options['api_key'])) { set_config('api_key', trim($options['api_key']), 'flickr'); } if (!empty($options['secret'])) { set_config('secret', trim($options['secret']), 'flickr'); } unset($options['api_key']); unset($options['secret']); $ret = parent::set_option($options); return $ret; } /** * * @param string $config * @return mixed */ public function get_option($config = '') { if ($config==='api_key') { return trim(get_config('flickr', 'api_key')); } elseif ($config ==='secret') { return trim(get_config('flickr', 'secret')); } else { $options['api_key'] = trim(get_config('flickr', 'api_key')); $options['secret'] = trim(get_config('flickr', 'secret')); } $options = parent::get_option($config); return $options; } /** * * @return bool */ public function global_search() { if (empty($this->token)) { return false; } else { return true; } } /** * * @return null */ public function print_login() { if ($this->options['ajax']) { $ret = array(); $popup_btn = new stdClass(); $popup_btn->type = 'popup'; $popup_btn->url = $this->flickr->auth(); $ret['login'] = array($popup_btn); return $ret; } else { echo ''.get_string('login', 'repository').''; } } /** * Converts result received from phpFlickr::photo_search to Filepicker/repository format * * @param mixed $photos * @return array */ private function build_list($photos) { $photos_url = $this->flickr->urls_getUserPhotos($this->nsid); $ret = array(); $ret['manage'] = $photos_url; $ret['list'] = array(); $ret['pages'] = $photos['pages']; $ret['total'] = $photos['total']; $ret['perpage'] = $photos['perpage']; $ret['page'] = $photos['page']; if (!empty($photos['photo'])) { foreach ($photos['photo'] as $p) { if(empty($p['title'])) { $p['title'] = get_string('notitle', 'repository_flickr'); } if (isset($p['originalformat'])) { $format = $p['originalformat']; } else { $format = 'jpg'; } $format = '.'.$format; // append extensions to the files if (substr($p['title'], strlen($p['title'])-strlen($format)) != $format) { $p['title'] .= $format; } $ret['list'][] = array('title'=>$p['title'],'source'=>$p['id'], 'id'=>$p['id'],'thumbnail'=>$this->flickr->buildPhotoURL($p, 'Square'), 'thumbnail_width'=>75, 'thumbnail_height'=>75, 'date'=>'', 'size'=>'unknown', 'url'=>$photos_url.$p['id']); } } return $ret; } /** * * @param string $search_text * @param int $page * @return array */ public function search($search_text, $page = 0) { $photos = $this->flickr->photos_search(array( 'user_id'=>$this->nsid, 'per_page'=>24, 'extras'=>'original_format', 'page'=>$page, 'text'=>$search_text )); $ret = $this->build_list($photos); $ret['list'] = array_filter($ret['list'], array($this, 'filter')); // TODO this breaks pagination return $ret; } /** * * @param string $path * @param int $page * @return array */ public function get_listing($path = '', $page = '') { return $this->search('', $page); } /** * Return photo url by given photo id * @param string $photoid * @return string */ private function build_photo_url($photoid) { $bestsize = $this->get_best_size($photoid); if (!isset($bestsize['source'])) { throw new repository_exception('cannotdownload', 'repository'); } return $bestsize['source']; } /** * Returns the best size for a photo * * @param string $photoid the photo identifier * @return array of information provided by the API */ protected function get_best_size($photoid) { if (!isset(self::$sizes[$photoid])) { // Sizes are returned from smallest to greatest. self::$sizes[$photoid] = $this->flickr->photos_getSizes($photoid); } $sizes = self::$sizes[$photoid]; $bestsize = array(); if (is_array($sizes)) { while ($bestsize = array_pop($sizes)) { // Make sure the source is set. Exit the loop if found. if (isset($bestsize['source'])) { break; } } } return $bestsize; } public function get_link($photoid) { return $this->build_photo_url($photoid); } /** * * @param string $photoid * @param string $file * @return string */ public function get_file($photoid, $file = '') { $url = $this->build_photo_url($photoid); return parent::get_file($url, $file); } /** * Add Plugin settings input to Moodle form * @param object $mform */ public static function type_config_form($mform, $classname = 'repository') { global $CFG; $api_key = get_config('flickr', 'api_key'); $secret = get_config('flickr', 'secret'); if (empty($api_key)) { $api_key = ''; } if (empty($secret)) { $secret = ''; } parent::type_config_form($mform); $strrequired = get_string('required'); $mform->addElement('text', 'api_key', get_string('apikey', 'repository_flickr'), array('value'=>$api_key,'size' => '40')); $mform->setType('api_key', PARAM_RAW_TRIMMED); $mform->addElement('text', 'secret', get_string('secret', 'repository_flickr'), array('value'=>$secret,'size' => '40')); $mform->setType('secret', PARAM_RAW_TRIMMED); //retrieve the flickr instances $params = array(); $params['context'] = array(); //$params['currentcontext'] = $this->context; $params['onlyvisible'] = false; $params['type'] = 'flickr'; $instances = repository::get_instances($params); if (empty($instances)) { $callbackurl = get_string('callbackwarning', 'repository_flickr'); $mform->addElement('static', null, '', $callbackurl); } else { $instance = array_shift($instances); $callbackurl = $CFG->wwwroot.'/repository/repository_callback.php?repo_id='.$instance->id; $mform->addElement('static', 'callbackurl', '', get_string('callbackurltext', 'repository_flickr', $callbackurl)); } $mform->addRule('api_key', $strrequired, 'required', null, 'client'); $mform->addRule('secret', $strrequired, 'required', null, 'client'); } /** * Names of the plugin settings * @return array */ public static function get_type_option_names() { return array('api_key', 'secret', 'pluginname'); } public function supported_filetypes() { return array('web_image'); } public function supported_returntypes() { return (FILE_INTERNAL | FILE_EXTERNAL); } /** * Return the source information * * @param string $photoid * @return string|null */ public function get_file_source_info($photoid) { return $this->build_photo_url($photoid); } }