2008-06-27 06:19:40 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Box REST Client Library for PHP5 Developers
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @author James Levy <james@box.net>
|
|
|
|
* @link http://enabled.box.net
|
|
|
|
* @access public
|
|
|
|
* @version 1.0
|
|
|
|
* copyright Box.net 2007
|
|
|
|
* Available for use and distribution under GPL-license
|
|
|
|
* Go to http://www.gnu.org/licenses/gpl-3.0.txt for full text
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Modified by Dongsheng Cai <dongsheng@cvs.moodle.org>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2008-07-07 06:34:39 +00:00
|
|
|
require_once($CFG->dirroot.'/repository/'.'curl.class.php');
|
2008-06-27 06:19:40 +00:00
|
|
|
|
|
|
|
class boxclient {
|
|
|
|
|
|
|
|
var $_debug = false;
|
|
|
|
var $_box_api_url = 'http://www.box.net/api/1.0/rest';
|
|
|
|
var $_box_api_upload_url = 'http://upload.box.net/api/1.0/upload';
|
|
|
|
var $_error_code = '';
|
|
|
|
var $_error_msg = '';
|
|
|
|
var $auth_token = '';
|
|
|
|
|
|
|
|
public function setAuth($str){
|
|
|
|
$this->auth_token = $str;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function __construct($api_key, $auth_token) {
|
|
|
|
$this->api_key = $api_key;
|
|
|
|
$this->auth_token = $auth_token;
|
|
|
|
}
|
|
|
|
// Setup for Functions
|
|
|
|
function makeRequest($method, $params = array()) {
|
|
|
|
$this->_clearErrors();
|
|
|
|
$useCURL = in_array('curl', get_loaded_extensions());
|
|
|
|
if ($method == 'upload'){
|
|
|
|
$args = array();
|
|
|
|
foreach($params as $k => $v){
|
|
|
|
array_push($args, urlencode($v));
|
|
|
|
$query_str = implode('/', $args);
|
|
|
|
}
|
|
|
|
$request = $this->_box_api_upload_url .'/'. $query_str;
|
|
|
|
if ($this->_debug){
|
|
|
|
echo "Upload Request: ".$request;
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
$args = array();
|
|
|
|
foreach($params as $k => $v){
|
|
|
|
array_push($args, urlencode($k).'='.urlencode($v));
|
|
|
|
$query_str = implode('&', $args);
|
|
|
|
}
|
|
|
|
$request = $this->_box_api_url .'?'. $method . '&' . $query_str;
|
2008-07-07 06:34:39 +00:00
|
|
|
if ($this->_debug){
|
|
|
|
echo "Request: ".$request;
|
|
|
|
}
|
2008-06-27 06:19:40 +00:00
|
|
|
}
|
|
|
|
if ($useCURL) {
|
2008-07-08 05:00:59 +00:00
|
|
|
$c = new curl(array('cache'=>true));
|
2008-07-07 06:34:39 +00:00
|
|
|
$c->setopt(array('CURLOPT_FOLLOWLOCATION'=>true));
|
|
|
|
$xml = $c->get($request);
|
|
|
|
/*
|
2008-06-27 06:19:40 +00:00
|
|
|
$error = $c->hasError();
|
|
|
|
if ($error) {
|
|
|
|
$this->_error_msg = $error;
|
|
|
|
return false;
|
|
|
|
}
|
2008-07-07 06:34:39 +00:00
|
|
|
*/
|
2008-06-27 06:19:40 +00:00
|
|
|
} else {
|
|
|
|
$url_parsed = parse_url($request);
|
|
|
|
$host = $url_parsed["host"];
|
|
|
|
$port = ($url_parsed['port'] == 0) ? 80 : $url_parsed['port'];
|
|
|
|
$path = $url_parsed["path"] . (($url_parsed['query'] != '') ? $path .= "?{$url_parsed[query]}" : '');
|
|
|
|
$headers = "GET $path HTTP/1.0\r\n";
|
|
|
|
$headers .= "Host: $host\r\n\r\n";
|
|
|
|
$fp = fsockopen($host, $port, $errno, $errstr, 30);
|
|
|
|
if (!$fp) {
|
|
|
|
$this->_error_msg = $errstr;
|
|
|
|
$this->_error_code = $errno;
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
fwrite($fp, $headers);
|
|
|
|
while (!feof($fp)) {
|
|
|
|
$xml .= fgets($fp, 1024);
|
|
|
|
}
|
|
|
|
fclose($fp);
|
|
|
|
|
|
|
|
|
|
|
|
$xml_start = strpos($xml, '<?xml');
|
|
|
|
$xml = substr($xml, $xml_start, strlen($xml));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>XML Response</h2>';
|
|
|
|
echo '<pre class="xml">';
|
|
|
|
echo htmlspecialchars($xml);
|
|
|
|
echo '</pre>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$xml_parser = xml_parser_create();
|
|
|
|
xml_parse_into_struct($xml_parser, $xml, $data);
|
|
|
|
xml_parser_free($xml_parser);
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
function getTicket($params = array()) {
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=get_ticket', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'TICKET':
|
|
|
|
$ret_array['ticket'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Ticket Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
// Get Auth Token
|
|
|
|
function getAuthToken($ticket) {
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['ticket'] = $ticket;
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=get_auth_token', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag'])
|
|
|
|
{
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'AUTH_TOKEN':
|
|
|
|
$ret_array['auth_token'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($ret_array['status'] == 'get_auth_token_ok'){
|
|
|
|
$this->auth_token = $ret_array['auth_token'];
|
|
|
|
$auth_token = $ret_array['auth_token'];
|
2008-07-07 06:34:39 +00:00
|
|
|
return $auth_token;
|
2008-06-27 06:19:40 +00:00
|
|
|
}else{
|
|
|
|
echo '<a href="http://www.box.net/api/1.0/auth/'.$ticket.'">Login</a>';
|
2008-07-07 06:34:39 +00:00
|
|
|
return false;
|
2008-06-27 06:19:40 +00:00
|
|
|
//header ('location: http://www.box.net/api/1.0/auth/'.$ticket) ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Retrieve Account Tree (http://enabled.box.net/docs/rest#get_account_tree)
|
|
|
|
function getAccountTree($params = array()) {
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['folder_id'] = 0;
|
|
|
|
$params['onelevel'] = 1;
|
|
|
|
$params['params[]'] = 'nozip';
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=get_account_tree', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$tree_count=count($data);
|
|
|
|
global $tree_count;
|
|
|
|
$entry_count = 0;
|
|
|
|
for ($i=0, $tree_count=count($data); $i<$tree_count; $i++) {
|
|
|
|
$a = $data[$i];
|
|
|
|
switch ($a['tag'])
|
|
|
|
{
|
|
|
|
case 'FOLDER':
|
|
|
|
if (@is_array($a['attributes'])) {
|
|
|
|
$ret_array['folder_id'][$i] = $a['attributes']['ID'];
|
|
|
|
$ret_array['folder_name'][$i] = $a['attributes']['NAME'];
|
|
|
|
$ret_array['shared'][$i] = $a['attributes']['SHARED'];
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'FILE':
|
|
|
|
if (@is_array($a['attributes'])) {
|
|
|
|
$ret_array['file_id'][$i] = $a['attributes']['ID'];
|
|
|
|
@$ret_array['file_name'][$i] = $a['attributes']['FILE_NAME'];
|
|
|
|
@$ret_array['file_keyword'][$i] = $a['attributes']['KEYWORD'];
|
|
|
|
$entry_count++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Account Tree Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
// Create New Folder
|
|
|
|
function CreateFolder($new_folder_name, $params = array()) {
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['parent_id'] = 0; //Set to '0' by default. Change to create within sub-folder.
|
|
|
|
$params['name'] = $new_folder_name;
|
|
|
|
$params['share'] = 1; //Set to '1' by default. Set to '0' to make folder private.
|
|
|
|
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=create_folder', $params);
|
|
|
|
|
|
|
|
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'FOLDER_ID':
|
|
|
|
$ret_array['folder_id'] = $a['value'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'FOLDER_NAME':
|
|
|
|
$ret_array['folder_type'] = $a['value'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'SHARED':
|
|
|
|
$ret_array['shared'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'PASSWORD':
|
|
|
|
$ret_array['password'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Account Tree Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
// Upload File
|
|
|
|
function UploadFile ($params = array()) {
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['new_file1'] = $_FILES['new_file1'];
|
|
|
|
$params['folder id'] = 0; //Set to '0' by default. Change to create within sub-folder.
|
|
|
|
$params['share'] = 1; //Set to '1' by default. Set to '0' to make folder private.
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeUploadRequst($params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
for ($i=0, $tree_count=count($data); $i<$tree_count; $i++) {
|
|
|
|
$a = $data[$i];
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'FILE':
|
|
|
|
if (is_array($a['attributes'])) {
|
|
|
|
$ret_array['file_name'][$i] = $a['attributes']['FILE_NAME'];
|
|
|
|
$ret_array['id'][$i] = $a['attributes']['ID'];
|
|
|
|
$ret_array['folder_name'][$i] = $a['attributes']['FOLDER_NAME'];
|
|
|
|
$ret_array['error'][$i] = $a['attributes']['ERROR'];
|
|
|
|
$ret_array['public_name'][$i] = $a['attributes']['PUBLIC_NAME'];
|
|
|
|
$entry_count++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Account Tree Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Set Description of File or Folder
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Register New User
|
|
|
|
|
|
|
|
function RegisterUser($params = array()) {
|
|
|
|
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['login'] = $_REQUEST['login'];
|
|
|
|
$params['password'] = $_REQUEST['password'];
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=register_new_user', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'AUTH_TOKEN':
|
|
|
|
$ret_array['auth_token'] = $a['value'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'LOGIN':
|
|
|
|
$ret_array['login'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'SPACE_AMOUNT':
|
|
|
|
$ret_array['space_amount'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'SPACE_USED':
|
|
|
|
$ret_array['space_used'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Registration Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add Tags (http://enabled.box.net/docs/rest#add_to_tag)
|
|
|
|
|
|
|
|
function AddTag($tag, $id, $target_type, $params = array()) {
|
|
|
|
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['target'] = $target_type; // File or folder
|
|
|
|
$params['target_id'] = $id; // Set to ID of file or folder
|
|
|
|
$params['tags[]'] = $tag;
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=add_to_tag', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Tag Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $ret_array;
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// Public Share (http://enabled.box.net/docs/rest#public_share)
|
|
|
|
|
|
|
|
function PublicShare($message, $emails, $id, $target_type, $password, $params = array()) {
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['target'] = $target_type; // File or folder
|
|
|
|
$params['target_id'] = $id; // Set to ID of file or folder
|
|
|
|
$params['password'] = $password; //optional
|
|
|
|
$params['message'] = $message;
|
|
|
|
$params['emails'] = $emails;
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=public_share', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'PUBLIC_NAME':
|
|
|
|
$ret_array['public_name'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Public Share Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Get Friends (http://enabled.box.net/docs/rest#get_friends)
|
|
|
|
|
|
|
|
function GetFriends ($params = array()) {
|
|
|
|
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$params['params[]'] = 'nozip';
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=get_friends', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'NAME':
|
|
|
|
$ret_array['name'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'EMAIL':
|
|
|
|
$ret_array['email'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'ACCEPTED':
|
|
|
|
$ret_array['accepted'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'AVATAR_URL':
|
|
|
|
$ret_array['avatar_url'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'ID':
|
|
|
|
$ret_array['id'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'URL':
|
|
|
|
$ret_array['url'] = $a['value'];
|
|
|
|
break;
|
|
|
|
case 'STATUS':
|
|
|
|
$ret_array['status'] = $a['value'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Get Friend Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Logout User
|
|
|
|
|
|
|
|
function Logout($params = array()) {
|
|
|
|
|
|
|
|
$params['api_key'] = $this->api_key;
|
|
|
|
$params['auth_token'] = $this->auth_token;
|
|
|
|
$ret_array = array();
|
|
|
|
$data = $this->makeRequest('action=logout', $params);
|
|
|
|
if ($this->_checkForError($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
foreach ($data as $a) {
|
|
|
|
switch ($a['tag']) {
|
|
|
|
case 'ACTION':
|
|
|
|
$ret_array['logout'] = $a['value'];
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if ($this->_debug) {
|
|
|
|
echo '<h2>Logout Return</h2>';
|
|
|
|
$this->_a($ret_array);
|
|
|
|
var_dump ($a);
|
|
|
|
}
|
|
|
|
return $ret_array;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function _checkForError($data) {
|
|
|
|
if (@$data[0]['attributes']['STAT'] == 'fail') {
|
|
|
|
$this->_error_code = $data[1]['attributes']['CODE'];
|
|
|
|
$this->_error_msg = $data[1]['attributes']['MSG'];
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function isError() {
|
|
|
|
if ($this->_error_msg != '') {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function getErrorMsg() {
|
|
|
|
return '<p>Error: (' . $this->_error_code . ') ' . $this->_error_msg . '</p>';
|
|
|
|
}
|
|
|
|
|
|
|
|
function getErrorCode() {
|
|
|
|
return $this->_error_code;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function _clearErrors() {
|
|
|
|
$this->_error_code = '';
|
|
|
|
$this->_error_msg = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setDebug($debug) {
|
|
|
|
$this->_debug = $debug;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function _a($array) {
|
|
|
|
var_dump($array);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|