1b36f8833SAndreas Gohr<?php 2d6d97f60SAnna Dabrowska 3b36f8833SAndreas Gohr/** 4b36f8833SAndreas Gohr * DokuWiki Plugin struct (Helper Component) 5b36f8833SAndreas Gohr * 6b36f8833SAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 7b36f8833SAndreas Gohr * @author Andreas Gohr, Michael Große <dokuwiki@cosmocode.de> 8b36f8833SAndreas Gohr */ 9b36f8833SAndreas Gohr 10b36f8833SAndreas Gohr// must be run within Dokuwiki 11935a9fa3SMichael Großeuse dokuwiki\plugin\struct\meta\ConfigParser; 12935a9fa3SMichael Großeuse dokuwiki\plugin\struct\meta\SearchConfig; 13ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\StructException; 14b36f8833SAndreas Gohr 15d6d97f60SAnna Dabrowskaclass remote_plugin_struct extends DokuWiki_Remote_Plugin 16d6d97f60SAnna Dabrowska{ 17b36f8833SAndreas Gohr /** @var helper_plugin_struct hlp */ 18b36f8833SAndreas Gohr protected $hlp; 19b36f8833SAndreas Gohr 20b36f8833SAndreas Gohr /** 21b36f8833SAndreas Gohr * remote_plugin_struct constructor. 22b36f8833SAndreas Gohr */ 23d6d97f60SAnna Dabrowska public function __construct() 24d6d97f60SAnna Dabrowska { 25b36f8833SAndreas Gohr parent::__construct(); 26b36f8833SAndreas Gohr 27b36f8833SAndreas Gohr /** @var helper_plugin_struct hlp */ 28b36f8833SAndreas Gohr $this->hlp = plugin_load('helper', 'struct'); 29b36f8833SAndreas Gohr } 30b36f8833SAndreas Gohr 31b36f8833SAndreas Gohr /** 32b36f8833SAndreas Gohr * Get the structured data of a given page 33b36f8833SAndreas Gohr * 34b36f8833SAndreas Gohr * @param string $page The page to get data for 35b36f8833SAndreas Gohr * @param string $schema The schema to use empty for all 36b36f8833SAndreas Gohr * @param int $time A timestamp if you want historic data (0 for now) 37b36f8833SAndreas Gohr * @return array ('schema' => ( 'fieldlabel' => 'value', ...)) 38b36f8833SAndreas Gohr * @throws RemoteAccessDeniedException 39b36f8833SAndreas Gohr * @throws RemoteException 40b36f8833SAndreas Gohr */ 41d6d97f60SAnna Dabrowska public function getData($page, $schema, $time) 42d6d97f60SAnna Dabrowska { 43b36f8833SAndreas Gohr $page = cleanID($page); 44b36f8833SAndreas Gohr 4599d15ae8SEnno Lohmeier if (auth_quickaclcheck($page) < AUTH_READ) { 46b36f8833SAndreas Gohr throw new RemoteAccessDeniedException('no permissions to access data of that page'); 47b36f8833SAndreas Gohr } 48b36f8833SAndreas Gohr 49b36f8833SAndreas Gohr if (!$schema) $schema = null; 50b36f8833SAndreas Gohr 51b36f8833SAndreas Gohr try { 52b36f8833SAndreas Gohr return $this->hlp->getData($page, $schema, $time); 53b36f8833SAndreas Gohr } catch (StructException $e) { 54b36f8833SAndreas Gohr throw new RemoteException($e->getMessage(), 0, $e); 55b36f8833SAndreas Gohr } 56b36f8833SAndreas Gohr } 57b36f8833SAndreas Gohr 58b36f8833SAndreas Gohr 59b36f8833SAndreas Gohr /** 60b36f8833SAndreas Gohr * Saves data for a given page (creates a new revision) 61b36f8833SAndreas Gohr * 62b36f8833SAndreas Gohr * If this call succeeds you can assume your data has either been saved or it was 63b36f8833SAndreas Gohr * not necessary to save it because the data already existed in the wanted form or 64b36f8833SAndreas Gohr * the given schemas are no longer assigned to that page. 65b36f8833SAndreas Gohr * 66b36f8833SAndreas Gohr * @param string $page 67b36f8833SAndreas Gohr * @param array $data ('schema' => ( 'fieldlabel' => 'value', ...)) 68b36f8833SAndreas Gohr * @param string $summary 69178d3992SElan Ruusamäe * @param bool $minor 70b36f8833SAndreas Gohr * @return bool returns always true 71b36f8833SAndreas Gohr * @throws RemoteAccessDeniedException 72b36f8833SAndreas Gohr * @throws RemoteException 73b36f8833SAndreas Gohr */ 74d6d97f60SAnna Dabrowska public function saveData($page, $data, $summary, $minor = false) 75d6d97f60SAnna Dabrowska { 76b36f8833SAndreas Gohr $page = cleanID($page); 77b36f8833SAndreas Gohr 7899d15ae8SEnno Lohmeier if (auth_quickaclcheck($page) < AUTH_EDIT) { 79b36f8833SAndreas Gohr throw new RemoteAccessDeniedException('no permissions to save data for that page'); 80b36f8833SAndreas Gohr } 81b36f8833SAndreas Gohr 82b36f8833SAndreas Gohr try { 83178d3992SElan Ruusamäe $this->hlp->saveData($page, $data, $summary, $minor); 84b36f8833SAndreas Gohr return true; 85b36f8833SAndreas Gohr } catch (StructException $e) { 86b36f8833SAndreas Gohr throw new RemoteException($e->getMessage(), 0, $e); 87b36f8833SAndreas Gohr } 88b36f8833SAndreas Gohr } 89b36f8833SAndreas Gohr 90b36f8833SAndreas Gohr /** 91b36f8833SAndreas Gohr * Get info about existing schemas columns 92b36f8833SAndreas Gohr * 93b36f8833SAndreas Gohr * Returns only current, enabled columns 94b36f8833SAndreas Gohr * 95b36f8833SAndreas Gohr * @param string $schema the schema to query, empty for all 96b36f8833SAndreas Gohr * @return array 97b36f8833SAndreas Gohr * @throws RemoteAccessDeniedException 98b36f8833SAndreas Gohr * @throws RemoteException 99b36f8833SAndreas Gohr */ 100d6d97f60SAnna Dabrowska public function getSchema($schema = null) 101d6d97f60SAnna Dabrowska { 102b36f8833SAndreas Gohr if (!auth_ismanager()) { 103b36f8833SAndreas Gohr throw new RemoteAccessDeniedException('you need to be manager to access schema info'); 104b36f8833SAndreas Gohr } 105b36f8833SAndreas Gohr 106b36f8833SAndreas Gohr try { 107b36f8833SAndreas Gohr $result = array(); 108*6c9d1a10SAnna Dabrowska $schemas = $this->hlp::getSchema($schema ?: null); 109b36f8833SAndreas Gohr foreach ($schemas as $name => $schema) { 110b36f8833SAndreas Gohr $result[$name] = array(); 111b36f8833SAndreas Gohr foreach ($schema->getColumns(false) as $column) { 112b36f8833SAndreas Gohr $result[$name][] = array( 113b36f8833SAndreas Gohr 'name' => $column->getLabel(), 114b36f8833SAndreas Gohr 'type' => array_pop(explode('\\', get_class($column->getType()))), 115b36f8833SAndreas Gohr 'ismulti' => $column->isMulti() 116b36f8833SAndreas Gohr ); 117b36f8833SAndreas Gohr } 118b36f8833SAndreas Gohr } 119b36f8833SAndreas Gohr return $result; 120b36f8833SAndreas Gohr } catch (StructException $e) { 121b36f8833SAndreas Gohr throw new RemoteException($e->getMessage(), 0, $e); 122b36f8833SAndreas Gohr } 123b36f8833SAndreas Gohr } 124935a9fa3SMichael Große 125935a9fa3SMichael Große /** 126935a9fa3SMichael Große * Get the data that would be shown in an aggregation 127935a9fa3SMichael Große * 128935a9fa3SMichael Große * @param array $schemas array of strings with the schema-names 129935a9fa3SMichael Große * @param array $cols array of strings with the columns 130935a9fa3SMichael Große * @param array $filter array of arrays with ['logic'=> 'and'|'or', 'condition' => 'your condition'] 131935a9fa3SMichael Große * @param string $sort string indicating the column to sort by 132935a9fa3SMichael Große * 133935a9fa3SMichael Große * @return array array of rows, each row is an array of the column values 134935a9fa3SMichael Große * @throws RemoteException 135935a9fa3SMichael Große */ 136d6d97f60SAnna Dabrowska public function getAggregationData(array $schemas, array $cols, array $filter = [], $sort = '') 137d6d97f60SAnna Dabrowska { 138935a9fa3SMichael Große $schemaLine = 'schema: ' . implode(', ', $schemas); 139935a9fa3SMichael Große $columnLine = 'cols: ' . implode(', ', $cols); 140935a9fa3SMichael Große $filterLines = array_map(function ($filter) { 141935a9fa3SMichael Große return 'filter' . $filter['logic'] . ': ' . $filter['condition']; 142935a9fa3SMichael Große }, $filter); 143935a9fa3SMichael Große $sortLine = 'sort: ' . $sort; 144935a9fa3SMichael Große // schemas, cols, REV?, filter, order 145935a9fa3SMichael Große 146935a9fa3SMichael Große try { 147935a9fa3SMichael Große $parser = new ConfigParser(array_merge([$schemaLine, $columnLine, $sortLine], $filterLines)); 148935a9fa3SMichael Große $config = $parser->getConfig(); 149935a9fa3SMichael Große $search = new SearchConfig($config); 150935a9fa3SMichael Große $results = $search->execute(); 151935a9fa3SMichael Große $data = []; 152935a9fa3SMichael Große /** @var \dokuwiki\plugin\struct\meta\Value[] $rowValues */ 153935a9fa3SMichael Große foreach ($results as $rowValues) { 154935a9fa3SMichael Große $row = []; 155935a9fa3SMichael Große foreach ($rowValues as $value) { 156935a9fa3SMichael Große $row[$value->getColumn()->getFullQualifiedLabel()] = $value->getDisplayValue(); 157935a9fa3SMichael Große } 158935a9fa3SMichael Große $data[] = $row; 159935a9fa3SMichael Große } 160935a9fa3SMichael Große return $data; 161935a9fa3SMichael Große } catch (StructException $e) { 162935a9fa3SMichael Große throw new RemoteException($e->getMessage(), 0, $e); 163935a9fa3SMichael Große } 164935a9fa3SMichael Große } 165b36f8833SAndreas Gohr} 166