aboutsummaryrefslogtreecommitdiffstats
path: root/lib/public
diff options
context:
space:
mode:
authorJulius Härtl <jus@bitgrid.net>2020-05-27 09:07:17 +0200
committerJulius Härtl <jus@bitgrid.net>2020-07-15 09:24:50 +0200
commit673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9 (patch)
tree052e49a443b04c57b9e19d89000507e01466b275 /lib/public
parentb327b4fbe6d732cca06bb200921439ac1eba3f15 (diff)
downloadnextcloud-server-673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9.tar.gz
nextcloud-server-673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9.zip
Add new dashboard public API
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'lib/public')
-rw-r--r--lib/public/Dashboard/IManager.php46
-rw-r--r--lib/public/Dashboard/IPanel.php69
-rw-r--r--lib/public/Dashboard/IRegisterPanelEvent.php50
3 files changed, 165 insertions, 0 deletions
diff --git a/lib/public/Dashboard/IManager.php b/lib/public/Dashboard/IManager.php
new file mode 100644
index 00000000000..a5185ae22a7
--- /dev/null
+++ b/lib/public/Dashboard/IManager.php
@@ -0,0 +1,46 @@
+<?php
+/**
+ * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net>
+ *
+ * @author Julius Härtl <jus@bitgrid.net>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCP\Dashboard;
+
+/**
+ * Interface IManager
+ *
+ * @package OCP\Dashboard
+ * @since 20.0.0
+ */
+interface IManager {
+
+ /**
+ * @param IPanel $panel
+ * @since 20.0.0
+ */
+ public function registerPanel(IPanel $panel): void;
+
+ /**
+ * @since 20.0.0
+ *
+ * @return IPanel[]
+ */
+ public function getPanels(): array;
+}
diff --git a/lib/public/Dashboard/IPanel.php b/lib/public/Dashboard/IPanel.php
new file mode 100644
index 00000000000..1b0e3c11d1a
--- /dev/null
+++ b/lib/public/Dashboard/IPanel.php
@@ -0,0 +1,69 @@
+<?php
+/**
+ * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net>
+ *
+ * @author Julius Härtl <jus@bitgrid.net>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCP\Dashboard;
+
+/**
+ * Interface IPanel
+ *
+ * @package OCP\Dashboard
+ * @since 20.0.0
+ */
+interface IPanel {
+
+ /**
+ * @return string
+ * @since 20.0.0
+ */
+ public function getId(): string;
+
+ /**
+ * @return string
+ * @since 20.0.0
+ */
+ public function getTitle(): string;
+
+ /**
+ * @return int
+ * @since 20.0.0
+ */
+ public function getOrder(): int;
+
+ /**
+ * @return string
+ * @since 20.0.0
+ */
+ public function getIconClass(): string;
+
+ /**
+ * @return string The absolute path to an icon in SVG
+ * @since 20.0.0
+ */
+ public function getIconUrl(): string;
+
+ /**
+ * @return string The absolute url to the apps own view
+ * @since 20.0.0
+ */
+ public function getUrl(): string;
+}
diff --git a/lib/public/Dashboard/IRegisterPanelEvent.php b/lib/public/Dashboard/IRegisterPanelEvent.php
new file mode 100644
index 00000000000..f322d87d82d
--- /dev/null
+++ b/lib/public/Dashboard/IRegisterPanelEvent.php
@@ -0,0 +1,50 @@
+<?php
+/**
+ * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net>
+ *
+ * @author Julius Härtl <jus@bitgrid.net>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCP\Dashboard;
+
+use OCP\EventDispatcher\Event;
+
+/**
+ * Class IRegisterPanelEvent
+ *
+ * @package OCP\Dashboard
+ * @since 20.0.0
+ */
+class IRegisterPanelEvent extends Event {
+ private $manager;
+
+ public function __construct(IManager $manager) {
+ parent::__construct();
+
+ $this->manager = $manager;
+ }
+
+ /**
+ * @param IPanel $panel
+ * @since 20.0.0
+ */
+ public function registerPanel(IPanel $panel) {
+ $this->manager->registerPanel($panel);
+ }
+}