2013-05-09 21:36:18 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ownCloud
|
|
|
|
*
|
|
|
|
* @author Florin Peter
|
|
|
|
* @copyright 2013 Florin Peter <owncloud@florin-peter.de>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library 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 library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Encryption;
|
|
|
|
|
2013-05-20 03:24:36 +04:00
|
|
|
/**
|
|
|
|
* @brief Class to manage registration of hooks an various helper methods
|
|
|
|
*/
|
2013-05-17 02:58:41 +04:00
|
|
|
/**
|
|
|
|
* Class Helper
|
|
|
|
* @package OCA\Encryption
|
|
|
|
*/
|
2013-05-20 03:24:36 +04:00
|
|
|
class Helper
|
|
|
|
{
|
|
|
|
|
2013-05-09 21:36:18 +04:00
|
|
|
/**
|
|
|
|
* @brief register share related hooks
|
2013-05-20 03:24:36 +04:00
|
|
|
*
|
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function registerShareHooks() {
|
2013-05-20 03:24:36 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
\OCP\Util::connectHook( 'OCP\Share', 'pre_shared', 'OCA\Encryption\Hooks', 'preShared' );
|
|
|
|
\OCP\Util::connectHook( 'OCP\Share', 'post_shared', 'OCA\Encryption\Hooks', 'postShared' );
|
|
|
|
\OCP\Util::connectHook( 'OCP\Share', 'post_unshare', 'OCA\Encryption\Hooks', 'postUnshare' );
|
2013-05-20 03:24:36 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief register user related hooks
|
|
|
|
*
|
2013-05-09 21:36:18 +04:00
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function registerUserHooks() {
|
2013-05-09 21:36:18 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
\OCP\Util::connectHook( 'OC_User', 'post_login', 'OCA\Encryption\Hooks', 'login' );
|
|
|
|
\OCP\Util::connectHook( 'OC_User', 'post_setPassword', 'OCA\Encryption\Hooks', 'setPassphrase' );
|
|
|
|
\OCP\Util::connectHook( 'OC_User', 'post_createUser', 'OCA\Encryption\Hooks', 'postCreateUser' );
|
|
|
|
\OCP\Util::connectHook( 'OC_User', 'post_deleteUser', 'OCA\Encryption\Hooks', 'postDeleteUser' );
|
2013-05-09 21:36:18 +04:00
|
|
|
}
|
|
|
|
|
2013-05-20 03:24:36 +04:00
|
|
|
/**
|
|
|
|
* @brief register filesystem related hooks
|
|
|
|
*
|
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function registerFilesystemHooks() {
|
2013-05-20 03:24:36 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
\OCP\Util::connectHook( 'OC_Filesystem', 'post_rename', 'OCA\Encryption\Hooks', 'postRename' );
|
2013-05-20 03:24:36 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief setup user for files_encryption
|
|
|
|
*
|
|
|
|
* @param Util $util
|
|
|
|
* @param string $password
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function setupUser( $util, $password ) {
|
2013-05-20 03:24:36 +04:00
|
|
|
// Check files_encryption infrastructure is ready for action
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( !$util->ready() ) {
|
2013-05-20 03:24:36 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
\OC_Log::write( 'Encryption library', 'User account "' . $util->getUserId() . '" is not ready for encryption; configuration started', \OC_Log::DEBUG );
|
2013-05-20 03:24:36 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( !$util->setupServerSide( $password ) ) {
|
2013-05-20 03:24:36 +04:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief enable recovery
|
|
|
|
*
|
|
|
|
* @param $recoveryKeyId
|
|
|
|
* @param $recoveryPassword
|
|
|
|
* @internal param \OCA\Encryption\Util $util
|
|
|
|
* @internal param string $password
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function adminEnableRecovery( $recoveryKeyId, $recoveryPassword ) {
|
|
|
|
$view = new \OC\Files\View( '/' );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( $recoveryKeyId === null ) {
|
|
|
|
$recoveryKeyId = 'recovery_' . substr( md5( time() ), 0, 8 );
|
|
|
|
\OC_Appconfig::setValue( 'files_encryption', 'recoveryKeyId', $recoveryKeyId );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( !$view->is_dir( '/owncloud_private_key' ) ) {
|
|
|
|
$view->mkdir( '/owncloud_private_key' );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (
|
2013-05-24 01:56:31 +04:00
|
|
|
( !$view->file_exists( "/public-keys/" . $recoveryKeyId . ".public.key" )
|
|
|
|
|| !$view->file_exists( "/owncloud_private_key/" . $recoveryKeyId . ".private.key" ) )
|
2013-05-17 02:58:41 +04:00
|
|
|
) {
|
|
|
|
|
|
|
|
$keypair = \OCA\Encryption\Crypt::createKeypair();
|
|
|
|
|
|
|
|
\OC_FileProxy::$enabled = false;
|
|
|
|
|
|
|
|
// Save public key
|
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( !$view->is_dir( '/public-keys' ) ) {
|
|
|
|
$view->mkdir( '/public-keys' );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
$view->file_put_contents( '/public-keys/' . $recoveryKeyId . '.public.key', $keypair['publicKey'] );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
// Encrypt private key empthy passphrase
|
2013-05-24 01:56:31 +04:00
|
|
|
$encryptedPrivateKey = \OCA\Encryption\Crypt::symmetricEncryptFileContent( $keypair['privateKey'], $recoveryPassword );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
// Save private key
|
2013-05-24 01:56:31 +04:00
|
|
|
$view->file_put_contents( '/owncloud_private_key/' . $recoveryKeyId . '.private.key', $encryptedPrivateKey );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
// create control file which let us check later on if the entered password was correct.
|
2013-05-24 01:56:31 +04:00
|
|
|
$encryptedControlData = \OCA\Encryption\Crypt::keyEncrypt( "ownCloud", $keypair['publicKey'] );
|
|
|
|
if ( !$view->is_dir( '/control-file' ) ) {
|
|
|
|
$view->mkdir( '/control-file' );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
2013-05-24 01:56:31 +04:00
|
|
|
$view->file_put_contents( '/control-file/controlfile.enc', $encryptedControlData );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
\OC_FileProxy::$enabled = true;
|
|
|
|
|
|
|
|
// Set recoveryAdmin as enabled
|
2013-05-24 01:56:31 +04:00
|
|
|
\OC_Appconfig::setValue( 'files_encryption', 'recoveryAdminEnabled', 1 );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
|
|
|
$return = true;
|
|
|
|
|
|
|
|
} else { // get recovery key and check the password
|
2013-05-24 01:56:31 +04:00
|
|
|
$util = new \OCA\Encryption\Util( new \OC_FilesystemView( '/' ), \OCP\User::getUser() );
|
2013-05-24 20:37:58 +04:00
|
|
|
$return = $util->checkRecoveryPassword( $recoveryPassword );
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( $return ) {
|
|
|
|
\OC_Appconfig::setValue( 'files_encryption', 'recoveryAdminEnabled', 1 );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief disable recovery
|
|
|
|
*
|
|
|
|
* @param $recoveryPassword
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-05-24 01:56:31 +04:00
|
|
|
public static function adminDisableRecovery( $recoveryPassword ) {
|
|
|
|
$util = new Util( new \OC_FilesystemView( '/' ), \OCP\User::getUser() );
|
|
|
|
$return = $util->checkRecoveryPassword( $recoveryPassword );
|
2013-05-17 02:58:41 +04:00
|
|
|
|
2013-05-24 01:56:31 +04:00
|
|
|
if ( $return ) {
|
2013-05-17 02:58:41 +04:00
|
|
|
// Set recoveryAdmin as disabled
|
2013-05-24 01:56:31 +04:00
|
|
|
\OC_Appconfig::setValue( 'files_encryption', 'recoveryAdminEnabled', 0 );
|
2013-05-17 02:58:41 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
2013-05-09 21:36:18 +04:00
|
|
|
}
|