2017-05-30 07:22:48 -04:00
< ? php
2025-06-30 09:04:05 -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 ;
2025-10-01 09:00:20 -04:00
use OCP\AppFramework\Services\IAppConfig ;
2017-05-30 07:22:48 -04:00
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 {
2023-08-03 07:06:40 -04:00
public function __construct (
protected Util $util ,
2025-10-01 09:00:20 -04:00
protected IAppConfig $config ,
2023-08-03 07:06:40 -04:00
protected QuestionHelper $questionHelper ,
) {
2017-05-30 07:22:48 -04:00
parent :: __construct ();
}
2023-08-03 07:06:40 -04:00
protected function configure () : void {
2017-05-30 07:22:48 -04:00
$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' );
2023-08-03 07:20:33 -04:00
return self :: SUCCESS ;
2017-05-30 07:22:48 -04:00
}
2023-08-03 07:20:33 -04:00
$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 )) {
2025-10-01 09:00:20 -04:00
$this -> config -> setAppValueBool ( 'useMasterKey' , false );
2023-08-03 07:20:33 -04:00
$output -> writeln ( 'Master key successfully disabled.' );
return self :: SUCCESS ;
}
$output -> writeln ( 'aborted.' );
return self :: FAILURE ;
2017-05-30 07:22:48 -04:00
}
}