aboutsummaryrefslogtreecommitdiff
path: root/lib/classes/StudipItem.php
diff options
context:
space:
mode:
authorPhilipp Schüttlöffel <schuettloeffel@zqs.uni-hannover.de>2024-09-24 10:53:31 +0200
committerPhilipp Schüttlöffel <schuettloeffel@zqs.uni-hannover.de>2024-09-24 10:53:31 +0200
commit4459dd7917f4d1c34f40bb68f0e991e9c3d53e4c (patch)
tree5c07151ae61276d334e88f6309c30d439a85c12e /lib/classes/StudipItem.php
parentda0022e5c1abbf9825ae76debaabdff7e8623bb4 (diff)
parent97a188592c679890a25c37ab78463add76a52ff7 (diff)
Merge branch 'main' into issue-3911issue-3911
Diffstat (limited to 'lib/classes/StudipItem.php')
-rw-r--r--lib/classes/StudipItem.php72
1 files changed, 72 insertions, 0 deletions
diff --git a/lib/classes/StudipItem.php b/lib/classes/StudipItem.php
new file mode 100644
index 0000000..b575bdc
--- /dev/null
+++ b/lib/classes/StudipItem.php
@@ -0,0 +1,72 @@
+<?php
+
+/**
+ * StudipItem.interface.php - contains the StudipItem interface.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * @author Moritz Strohm <strohm@data-quest.de>
+ * @copyright 2018-2019
+ * @license http://www.gnu.org/licenses/gpl-2.0.html GPL version 2
+ * @category Stud.IP
+ * @since 4.5
+ */
+
+
+/**
+ * This interface provides methods which allow an unified access
+ * to basic properties of Stud.IP objects.
+ * It is meant to be an extension for SimpleORMap objects.
+ */
+interface StudipItem
+{
+ /**
+ * Returns a human-readable name of the object.
+ *
+ * @param bool $long_format If set to true, a long format
+ * that has the object type as a prefix (course, room etc.)
+ * is returned. Otherwise only the name is returned.
+ *
+ * @returns string A human-readable string of the object's name.
+ */
+ public function getItemName($long_format = true);
+
+ /**
+ * Returns an URL that points to a page describing or displaying
+ * the object.
+ *
+ * @returns string|null Either the URL to a descriptive page for
+ * the object or null, if the object does not have such an URL.
+ */
+ public function getItemURL();
+
+ /**
+ * Returns the URL to the avatar image or icon of the object,
+ * if applicable.
+ *
+ * @returns string|null Either the URL to the object's avatar
+ * or icon or null, if the object does not have an avatar.
+ */
+ public function getItemAvatarURL();
+
+
+ /**
+ * Creates a StudipLink object that links to a page with information
+ * about the StudipItem object.
+ *
+ * @returns StudipLink A StudipLink object for the information page
+ * of the StudipItem object.
+ */
+ public function getLink() : StudipLink;
+
+
+ /**
+ * @return string A string representation of the item.
+ * For backward compatibility with existing plugins that have classes
+ * derived of StudipItem, the return type is not specified.
+ */
+ public function __toString();
+}