2012-02-22 21:16:33 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2016-05-26 17:56:05 +00:00
|
|
|
* @author Lukas Reschke <lukas@statuscode.ch>
|
2015-03-26 10:44:34 +00:00
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
|
|
|
* @author Robin Appelman <icewind@owncloud.com>
|
|
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
|
|
|
*
|
2016-01-12 14:02:16 +00:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
2015-03-26 10:44:34 +00:00
|
|
|
* @license AGPL-3.0
|
|
|
|
*
|
|
|
|
* This code is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program 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, version 3,
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*
|
2012-02-22 21:16:33 +00:00
|
|
|
*/
|
2015-02-26 10:37:37 +00:00
|
|
|
|
2012-07-25 22:06:51 +00:00
|
|
|
OC_Util::checkAdminUser();
|
2012-08-09 22:11:04 +00:00
|
|
|
OCP\JSON::callCheck();
|
2012-07-25 23:38:20 +00:00
|
|
|
|
2012-02-22 21:16:33 +00:00
|
|
|
$action=isset($_POST['action'])?$_POST['action']:$_GET['action'];
|
2014-02-18 13:12:49 +00:00
|
|
|
|
|
|
|
if(isset($_POST['app']) || isset($_GET['app'])) {
|
2015-02-13 12:33:20 +00:00
|
|
|
$app=OC_App::cleanAppId(isset($_POST['app'])? (string)$_POST['app']: (string)$_GET['app']);
|
2014-02-18 13:12:49 +00:00
|
|
|
}
|
2014-02-18 11:32:57 +00:00
|
|
|
|
|
|
|
// An admin should not be able to add remote and public services
|
|
|
|
// on its own. This should only be possible programmatically.
|
|
|
|
// This change is due the fact that an admin may not be expected
|
|
|
|
// to execute arbitrary code in every environment.
|
2015-02-13 12:33:20 +00:00
|
|
|
if($app === 'core' && isset($_POST['key']) &&(substr((string)$_POST['key'],0,7) === 'remote_' || substr((string)$_POST['key'],0,7) === 'public_')) {
|
2014-02-18 11:32:57 +00:00
|
|
|
OC_JSON::error(array('data' => array('message' => 'Unexpected error!')));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-02-22 21:16:33 +00:00
|
|
|
$result=false;
|
2014-10-17 10:08:31 +00:00
|
|
|
$appConfig = \OC::$server->getAppConfig();
|
2012-09-07 13:22:01 +00:00
|
|
|
switch($action) {
|
2012-02-22 21:16:33 +00:00
|
|
|
case 'getValue':
|
2015-02-13 12:33:20 +00:00
|
|
|
$result=$appConfig->getValue($app, (string)$_GET['key'], (string)$_GET['defaultValue']);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'setValue':
|
2015-02-13 12:33:20 +00:00
|
|
|
$result=$appConfig->setValue($app, (string)$_POST['key'], (string)$_POST['value']);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'getApps':
|
2014-10-17 10:08:31 +00:00
|
|
|
$result=$appConfig->getApps();
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'getKeys':
|
2014-10-17 10:08:31 +00:00
|
|
|
$result=$appConfig->getKeys($app);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'hasKey':
|
2015-02-13 12:33:20 +00:00
|
|
|
$result=$appConfig->hasKey($app, (string)$_GET['key']);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'deleteKey':
|
2015-02-13 12:33:20 +00:00
|
|
|
$result=$appConfig->deleteKey($app, (string)$_POST['key']);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
case 'deleteApp':
|
2014-10-17 10:08:31 +00:00
|
|
|
$result=$appConfig->deleteApp($app);
|
2012-02-22 21:16:33 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
OC_JSON::success(array('data'=>$result));
|
2014-02-18 11:32:57 +00:00
|
|
|
|