adjust files_external
This commit is contained in:
parent
5696c8aa35
commit
a2f752bcf3
6 changed files with 187 additions and 53 deletions
|
@ -13,7 +13,7 @@
|
||||||
<admin>admin-external-storage</admin>
|
<admin>admin-external-storage</admin>
|
||||||
</documentation>
|
</documentation>
|
||||||
<rememberlogin>false</rememberlogin>
|
<rememberlogin>false</rememberlogin>
|
||||||
<version>1.1.0</version>
|
<version>1.1.1</version>
|
||||||
<types>
|
<types>
|
||||||
<filesystem/>
|
<filesystem/>
|
||||||
</types>
|
</types>
|
||||||
|
@ -24,4 +24,9 @@
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<owncloud min-version="9.2" max-version="9.2" />
|
<owncloud min-version="9.2" max-version="9.2" />
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
|
<settings>
|
||||||
|
<admin>OCA\Files_External\Settings\Admin</admin>
|
||||||
|
<admin-section>OCA\Files_External\Settings\Section</admin-section>
|
||||||
|
</settings>
|
||||||
</info>
|
</info>
|
||||||
|
|
|
@ -68,10 +68,6 @@ class Application extends App implements IBackendProvider, IAuthMechanismProvide
|
||||||
* Register settings templates
|
* Register settings templates
|
||||||
*/
|
*/
|
||||||
public function registerSettings() {
|
public function registerSettings() {
|
||||||
$container = $this->getContainer();
|
|
||||||
$backendService = $container->query('OCA\\Files_External\\Service\\BackendService');
|
|
||||||
|
|
||||||
\OCP\App::registerAdmin('files_external', 'settings');
|
|
||||||
\OCP\App::registerPersonal('files_external', 'personal');
|
\OCP\App::registerPersonal('files_external', 'personal');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
96
apps/files_external/lib/Settings/Admin.php
Normal file
96
apps/files_external/lib/Settings/Admin.php
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OCA\Files_External\Settings;
|
||||||
|
|
||||||
|
use OCA\Files_External\Lib\Auth\Password\GlobalAuth;
|
||||||
|
use OCA\Files_External\Service\BackendService;
|
||||||
|
use OCA\Files_External\Service\GlobalStoragesService;
|
||||||
|
use OCP\AppFramework\Http\TemplateResponse;
|
||||||
|
use OCP\Encryption\IManager;
|
||||||
|
use OCP\Settings\ISettings;
|
||||||
|
|
||||||
|
class Admin implements ISettings {
|
||||||
|
|
||||||
|
/** @var IManager */
|
||||||
|
private $encryptionManager;
|
||||||
|
|
||||||
|
/** @var GlobalStoragesService */
|
||||||
|
private $globalStoragesService;
|
||||||
|
|
||||||
|
/** @var BackendService */
|
||||||
|
private $backendService;
|
||||||
|
|
||||||
|
/** @var GlobalAuth */
|
||||||
|
private $globalAuth;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
IManager $encryptionManager,
|
||||||
|
GlobalStoragesService $globalStoragesService,
|
||||||
|
BackendService $backendService,
|
||||||
|
GlobalAuth $globalAuth
|
||||||
|
) {
|
||||||
|
$this->encryptionManager = $encryptionManager;
|
||||||
|
$this->globalStoragesService = $globalStoragesService;
|
||||||
|
$this->backendService = $backendService;
|
||||||
|
$this->globalAuth = $globalAuth;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return TemplateResponse
|
||||||
|
*/
|
||||||
|
public function getForm() {
|
||||||
|
$parameters = [
|
||||||
|
'encryptionEnabled' => $this->encryptionManager->isEnabled(),
|
||||||
|
'visibilityType' => BackendService::VISIBILITY_ADMIN,
|
||||||
|
'storages' => $this->globalStoragesService->getStorages(),
|
||||||
|
'backends' => $this->backendService->getAvailableBackends(),
|
||||||
|
'authMechanisms' => $this->backendService->getAuthMechanisms(),
|
||||||
|
'dependencies' => \OC_Mount_Config::dependencyMessage($this->backendService->getBackends()),
|
||||||
|
'allowUserMounting' => $this->backendService->isUserMountingAllowed(),
|
||||||
|
'globalCredentials' => $this->globalAuth->getAuth(''),
|
||||||
|
'globalCredentialsUid' => '',
|
||||||
|
];
|
||||||
|
|
||||||
|
return new TemplateResponse('files_external', 'settings', $parameters, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string the section ID, e.g. 'sharing'
|
||||||
|
*/
|
||||||
|
public function getSection() {
|
||||||
|
return 'externalstorage';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int whether the form should be rather on the top or bottom of
|
||||||
|
* the admin section. The forms are arranged in ascending order of the
|
||||||
|
* priority values. It is required to return a value between 0 and 100.
|
||||||
|
*
|
||||||
|
* E.g.: 70
|
||||||
|
*/
|
||||||
|
public function getPriority() {
|
||||||
|
return 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
67
apps/files_external/lib/Settings/Section.php
Normal file
67
apps/files_external/lib/Settings/Section.php
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OCA\Files_External\Settings;
|
||||||
|
|
||||||
|
use OCP\IL10N;
|
||||||
|
use OCP\Settings\ISection;
|
||||||
|
|
||||||
|
class Section implements ISection {
|
||||||
|
/** @var IL10N */
|
||||||
|
private $l;
|
||||||
|
|
||||||
|
public function __construct(IL10N $l) {
|
||||||
|
$this->l = $l;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the ID of the section. It is supposed to be a lower case string,
|
||||||
|
* e.g. 'ldap'
|
||||||
|
*
|
||||||
|
* @returns string
|
||||||
|
*/
|
||||||
|
public function getID() {
|
||||||
|
return 'externalstorage';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the translated name as it should be displayed, e.g. 'LDAP / AD
|
||||||
|
* integration'. Use the L10N service to translate it.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getName() {
|
||||||
|
return $this->l->t('External Storage');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int whether the form should be rather on the top or bottom of
|
||||||
|
* the settings navigation. The sections are arranged in ascending order of
|
||||||
|
* the priority values. It is required to return a value between 0 and 99.
|
||||||
|
*
|
||||||
|
* E.g.: 70
|
||||||
|
*/
|
||||||
|
public function getPriority() {
|
||||||
|
return 35;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,48 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
||||||
*
|
|
||||||
* @author Joas Schilling <coding@schilljs.com>
|
|
||||||
* @author Michael Gapczynski <GapczynskiM@gmail.com>
|
|
||||||
* @author Morris Jobke <hey@morrisjobke.de>
|
|
||||||
* @author Robin Appelman <robin@icewind.nl>
|
|
||||||
* @author Robin McCorkell <robin@mccorkell.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/>
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
use \OCA\Files_External\Service\BackendService;
|
|
||||||
|
|
||||||
// we must use the same container
|
|
||||||
$appContainer = \OC_Mount_Config::$app->getContainer();
|
|
||||||
$backendService = $appContainer->query('OCA\Files_External\Service\BackendService');
|
|
||||||
$globalStoragesService = $appContainer->query('OCA\Files_External\Service\GlobalStoragesService');
|
|
||||||
$globalAuth = $appContainer->query('OCA\Files_External\Lib\Auth\Password\GlobalAuth');
|
|
||||||
|
|
||||||
\OC_Util::addVendorScript('select2/select2');
|
|
||||||
\OC_Util::addVendorStyle('select2/select2');
|
|
||||||
|
|
||||||
$tmpl = new OCP\Template('files_external', 'settings');
|
|
||||||
$tmpl->assign('encryptionEnabled', \OC::$server->getEncryptionManager()->isEnabled());
|
|
||||||
$tmpl->assign('visibilityType', BackendService::VISIBILITY_ADMIN);
|
|
||||||
$tmpl->assign('storages', $globalStoragesService->getStorages());
|
|
||||||
$tmpl->assign('backends', $backendService->getAvailableBackends());
|
|
||||||
$tmpl->assign('authMechanisms', $backendService->getAuthMechanisms());
|
|
||||||
$tmpl->assign('dependencies', OC_Mount_Config::dependencyMessage($backendService->getBackends()));
|
|
||||||
$tmpl->assign('allowUserMounting', $backendService->isUserMountingAllowed());
|
|
||||||
$tmpl->assign('globalCredentials', $globalAuth->getAuth(''));
|
|
||||||
$tmpl->assign('globalCredentialsUid', '');
|
|
||||||
return $tmpl->fetchPage();
|
|
|
@ -310,6 +310,24 @@ class DIContainer extends SimpleContainer implements IAppContainer {
|
||||||
return $c->query('ServerContainer')->getWebRoot();
|
return $c->query('ServerContainer')->getWebRoot();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$this->registerService('\OCP\Encryption\IManager', function ($c) {
|
||||||
|
$view = new \OC\Files\View();
|
||||||
|
$util = new \OC\Encryption\Util(
|
||||||
|
$view,
|
||||||
|
$c->query('\OCP\IUserManager'),
|
||||||
|
$c->query('\OCP\IGroupManager'),
|
||||||
|
$c->query('\OCP\IConfig')
|
||||||
|
);
|
||||||
|
return new \OC\Encryption\Manager(
|
||||||
|
$c->query('\OCP\IConfig'),
|
||||||
|
$c->query('\OCP\ILogger'),
|
||||||
|
$c->query('ServerContainer')->getL10N('core'),
|
||||||
|
new \OC\Files\View(),
|
||||||
|
$util,
|
||||||
|
new \OC\Memcache\ArrayCache()
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* App Framework APIs
|
* App Framework APIs
|
||||||
|
|
Loading…
Reference in a new issue