2017-05-30 07:22:48 -04:00
< ? php
2025-04-27 08:38:18 -04:00
2017-05-30 07:22:48 -04:00
/**
2024-05-28 10:42:42 -04:00
* SPDX - FileCopyrightText : 2017 Nextcloud GmbH and Nextcloud contributors
* SPDX - License - Identifier : AGPL - 3.0 - or - later
2017-05-30 07:22:48 -04:00
*/
namespace OCA\Encryption\Command ;
use OCA\Encryption\Util ;
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 DisableMasterKey extends Command {
/** @var Util */
protected $util ;
/** @var IConfig */
protected $config ;
2025-04-27 08:38:18 -04:00
/** @var QuestionHelper */
2017-05-30 07:22:48 -04:00
protected $questionHelper ;
/**
* @ param Util $util
* @ param IConfig $config
* @ param QuestionHelper $questionHelper
*/
public function __construct ( Util $util ,
2023-11-23 04:22:34 -05:00
IConfig $config ,
QuestionHelper $questionHelper ) {
2017-05-30 07:22:48 -04:00
$this -> util = $util ;
$this -> config = $config ;
$this -> questionHelper = $questionHelper ;
parent :: __construct ();
}
protected function configure () {
$this
-> setName ( 'encryption:disable-master-key' )
-> setDescription ( 'Disable the master key and use per-user keys instead. Only available for fresh installations with no existing encrypted data! There is no way to enable it again.' );
}
2020-06-26 09:12:11 -04:00
protected function execute ( InputInterface $input , OutputInterface $output ) : int {
2017-05-30 07:22:48 -04:00
$isMasterKeyEnabled = $this -> util -> isMasterKeyEnabled ();
2020-04-10 08:19:56 -04:00
if ( ! $isMasterKeyEnabled ) {
2017-05-30 07:22:48 -04:00
$output -> writeln ( 'Master key already disabled' );
} else {
$question = new ConfirmationQuestion (
'Warning: Only perform this operation for a fresh installations with no existing encrypted data! '
. 'There is no way to enable the master key again. '
. 'We strongly recommend to keep the master key, it provides significant performance improvements '
. 'and is easier to handle for both, users and administrators. '
. 'Do you really want to switch to per-user keys? (y/n) ' , false );
if ( $this -> questionHelper -> ask ( $input , $output , $question )) {
$this -> config -> setAppValue ( 'encryption' , 'useMasterKey' , '0' );
$output -> writeln ( 'Master key successfully disabled.' );
} else {
$output -> writeln ( 'aborted.' );
2020-06-26 09:12:11 -04:00
return 1 ;
2017-05-30 07:22:48 -04:00
}
}
2020-06-26 09:12:11 -04:00
return 0 ;
2017-05-30 07:22:48 -04:00
}
}