a7df23ceba
This enforces proper types on POST and GET arguments where I considered it sensible. I didn't update some as I don't know what kind of values they would support 🙈 Fixes https://github.com/owncloud/core/issues/14196 for core
48 lines
1.2 KiB
PHP
48 lines
1.2 KiB
PHP
<?php
|
|
/**
|
|
* Copyright (c) 2013 Georg Ehrke georg@ownCloud.com
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
* later.
|
|
* See the COPYING-README file.
|
|
*/
|
|
OCP\JSON::checkAdminUser();
|
|
OCP\JSON::callCheck();
|
|
|
|
if (!array_key_exists('appid', $_POST)) {
|
|
OCP\JSON::error(array(
|
|
'message' => 'No AppId given!'
|
|
));
|
|
return;
|
|
}
|
|
|
|
$appId = (string)$_POST['appid'];
|
|
|
|
if (!is_numeric($appId)) {
|
|
$appId = \OC::$server->getAppConfig()->getValue($appId, 'ocsid', null);
|
|
if ($appId === null) {
|
|
OCP\JSON::error(array(
|
|
'message' => 'No OCS-ID found for app!'
|
|
));
|
|
exit;
|
|
}
|
|
}
|
|
|
|
$appId = OC_App::cleanAppId($appId);
|
|
|
|
$config = \OC::$server->getConfig();
|
|
$config->setSystemValue('maintenance', true);
|
|
try {
|
|
$result = OC_Installer::updateAppByOCSId($appId);
|
|
$config->setSystemValue('maintenance', false);
|
|
} catch(Exception $ex) {
|
|
$config->setSystemValue('maintenance', false);
|
|
OC_JSON::error(array("data" => array( "message" => $ex->getMessage() )));
|
|
return;
|
|
}
|
|
|
|
if($result !== false) {
|
|
OC_JSON::success(array('data' => array('appid' => $appId)));
|
|
} else {
|
|
$l = \OC::$server->getL10N('settings');
|
|
OC_JSON::error(array("data" => array( "message" => $l->t("Couldn't update app.") )));
|
|
}
|