X-Git-Url: https://git.cweiske.de/grauphel.git/blobdiff_plain/cd37bde4ef0747a11c1221e937027fe17f2894fe..6c8ad60e9888fa5625dad2460ca073f93ac1ae0d:/controller/guicontroller.php diff --git a/controller/guicontroller.php b/controller/guicontroller.php index b92d374..6f0a15c 100644 --- a/controller/guicontroller.php +++ b/controller/guicontroller.php @@ -15,6 +15,8 @@ namespace OCA\Grauphel\Controller; use \OCP\AppFramework\Controller; use \OCP\AppFramework\Http\TemplateResponse; +use \OCA\Grauphel\Lib\Client; +use \OCA\Grauphel\Lib\TokenStorage; /** * Owncloud frontend @@ -70,14 +72,123 @@ class GuiController extends Controller return $res; } - protected function addNavigation(TemplateResponse $res) + /** + * Show all notes of a tag + * + * @NoAdminRequired + * @NoCSRFRequired + */ + public function tag($rawtag) + { + $notes = $this->getNotes()->loadNotesOverview(null, $rawtag); + + $res = new TemplateResponse('grauphel', 'tag'); + $res->setParams( + array( + 'tag' => $this->getPrettyTagName($rawtag), + 'rawtag' => $rawtag, + 'notes' => $notes, + ) + ); + $this->addNavigation($res, $rawtag); + + return $res; + } + + /** + * Show access tokens + * + * @NoAdminRequired + * @NoCSRFRequired + */ + public function tokens() + { + $tokens = new TokenStorage(); + $res = new TemplateResponse('grauphel', 'tokens'); + $res->setParams( + array( + 'tokens' => $tokens->loadForUser( + $this->user->getUid(), 'access' + ), + 'client' => new Client(), + 'username' => $this->user->getUid(), + ) + ); + $this->addNavigation($res, null); + + return $res; + } + + /** + * Allow the user to clear his database + * + * @NoAdminRequired + * @NoCSRFRequired + */ + public function database($reset = null) + { + $res = new TemplateResponse('grauphel', 'gui-database'); + $res->setParams(array('reset' => $reset)); + $this->addNavigation($res, null); + $this->addStats($res); + + return $res; + } + + /** + * Resets the database by deleting all notes and deleting the user's + * sync data. + * + * @NoAdminRequired + */ + public function databaseReset() + { + $reset = false; + if ($_POST['username'] != '' && $_POST['username'] == $this->user->getUid()) { + $notes = $this->getNotes(); + $notes->deleteAll(); + $notes->deleteSyncData(); + $reset = true; + } + + return $this->database($reset); + } + + protected function addNavigation(TemplateResponse $res, $selectedRawtag = null) { $nav = new \OCP\Template('grauphel', 'appnavigation', ''); $nav->assign('apiroot', $this->getApiRootUrl()); + $nav->assign('tags', array()); $params = $res->getParams(); $params['appNavigation'] = $nav; $res->setParams($params); + + if ($this->user === null) { + return; + } + + $rawtags = $this->getNotes()->getTags(); + sort($rawtags); + array_unshift( + $rawtags, + 'grauphel:special:all', 'grauphel:special:untagged' + ); + + $tags = array(); + foreach ($rawtags as $rawtag) { + $name = $this->getPrettyTagName($rawtag); + if ($name !== false) { + $tags[] = array( + 'name' => $name, + 'id' => $rawtag, + 'href' => $this->urlGen->linkToRoute( + 'grauphel.gui.tag', array('rawtag' => $rawtag) + ), + ); + } + } + $nav->assign('tags', $tags); } protected function addStats(TemplateResponse $res) @@ -87,8 +198,7 @@ class GuiController extends Controller } $username = $this->user->getUid(); - $notes = new \OCA\Grauphel\Lib\NoteStorage($this->urlGen); - $notes->setUsername($username); + $notes = $this->getNotes(); $tokens = new \OCA\Grauphel\Lib\TokenStorage(); $nav = new \OCP\Template('grauphel', 'indexStats', ''); @@ -118,5 +228,23 @@ class GuiController extends Controller '/' ); } + + protected function getNotes() + { + $username = $this->user->getUid(); + $notes = new \OCA\Grauphel\Lib\NoteStorage($this->urlGen); + $notes->setUsername($username); + return $notes; + } + + protected function getPrettyTagName($rawtag) + { + if (substr($rawtag, 0, 16) == 'system:notebook:') { + return substr($rawtag, 16); + } else if (substr($rawtag, 0, 17) == 'grauphel:special:') { + return '*' . substr($rawtag, 17) . '*'; + } + return false; + } } ?>