2015-08-24 13:56:04 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-21 15:07:57 +00:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
2016-05-26 17:56:05 +00:00
|
|
|
* @author Björn Schießle <bjoern@schiessle.org>
|
2019-12-03 18:57:53 +00:00
|
|
|
* @author Evgeny Golyshev <eugulixes@gmail.com>
|
2016-07-21 15:07:57 +00:00
|
|
|
* @author Joas Schilling <coding@schilljs.com>
|
2017-11-06 14:56:42 +00:00
|
|
|
* @author Matthew Setter <matthew@matthewsetter.com>
|
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
2015-08-24 13:56:04 +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,
|
2019-12-03 18:57:53 +00:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
2015-08-24 13:56:04 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OC\Core\Command\Encryption;
|
|
|
|
|
|
|
|
use OCP\App\IAppManager;
|
|
|
|
use OCP\Encryption\IManager;
|
|
|
|
use OCP\IConfig;
|
|
|
|
use Symfony\Component\Console\Command\Command;
|
|
|
|
use Symfony\Component\Console\Helper\QuestionHelper;
|
|
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
use Symfony\Component\Console\Question\ConfirmationQuestion;
|
|
|
|
|
|
|
|
class EncryptAll extends Command {
|
|
|
|
|
|
|
|
/** @var IManager */
|
|
|
|
protected $encryptionManager;
|
|
|
|
|
|
|
|
/** @var IAppManager */
|
|
|
|
protected $appManager;
|
|
|
|
|
|
|
|
/** @var IConfig */
|
|
|
|
protected $config;
|
|
|
|
|
|
|
|
/** @var QuestionHelper */
|
|
|
|
protected $questionHelper;
|
|
|
|
|
|
|
|
/** @var bool */
|
|
|
|
protected $wasTrashbinEnabled;
|
|
|
|
|
|
|
|
/** @var bool */
|
2017-02-23 05:02:31 +00:00
|
|
|
protected $wasMaintenanceModeEnabled;
|
2015-08-24 13:56:04 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param IManager $encryptionManager
|
|
|
|
* @param IAppManager $appManager
|
|
|
|
* @param IConfig $config
|
|
|
|
* @param QuestionHelper $questionHelper
|
|
|
|
*/
|
|
|
|
public function __construct(
|
|
|
|
IManager $encryptionManager,
|
|
|
|
IAppManager $appManager,
|
|
|
|
IConfig $config,
|
|
|
|
QuestionHelper $questionHelper
|
|
|
|
) {
|
|
|
|
parent::__construct();
|
|
|
|
$this->appManager = $appManager;
|
|
|
|
$this->encryptionManager = $encryptionManager;
|
|
|
|
$this->config = $config;
|
|
|
|
$this->questionHelper = $questionHelper;
|
2015-09-18 06:53:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-02-23 05:02:31 +00:00
|
|
|
* Set maintenance mode and disable the trashbin app
|
2015-09-18 06:53:02 +00:00
|
|
|
*/
|
2017-02-23 05:02:31 +00:00
|
|
|
protected function forceMaintenanceAndTrashbin() {
|
2015-08-24 13:56:04 +00:00
|
|
|
$this->wasTrashbinEnabled = $this->appManager->isEnabledForUser('files_trashbin');
|
2019-02-06 16:08:41 +00:00
|
|
|
$this->wasMaintenanceModeEnabled = $this->config->getSystemValueBool('maintenance');
|
2017-02-23 05:02:31 +00:00
|
|
|
$this->config->setSystemValue('maintenance', true);
|
2015-08-24 13:56:04 +00:00
|
|
|
$this->appManager->disableApp('files_trashbin');
|
|
|
|
}
|
|
|
|
|
2015-09-18 06:53:02 +00:00
|
|
|
/**
|
2017-02-23 05:02:31 +00:00
|
|
|
* Reset the maintenance mode and re-enable the trashbin app
|
2015-09-18 06:53:02 +00:00
|
|
|
*/
|
2017-02-23 05:02:31 +00:00
|
|
|
protected function resetMaintenanceAndTrashbin() {
|
|
|
|
$this->config->setSystemValue('maintenance', $this->wasMaintenanceModeEnabled);
|
2015-08-24 13:56:04 +00:00
|
|
|
if ($this->wasTrashbinEnabled) {
|
|
|
|
$this->appManager->enableApp('files_trashbin');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function configure() {
|
|
|
|
parent::configure();
|
|
|
|
|
2015-09-14 10:00:39 +00:00
|
|
|
$this->setName('encryption:encrypt-all');
|
2015-09-21 11:30:04 +00:00
|
|
|
$this->setDescription('Encrypt all files for all users');
|
|
|
|
$this->setHelp(
|
2015-08-24 13:56:04 +00:00
|
|
|
'This will encrypt all files for all users. '
|
|
|
|
. 'Please make sure that no user access his files during this process!'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function execute(InputInterface $input, OutputInterface $output) {
|
2018-07-29 15:02:42 +00:00
|
|
|
if ( !$input->isInteractive() ) {
|
|
|
|
$output->writeln('Invalid TTY.');
|
|
|
|
$output->writeln('If you are trying to execute the command in a Docker ');
|
|
|
|
$output->writeln("container, do not forget to execute 'docker exec' with");
|
|
|
|
$output->writeln("the '-i' and '-t' options.");
|
|
|
|
$output->writeln('');
|
|
|
|
return;
|
|
|
|
}
|
2015-08-24 13:56:04 +00:00
|
|
|
|
|
|
|
if ($this->encryptionManager->isEnabled() === false) {
|
|
|
|
throw new \Exception('Server side encryption is not enabled');
|
|
|
|
}
|
|
|
|
|
|
|
|
$output->writeln("\n");
|
2017-03-20 03:58:12 +00:00
|
|
|
$output->writeln('You are about to encrypt all files stored in your Nextcloud installation.');
|
2017-02-24 11:36:27 +00:00
|
|
|
$output->writeln('Depending on the number of available files, and their size, this may take quite some time.');
|
|
|
|
$output->writeln('Please ensure that no user accesses their files during this time!');
|
|
|
|
$output->writeln('Note: The encryption module you use determines which files get encrypted.');
|
2015-08-24 13:56:04 +00:00
|
|
|
$output->writeln('');
|
|
|
|
$question = new ConfirmationQuestion('Do you really want to continue? (y/n) ', false);
|
|
|
|
if ($this->questionHelper->ask($input, $output, $question)) {
|
2017-02-23 05:02:31 +00:00
|
|
|
$this->forceMaintenanceAndTrashbin();
|
2015-09-18 06:53:02 +00:00
|
|
|
|
2015-09-18 13:05:18 +00:00
|
|
|
try {
|
|
|
|
$defaultModule = $this->encryptionManager->getEncryptionModule();
|
|
|
|
$defaultModule->encryptAll($input, $output);
|
|
|
|
} catch (\Exception $ex) {
|
2017-02-23 05:02:31 +00:00
|
|
|
$this->resetMaintenanceAndTrashbin();
|
2015-09-18 13:05:18 +00:00
|
|
|
throw $ex;
|
|
|
|
}
|
2015-09-18 06:53:02 +00:00
|
|
|
|
2017-02-23 05:02:31 +00:00
|
|
|
$this->resetMaintenanceAndTrashbin();
|
2015-08-24 13:56:04 +00:00
|
|
|
} else {
|
|
|
|
$output->writeln('aborted');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|