summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2022-03-08 17:12:26 +0100
committerRobin Appelman <robin@icewind.nl>2022-03-24 17:01:38 +0100
commit469a684d45a3424a4ddd51a023f7b18fec0d950f (patch)
tree95b16e6b2d99ddda24bd77d0c2f6de2907d08ffb /lib
parent04052a959443c2df04a11ae1ed523eefd7e0a0ad (diff)
downloadnextcloud-server-469a684d45a3424a4ddd51a023f7b18fec0d950f.tar.gz
nextcloud-server-469a684d45a3424a4ddd51a023f7b18fec0d950f.zip
allow getting mounts by provider
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/Config/MountProviderCollection.php22
-rw-r--r--lib/public/Files/Config/IMountProviderCollection.php10
2 files changed, 26 insertions, 6 deletions
diff --git a/lib/private/Files/Config/MountProviderCollection.php b/lib/private/Files/Config/MountProviderCollection.php
index cd8a2a2e29f..efbb54edba5 100644
--- a/lib/private/Files/Config/MountProviderCollection.php
+++ b/lib/private/Files/Config/MountProviderCollection.php
@@ -75,16 +75,15 @@ class MountProviderCollection implements IMountProviderCollection, Emitter {
}
/**
- * Get all configured mount points for the user
- *
- * @param \OCP\IUser $user
- * @return \OCP\Files\Mount\IMountPoint[]
+ * @param IUser $user
+ * @param IMountProvider[] $providers
+ * @return IMountPoint[]
*/
- public function getMountsForUser(IUser $user) {
+ private function getMountsForFromProviders(IUser $user, array $providers): array {
$loader = $this->loader;
$mounts = array_map(function (IMountProvider $provider) use ($user, $loader) {
return $provider->getMountsForUser($user, $loader);
- }, $this->providers);
+ }, $providers);
$mounts = array_filter($mounts, function ($result) {
return is_array($result);
});
@@ -94,6 +93,17 @@ class MountProviderCollection implements IMountProviderCollection, Emitter {
return $this->filterMounts($user, $mounts);
}
+ public function getMountsForUser(IUser $user): array {
+ return $this->getMountsForFromProviders($user, $this->providers);
+ }
+
+ public function getMountsFromProvider(IUser $user, string $mountProviderClass): array {
+ $providers = array_filter($this->providers, function (IMountProvider $mountProvider) use ($mountProviderClass) {
+ return get_class($mountProvider) === $mountProviderClass;
+ });
+ return $this->getMountsForFromProviders($user, $providers);
+ }
+
public function addMountForUser(IUser $user, IMountManager $mountManager) {
// shared mount provider gets to go last since it needs to know existing files
// to check for name collisions
diff --git a/lib/public/Files/Config/IMountProviderCollection.php b/lib/public/Files/Config/IMountProviderCollection.php
index f845d72cee6..8a98c614a42 100644
--- a/lib/public/Files/Config/IMountProviderCollection.php
+++ b/lib/public/Files/Config/IMountProviderCollection.php
@@ -39,6 +39,16 @@ interface IMountProviderCollection {
public function getMountsForUser(IUser $user);
/**
+ * Get the configured mount points for the user from a specific mount provider
+ *
+ * @param \OCP\IUser $user
+ * @param class-string<IMountProvider> $mountProviderClass
+ * @return \OCP\Files\Mount\IMountPoint[]
+ * @since 24.0.0
+ */
+ public function getMountsFromProvider(IUser $user, string $mountProviderClass);
+
+ /**
* Get the configured home mount for this user
*
* @param \OCP\IUser $user