diff options
author | Julius Härtl <jus@bitgrid.net> | 2017-06-30 11:08:04 +0200 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2017-06-30 11:08:04 +0200 |
commit | 51a0741005bc815a547d3cbbd9317dc317f03952 (patch) | |
tree | b18d864379b997dd0b2313f75dcd9c58edb26d6b /lib/private/CapabilitiesManager.php | |
parent | 2afb4857cca4ca5eb48af63ab814727cfe77b1bd (diff) | |
download | nextcloud-server-51a0741005bc815a547d3cbbd9317dc317f03952.tar.gz nextcloud-server-51a0741005bc815a547d3cbbd9317dc317f03952.zip |
Add public capabilities API
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'lib/private/CapabilitiesManager.php')
-rw-r--r-- | lib/private/CapabilitiesManager.php | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/private/CapabilitiesManager.php b/lib/private/CapabilitiesManager.php index 159fa97c708..173760fe20f 100644 --- a/lib/private/CapabilitiesManager.php +++ b/lib/private/CapabilitiesManager.php @@ -24,6 +24,7 @@ namespace OC; use OCP\AppFramework\QueryException; use OCP\Capabilities\ICapability; +use OCP\Capabilities\IPublicCapability; use OCP\ILogger; class CapabilitiesManager { @@ -41,10 +42,11 @@ class CapabilitiesManager { /** * Get an array of al the capabilities that are registered at this manager * + * @param bool $public get public capabilities only * @throws \InvalidArgumentException * @return array */ - public function getCapabilities() { + public function getCapabilities($public = false) { $capabilities = []; foreach($this->capabilities as $capability) { try { @@ -55,7 +57,9 @@ class CapabilitiesManager { } if ($c instanceof ICapability) { - $capabilities = array_replace_recursive($capabilities, $c->getCapabilities()); + if(!$public || ($public && $c instanceof IPublicCapability)) { + $capabilities = array_replace_recursive($capabilities, $c->getCapabilities()); + } } else { throw new \InvalidArgumentException('The given Capability (' . get_class($c) . ') does not implement the ICapability interface'); } |