summaryrefslogtreecommitdiff
path: root/app/Api/LinkApi.php
diff options
context:
space:
mode:
Diffstat (limited to 'app/Api/LinkApi.php')
-rw-r--r--app/Api/LinkApi.php113
1 files changed, 113 insertions, 0 deletions
diff --git a/app/Api/LinkApi.php b/app/Api/LinkApi.php
new file mode 100644
index 00000000..d8e525e4
--- /dev/null
+++ b/app/Api/LinkApi.php
@@ -0,0 +1,113 @@
+<?php
+
+namespace Kanboard\Api;
+
+use Kanboard\Core\Base;
+
+/**
+ * Link API controller
+ *
+ * @package Kanboard\Api
+ * @author Frederic Guillot
+ */
+class LinkApi extends Base
+{
+ /**
+ * Get a link by id
+ *
+ * @access public
+ * @param integer $link_id Link id
+ * @return array
+ */
+ public function getLinkById($link_id)
+ {
+ return $this->linkModel->getById($link_id);
+ }
+
+ /**
+ * Get a link by name
+ *
+ * @access public
+ * @param string $label
+ * @return array
+ */
+ public function getLinkByLabel($label)
+ {
+ return $this->linkModel->getByLabel($label);
+ }
+
+ /**
+ * Get the opposite link id
+ *
+ * @access public
+ * @param integer $link_id Link id
+ * @return integer
+ */
+ public function getOppositeLinkId($link_id)
+ {
+ return $this->linkModel->getOppositeLinkId($link_id);
+ }
+
+ /**
+ * Get all links
+ *
+ * @access public
+ * @return array
+ */
+ public function getAllLinks()
+ {
+ return $this->linkModel->getAll();
+ }
+
+ /**
+ * Create a new link label
+ *
+ * @access public
+ * @param string $label
+ * @param string $opposite_label
+ * @return boolean|integer
+ */
+ public function createLink($label, $opposite_label = '')
+ {
+ $values = array(
+ 'label' => $label,
+ 'opposite_label' => $opposite_label,
+ );
+
+ list($valid, ) = $this->linkValidator->validateCreation($values);
+ return $valid ? $this->linkModel->create($label, $opposite_label) : false;
+ }
+
+ /**
+ * Update a link
+ *
+ * @access public
+ * @param integer $link_id
+ * @param integer $opposite_link_id
+ * @param string $label
+ * @return boolean
+ */
+ public function updateLink($link_id, $opposite_link_id, $label)
+ {
+ $values = array(
+ 'id' => $link_id,
+ 'opposite_id' => $opposite_link_id,
+ 'label' => $label,
+ );
+
+ list($valid, ) = $this->linkValidator->validateModification($values);
+ return $valid && $this->linkModel->update($values);
+ }
+
+ /**
+ * Remove a link a the relation to its opposite
+ *
+ * @access public
+ * @param integer $link_id
+ * @return boolean
+ */
+ public function removeLink($link_id)
+ {
+ return $this->linkModel->remove($link_id);
+ }
+}