}\r
\r
/**\r
- * @brief\r
+ * unshare file/folder from a user with whom you shared the file before\r
*/\r
public static function postUnshare($params) {\r
\r
// Unshare every user who no longer has access to the file\r
$delUsers = array_diff($userIds, $sharingUsers);\r
\r
+ list($owner, $ownerPath) = $util->getUidAndFilename($path);\r
+\r
// delete share key\r
- Keymanager::delShareKey($view, $delUsers, $path);\r
+ Keymanager::delShareKey($view, $delUsers, $ownerPath, $owner);\r
}\r
\r
}\r
}\r
\r
/**\r
+ * unmount file from yourself\r
* remember files/folders which get unmounted\r
*/\r
public static function preUmount($params) {\r
'itemType' => $itemType);\r
}\r
\r
+ /**\r
+ * unmount file from yourself\r
+ */\r
public static function postUmount($params) {\r
\r
if (!isset(self::$umountedFiles[$params[\OC\Files\Filesystem::signal_param_path]])) {\r
// check if the user still has access to the file, otherwise delete share key\r
$sharingUsers = \OCP\Share::getUsersSharingFile($path, $user);\r
if (!in_array(\OCP\User::getUser(), $sharingUsers['users'])) {\r
- Keymanager::delShareKey($view, array(\OCP\User::getUser()), $path);\r
+ Keymanager::delShareKey($view, array(\OCP\User::getUser()), $path, $user);\r
}\r
}\r
}\r
/**
* Delete a single user's shareKey for a single file
+ *
+ * @param \OC\Files\View $view relative to data/
+ * @param array $userIds list of users we want to remove
+ * @param string $filename the owners name of the file for which we want to remove the users relative to data/user/files
+ * @param string $owner owner of the file
*/
- public static function delShareKey(\OC\Files\View $view, $userIds, $filePath) {
+ public static function delShareKey($view, $userIds, $filename, $owner) {
$proxyStatus = \OC_FileProxy::$enabled;
\OC_FileProxy::$enabled = false;
- $userId = Helper::getUser($filePath);
-
- $util = new Util($view, $userId);
-
- list($owner, $filename) = $util->getUidAndFilename($filePath);
+ $util = new Util($view, $owner);
if ($util->isSystemWideMountPoint($filename)) {
$shareKeyPath = \OC\Files\Filesystem::normalizePath('/files_encryption/share-keys/' . $filename);
$this->view->file_put_contents('/'.Test_Encryption_Keymanager::TEST_USER.'/files_encryption/share-keys/folder1/subfolder/subsubfolder/file2.user3.shareKey', 'data');
// recursive delete share keys from user1 and user2
- Encryption\Keymanager::delShareKey($this->view, array('user1', 'user2', Test_Encryption_Keymanager::TEST_USER), '/folder1/');
+ Encryption\Keymanager::delShareKey($this->view, array('user1', 'user2', Test_Encryption_Keymanager::TEST_USER), '/folder1/', Test_Encryption_Keymanager::TEST_USER);
// check if share keys from user1 and user2 are deleted
$this->assertFalse($this->view->file_exists(
$this->view->file_put_contents('/'.Test_Encryption_Keymanager::TEST_USER.'/files_encryption/share-keys/folder1/existingFile.txt.' . Test_Encryption_Keymanager::TEST_USER . '.shareKey', 'data');
// recursive delete share keys from user1 and user2
- Encryption\Keymanager::delShareKey($this->view, array('user1', 'user2', Test_Encryption_Keymanager::TEST_USER), '/folder1/existingFile.txt');
+ Encryption\Keymanager::delShareKey($this->view, array('user1', 'user2', Test_Encryption_Keymanager::TEST_USER), '/folder1/existingFile.txt', Test_Encryption_Keymanager::TEST_USER);
// check if share keys from user1 and user2 are deleted
$this->assertFalse($this->view->file_exists(