From 7bf82fc312acb775bf150ce506d16a05989cd43e Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Wed, 17 Jan 2024 17:47:01 +0100 Subject: add key location to info:file output Signed-off-by: Robin Appelman --- lib/private/Encryption/Util.php | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'lib/private/Encryption/Util.php') diff --git a/lib/private/Encryption/Util.php b/lib/private/Encryption/Util.php index a828483265b..bd27d71c40e 100644 --- a/lib/private/Encryption/Util.php +++ b/lib/private/Encryption/Util.php @@ -385,4 +385,25 @@ class Util { return $result; } + + /** + * get path to key folder for a given file + * + * @param string $encryptionModuleId + * @param string $path path to the file, relative to data/ + * @return string + */ + public function getFileKeyDir(string $encryptionModuleId, string $path): string { + [$owner, $filename] = $this->getUidAndFilename($path); + $root = $this->getKeyStorageRoot(); + + // in case of system-wide mount points the keys are stored directly in the data directory + if ($this->isSystemWideMountPoint($filename, $owner)) { + $keyPath = $root . '/' . '/files_encryption/keys' . $filename . '/'; + } else { + $keyPath = $root . '/' . $owner . '/files_encryption/keys' . $filename . '/'; + } + + return Filesystem::normalizePath($keyPath . $encryptionModuleId . '/', false); + } } -- cgit v1.2.3