. /** * Microsoft Live Skydrive Repository Plugin * * @package repository_skydrive * @copyright 2012 Lancaster University Network Services Ltd * @author Dan Poltawski * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); require_once('microsoftliveapi.php'); /** * Microsoft skydrive repository plugin. * * @package repository_skydrive * @copyright 2012 Lancaster University Network Services Ltd * @author Dan Poltawski * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class repository_skydrive extends repository { /** @var microsoft_skydrive skydrive oauth2 api helper object */ private $skydrive = null; /** * Constructor * * @param int $repositoryid repository instance id. * @param int|stdClass $context a context id or context object. * @param array $options repository options. */ public function __construct($repositoryid, $context = SYSCONTEXTID, $options = array()) { parent::__construct($repositoryid, $context, $options); $clientid = get_config('skydrive', 'clientid'); $secret = get_config('skydrive', 'secret'); $returnurl = new moodle_url('/repository/repository_callback.php'); $returnurl->param('callback', 'yes'); $returnurl->param('repo_id', $this->id); $returnurl->param('sesskey', sesskey()); $this->skydrive = new microsoft_skydrive($clientid, $secret, $returnurl); $this->check_login(); } /** * Checks whether the user is logged in or not. * * @return bool true when logged in */ public function check_login() { return $this->skydrive->is_logged_in(); } /** * Print the login form, if required * * @return array of login options */ public function print_login() { $url = $this->skydrive->get_login_url(); if ($this->options['ajax']) { $popup = new stdClass(); $popup->type = 'popup'; $popup->url = $url->out(false); return array('login' => array($popup)); } else { echo ''.get_string('login', 'repository').''; } } /** * Given a path, and perhaps a search, get a list of files. * * See details on {@link http://docs.moodle.org/dev/Repository_plugins} * * @param string $path identifier for current path * @param string $page the page number of file list * @return array list of files including meta information as specified by parent. */ public function get_listing($path='', $page = '') { $ret = array(); $ret['dynload'] = true; $ret['nosearch'] = true; $ret['manage'] = 'https://skydrive.live.com/'; $fileslist = $this->skydrive->get_file_list($path); // Filter list for accepted types. Hopefully this will be done by core some day. $fileslist = array_filter($fileslist, array($this, 'filter')); $ret['list'] = $fileslist; // Generate path bar, always start with the plugin name. $ret['path'] = array(); $ret['path'][] = array('name'=> $this->name, 'path'=>''); // Now add each level folder. $trail = ''; if (!empty($path)) { $parts = explode('/', $path); foreach ($parts as $folderid) { if (!empty($folderid)) { $trail .= ('/'.$folderid); $ret['path'][] = array('name' => $this->skydrive->get_folder_name($folderid), 'path' => $trail); } } } return $ret; } /** * Downloads a repository file and saves to a path. * * @param string $id identifier of file * @param string $filename to save file as * @return array with keys: * path: internal location of the file * url: URL to the source */ public function get_file($id, $filename = '') { $path = $this->prepare_file($filename); return $this->skydrive->download_file($id, $path); } /** * Return names of the options to display in the repository form * * @return array of option names */ public static function get_type_option_names() { return array('clientid', 'secret', 'pluginname'); } /** * Setup repistory form. * * @param moodleform $mform Moodle form (passed by reference) * @param string $classname repository class name */ public static function type_config_form($mform, $classname = 'repository') { global $OUTPUT; $a = new stdClass; $a->callbackurl = microsoft_skydrive::callback_url()->out(false); $mform->addElement('static', null, '', get_string('oauthinfo', 'repository_skydrive', $a)); $mform->addElement('static', null, '', $OUTPUT->notification(get_string('deprecatedwarning', 'repository_skydrive', $a))); parent::type_config_form($mform); $strrequired = get_string('required'); $mform->addElement('text', 'clientid', get_string('clientid', 'repository_skydrive')); $mform->addElement('text', 'secret', get_string('secret', 'repository_skydrive')); $mform->addRule('clientid', $strrequired, 'required', null, 'client'); $mform->addRule('secret', $strrequired, 'required', null, 'client'); $mform->setType('clientid', PARAM_RAW_TRIMMED); $mform->setType('secret', PARAM_RAW_TRIMMED); } /** * Logout from repository instance and return * login form. * * @return page to display */ public function logout() { $this->skydrive->log_out(); return $this->print_login(); } /** * This repository doesn't support global search. * * @return bool if supports global search */ public function global_search() { return false; } /** * This repoistory supports any filetype. * * @return string '*' means this repository support any files */ public function supported_filetypes() { return '*'; } /** * This repostiory only supports internal files * * @return int return type bitmask supported */ public function supported_returntypes() { return FILE_INTERNAL; } }