2014-12-19 17:23:24 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-21 14:49:16 +00:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
|
|
|
* @author Lukas Reschke <lukas@statuscode.ch>
|
2017-11-06 14:56:42 +00:00
|
|
|
* @author Martin Mattel <martin.mattel@diemattels.at>
|
2015-03-26 10:44:34 +00:00
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
2016-07-21 16:13:36 +00:00
|
|
|
* @author Robin Appelman <robin@icewind.nl>
|
2016-01-12 14:02:16 +00:00
|
|
|
* @author Robin McCorkell <robin@mccorkell.me.uk>
|
2017-11-06 14:56:42 +00:00
|
|
|
* @author Roeland Jago Douma <roeland@famdouma.nl>
|
2015-03-26 10:44:34 +00:00
|
|
|
* @author Ross Nicoll <jrn@jrn.me.uk>
|
|
|
|
*
|
|
|
|
* @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/>
|
|
|
|
*
|
2014-12-19 17:23:24 +00:00
|
|
|
*/
|
2015-02-26 10:37:37 +00:00
|
|
|
|
2014-12-19 17:23:24 +00:00
|
|
|
namespace OCA\Files_External\Controller;
|
|
|
|
|
2016-06-21 11:55:07 +00:00
|
|
|
use OCA\Files_External\Lib\Auth\Password\GlobalAuth;
|
2014-12-19 17:23:24 +00:00
|
|
|
use OCP\AppFramework\Controller;
|
2016-06-27 10:29:27 +00:00
|
|
|
use OCP\IGroupManager;
|
2014-12-19 17:23:24 +00:00
|
|
|
use OCP\IRequest;
|
|
|
|
use OCP\AppFramework\Http\JSONResponse;
|
2015-08-19 20:13:16 +00:00
|
|
|
use OCA\Files_External\Lib\Auth\PublicKey\RSA;
|
2016-06-27 10:29:27 +00:00
|
|
|
use OCP\IUserSession;
|
2014-12-19 17:23:24 +00:00
|
|
|
|
|
|
|
class AjaxController extends Controller {
|
2015-08-19 20:13:16 +00:00
|
|
|
/** @var RSA */
|
|
|
|
private $rsaMechanism;
|
2016-06-21 11:55:07 +00:00
|
|
|
/** @var GlobalAuth */
|
|
|
|
private $globalAuth;
|
2016-06-27 10:29:27 +00:00
|
|
|
/** @var IUserSession */
|
|
|
|
private $userSession;
|
|
|
|
/** @var IGroupManager */
|
|
|
|
private $groupManager;
|
2015-08-19 20:13:16 +00:00
|
|
|
|
2016-06-27 10:29:27 +00:00
|
|
|
/**
|
|
|
|
* @param string $appName
|
|
|
|
* @param IRequest $request
|
|
|
|
* @param RSA $rsaMechanism
|
|
|
|
* @param GlobalAuth $globalAuth
|
|
|
|
* @param IUserSession $userSession
|
|
|
|
* @param IGroupManager $groupManager
|
|
|
|
*/
|
2016-06-21 11:55:07 +00:00
|
|
|
public function __construct($appName,
|
|
|
|
IRequest $request,
|
|
|
|
RSA $rsaMechanism,
|
2016-06-27 10:29:27 +00:00
|
|
|
GlobalAuth $globalAuth,
|
|
|
|
IUserSession $userSession,
|
|
|
|
IGroupManager $groupManager) {
|
2014-12-19 17:23:24 +00:00
|
|
|
parent::__construct($appName, $request);
|
2015-08-19 20:13:16 +00:00
|
|
|
$this->rsaMechanism = $rsaMechanism;
|
2016-06-21 11:55:07 +00:00
|
|
|
$this->globalAuth = $globalAuth;
|
2016-06-27 10:29:27 +00:00
|
|
|
$this->userSession = $userSession;
|
|
|
|
$this->groupManager = $groupManager;
|
2014-12-19 17:23:24 +00:00
|
|
|
}
|
|
|
|
|
2016-06-27 10:29:27 +00:00
|
|
|
/**
|
2017-06-05 13:42:25 +00:00
|
|
|
* @param int $keyLength
|
2016-06-27 10:29:27 +00:00
|
|
|
* @return array
|
|
|
|
*/
|
2017-06-05 13:42:25 +00:00
|
|
|
private function generateSshKeys($keyLength) {
|
|
|
|
$key = $this->rsaMechanism->createKey($keyLength);
|
2014-12-19 17:23:24 +00:00
|
|
|
// Replace the placeholder label with a more meaningful one
|
2017-02-23 16:29:04 +00:00
|
|
|
$key['publickey'] = str_replace('phpseclib-generated-key', gethostname(), $key['publickey']);
|
2014-12-19 17:23:24 +00:00
|
|
|
|
|
|
|
return $key;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates an SSH public/private key pair.
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
2017-06-05 13:42:25 +00:00
|
|
|
* @param int $keyLength
|
2014-12-19 17:23:24 +00:00
|
|
|
*/
|
2017-06-05 13:42:25 +00:00
|
|
|
public function getSshKeys($keyLength = 1024) {
|
|
|
|
$key = $this->generateSshKeys($keyLength);
|
2014-12-19 17:23:24 +00:00
|
|
|
return new JSONResponse(
|
|
|
|
array('data' => array(
|
|
|
|
'private_key' => $key['privatekey'],
|
|
|
|
'public_key' => $key['publickey']
|
|
|
|
),
|
|
|
|
'status' => 'success'
|
|
|
|
));
|
|
|
|
}
|
2016-06-21 11:55:07 +00:00
|
|
|
|
|
|
|
/**
|
2016-06-27 10:29:27 +00:00
|
|
|
* @NoAdminRequired
|
|
|
|
*
|
2016-06-21 11:55:07 +00:00
|
|
|
* @param string $uid
|
|
|
|
* @param string $user
|
|
|
|
* @param string $password
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function saveGlobalCredentials($uid, $user, $password) {
|
2016-06-27 10:29:27 +00:00
|
|
|
$currentUser = $this->userSession->getUser();
|
|
|
|
|
|
|
|
// Non-admins can only edit their own credentials
|
2018-01-26 11:36:25 +00:00
|
|
|
$allowedToEdit = ($this->groupManager->isAdmin($currentUser->getUID()) || $currentUser->getUID() === $uid);
|
2016-06-27 10:29:27 +00:00
|
|
|
|
|
|
|
if ($allowedToEdit) {
|
|
|
|
$this->globalAuth->saveAuth($uid, $user, $password);
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
2016-06-21 11:55:07 +00:00
|
|
|
}
|
2014-12-19 17:23:24 +00:00
|
|
|
}
|