nextcloud/lib/ocs/cloud.php

109 lines
3.0 KiB
PHP
Raw Normal View History

2012-07-30 16:42:18 +04:00
<?php
/**
* ownCloud
*
* @author Frank Karlitschek
* @author Tom Needham
* @copyright 2012 Frank Karlitschek frank@owncloud.org
* @copyright 2012 Tom Needham tom@owncloud.com
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
* License as published by the Free Software Foundation; either
* version 3 of the License, or any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY 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 this library. If not, see <http://www.gnu.org/licenses/>.
*
*/
2012-07-30 16:42:18 +04:00
class OC_OCS_Cloud {
2013-02-10 15:46:41 +04:00
public static function getCapabilities($parameters) {
$result = array();
list($major, $minor, $micro) = OC_Util::getVersion();
$result['version'] = array(
'major' => $major,
'minor' => $minor,
'micro' => $micro,
'string' => OC_Util::getVersionString(),
'edition' => OC_Util::getEditionString(),
);
2013-05-01 21:20:46 +04:00
$result['capabilities'] = array(
'core' => array(
'pollinterval' => OC_Config::getValue('pollinterval', 60),
),
);
return new OC_OCS_Result($result);
2012-07-30 16:42:18 +04:00
}
2013-05-01 21:20:46 +04:00
/**
* gets user info
2013-08-27 18:07:25 +04:00
*
* exposes the quota of an user:
* <data>
* <quota>
* <free>1234</free>
* <used>4321</used>
* <total>5555</total>
* <ralative>0.78</ralative>
* </quota>
* </data>
*
* @param $parameters object should contain parameter 'userid' which identifies
* the user from whom the information will be returned
2013-05-01 21:20:46 +04:00
*/
2013-05-01 21:26:02 +04:00
public static function getUser($parameters) {
2013-05-01 21:20:46 +04:00
// Check if they are viewing information on themselves
2013-05-01 21:26:02 +04:00
if($parameters['userid'] === OC_User::getUser()) {
2013-05-01 21:20:46 +04:00
// Self lookup
$quota = array();
$storage = OC_Helper::getStorageInfo();
$quota = array(
'free' => $storage['free'],
'used' => $storage['used'],
'total' => $storage['total'],
'relative' => $storage['relative'],
);
return new OC_OCS_Result(array('quota' => $quota));
} else {
// No permission to view this user data
return new OC_OCS_Result(null, 997);
}
}
2013-01-14 23:30:39 +04:00
public static function getUserPublickey($parameters) {
2012-07-30 16:42:18 +04:00
if(OC_User::userExists($parameters['user'])) {
2012-07-30 16:42:18 +04:00
// calculate the disc space
// TODO
return new OC_OCS_Result(array());
} else {
return new OC_OCS_Result(null, 300);
2012-07-30 16:42:18 +04:00
}
}
2013-01-14 23:30:39 +04:00
public static function getUserPrivatekey($parameters) {
2012-08-01 00:19:11 +04:00
$user = OC_User::getUser();
if(OC_User::isAdminUser($user) or ($user==$parameters['user'])) {
2012-07-30 16:42:18 +04:00
if(OC_User::userExists($user)) {
2012-08-01 00:19:11 +04:00
// calculate the disc space
$txt = 'this is the private key of '.$parameters['user'];
2012-08-01 00:19:11 +04:00
echo($txt);
} else {
return new OC_OCS_Result(null, 300, 'User does not exist');
2012-08-01 00:19:11 +04:00
}
} else {
return new OC_OCS_Result('null', 300, 'You don´t have permission to access this ressource.');
2012-08-01 00:19:11 +04:00
}
2012-07-30 16:42:18 +04:00
}
}