server/apps/files_encryption/ajax/mode.php

40 lines
1.2 KiB
PHP
Raw Normal View History

2012-08-02 08:39:30 +00:00
<?php
2012-08-02 11:55:23 +00:00
/**
* Copyright (c) 2012, Bjoern Schiessle <schiessle@owncloud.com>
* This file is licensed under the Affero General Public License version 3 or later.
* See the COPYING-README file.
*/
2012-08-03 10:21:49 +00:00
//TODO: Handle switch between client and server side encryption
2012-08-02 08:39:30 +00:00
use OCA_Encryption\Keymanager;
2012-08-02 08:39:30 +00:00
OCP\JSON::checkAppEnabled('files_encryption');
OCP\JSON::checkLoggedIn();
OCP\JSON::callCheck();
$mode = $_POST['mode'];
$changePasswd = false;
$passwdChanged = false;
if ( isset($_POST['newpasswd']) && isset($_POST['oldpasswd']) ) {
$oldpasswd = $_POST['oldpasswd'];
$newpasswd = $_POST['newpasswd'];
$changePasswd = true;
$passwdChanged = Keymanager::changePasswd($oldpasswd, $newpasswd);
}
2012-08-02 08:39:30 +00:00
$query = \OC_DB::prepare( "SELECT mode FROM *PREFIX*encryption WHERE uid = ?" );
$result = $query->execute(array(\OCP\User::getUser()));
2012-08-02 11:55:23 +00:00
if ($result->fetchRow()){
2012-08-02 08:39:30 +00:00
$query = OC_DB::prepare( 'UPDATE *PREFIX*encryption SET mode = ? WHERE uid = ?' );
} else {
$query = OC_DB::prepare( 'INSERT INTO *PREFIX*encryption ( mode, uid ) VALUES( ?, ? )' );
}
if ( (!$changePasswd || $passwdChanged) && $query->execute(array($mode, \OCP\User::getUser())) ) {
OCP\JSON::success();
} else {
OCP\JSON::error();
}