action.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. <?php
  2. global $_,$conf;
  3. switch($_['action']){
  4. /** COMMON **/
  5. case 'wiki_logo_download':
  6. global $myUser;
  7. if(!$myUser->connected()) throw new Exception("Permission denied");
  8. $logoDir = File::dir().'wiki'.SLASH.'logo';
  9. $logo = $logoDir.SLASH.'logo.png';
  10. if(!file_exists($logoDir)) mkdir($logoDir,0755,true);
  11. if(!file_exists($logo)) copy(__DIR__.SLASH.'img'.SLASH.'logo.png', $logo);
  12. File::downloadFile($logo);
  13. break;
  14. case 'wiki_logo_delete':
  15. Action::write(function(&$response){
  16. global $myUser,$_;
  17. User::check_access('wiki','configure');
  18. foreach (glob(File::dir().'wiki'.SLASH."logo".SLASH."logo.*") as $filename)
  19. unlink($filename);
  20. Log::put("Suppression du logo",'Wiki');
  21. });
  22. break;
  23. /** HOME **/
  24. case 'wiki_page_home':
  25. Action::write(function(&$response){
  26. global $myUser,$_;
  27. User::check_access('wiki','read');
  28. ob_start();
  29. require_once(__DIR__.SLASH.'page.home.php');
  30. $response['content'] = ob_get_clean();
  31. });
  32. break;
  33. case 'wiki_page_search':
  34. Action::write(function(&$response){
  35. global $myUser,$_;
  36. User::check_access('wiki','read');
  37. Log::put("Recherche lancée avec les mots clés : ".$_['term'],'Wiki');
  38. ob_start();
  39. require_once(__DIR__.SLASH.'page.search.php');
  40. $response['content'] = ob_get_clean();
  41. });
  42. break;
  43. case 'wiki_page_download':
  44. User::check_access('wiki','read');
  45. require_once(__DIR__.SLASH.'WikiPage.class.php');
  46. $workspace = WikiPage::workspace();
  47. $page = WikiPage::getById($_['page']);
  48. Log::put("Téléchargement de la page ".$workspace.SLASH.$page->path,'Wiki');
  49. File::downloadFile($workspace.SLASH.wiki_os_encode($page->path),null,null,true);
  50. break;
  51. /** CATEGORY **/
  52. //Récuperation d'une liste de page
  53. case 'wiki_category_search':
  54. Action::write(function(&$response){
  55. global $myUser,$_;
  56. User::check_access('wiki','read');
  57. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  58. require_once(__DIR__.SLASH.'WikiPage.class.php');
  59. $workspace = WikiPage::workspace();
  60. if(!file_exists($workspace)) mkdir($workspace,0755,true);
  61. foreach(WikiCategory::loadAll(array(), array('sort','label')) as $category){
  62. $response['rows'][] = $category;
  63. }
  64. });
  65. break;
  66. case 'wiki_category_edit':
  67. User::check_access('wiki','read');
  68. require_once(__DIR__.SLASH.'modal.category.php');
  69. break;
  70. case 'wiki_category_open':
  71. Action::write(function(&$response){
  72. global $myUser,$_;
  73. User::check_access('wiki','read');
  74. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  75. require_once(__DIR__.SLASH.'WikiPage.class.php');
  76. $category = WikiCategory::load(array('slug'=>$_['category']));
  77. $pages = $category->pages();
  78. $recents = WikiPage::loadAll(array('category'=>$category->id),array('updated DESC'),array('10'), array('*'), 1);
  79. ob_start();
  80. require_once(__DIR__.SLASH.'page.category.php');
  81. $response['content'] = ob_get_clean();
  82. $response['categorySlug'] = $category->slug;
  83. $response['pages'] = $pages;
  84. Log::put("Consultation de la catégorie ".$category->toText(),'Wiki');
  85. });
  86. break;
  87. case 'wiki_category_download':
  88. try{
  89. User::check_access('wiki','read');
  90. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  91. require_once(__DIR__.SLASH.'WikiPage.class.php');
  92. $workspace = WikiPage::workspace();
  93. $category = WikiCategory::getById($_['category']);
  94. $path = $workspace.SLASH.wiki_os_encode($category->path);
  95. $zipName = tempnam(sys_get_temp_dir(), "zip123");
  96. if (!extension_loaded('zip')) throw new Exception("L'extension ZIP est manquante");
  97. $zip = new ZipArchive();
  98. if (!$zip->open($zipName, ZIPARCHIVE::CREATE))
  99. throw new Exception ("Impossible de créer l'archive (problèmes de permissions ?");
  100. foreach(glob($path.SLASH.'*.md') as $file){
  101. $zip->addFromString(basename($file), file_get_contents($file));
  102. }
  103. $zip->close();
  104. $stream = file_get_contents($zipName);
  105. Log::put("Téléchargement de la catégorie ".$workspace.SLASH.$category->path,'Wiki');
  106. unlink($zipName);
  107. File::downloadStream($stream,$category->slug.'.zip');
  108. }catch(Exception $e){
  109. echo 'Erreur : '.$e->getMessage();
  110. }
  111. break;
  112. //Ajout ou modification d'élément page
  113. case 'wiki_category_save':
  114. Action::write(function(&$response){
  115. global $myUser,$_;
  116. User::check_access('wiki','edit');
  117. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  118. require_once(__DIR__.SLASH.'WikiPage.class.php');
  119. $workspace = WikiPage::workspace();
  120. $item = isset($_['id']) && is_numeric($_['id']) ? WikiCategory::getById($_['id']) : new WikiCategory();
  121. $item->icon = $_['icon'];
  122. $item->color = $_['color'];
  123. if($item->id==0){
  124. $item->label = $_['label'];
  125. $item->slug = slugify($item->label);
  126. $item->path = WikiPage::path_from_label($item->label);
  127. $dir = $workspace.SLASH.wiki_os_encode($item->path);
  128. if(!file_exists($dir)) mkdir($dir,0755,true);
  129. }else{
  130. if($item->label!=$_['label']){
  131. $oldDir = $workspace.SLASH.wiki_os_encode($item->path);
  132. $item->label = $_['label'] ;
  133. $item->slug = slugify($item->label);
  134. $item->path = WikiPage::path_from_label($item->label);
  135. $newDir = $workspace.SLASH.wiki_os_encode($item->path);
  136. if(file_exists($newDir)) throw new Exception("Ce nom de catégorie est déja pris");
  137. rename($oldDir, $newDir);
  138. }
  139. }
  140. $item->save();
  141. $response = $item->toArray();
  142. Log::put("Création/Modification de catégorie :".$item->toText(),'Wiki');
  143. });
  144. break;
  145. //Suppression d'élement page
  146. case 'wiki_category_delete':
  147. Action::write(function(&$response){
  148. global $myUser,$_;
  149. User::check_access('wiki','delete');
  150. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  151. require_once(__DIR__.SLASH.'WikiPage.class.php');
  152. $category = WikiCategory::getById($_['id']);
  153. WikiPage::delete(array('category'=>$_['id']));
  154. WikiCategory::deleteById($_['id']);
  155. Log::put("Suppression de catégorie :".$category->toText(),'Wiki');
  156. });
  157. break;
  158. /** PAGE **/
  159. case 'wiki_page_move':
  160. Action::write(function(&$response){
  161. global $myUser,$_;
  162. User::check_access('wiki','edit');
  163. if(empty($_['category'])) throw new Exception("catégorie non spécifiée", 400);
  164. require_once(__DIR__.SLASH.'WikiPage.class.php');
  165. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  166. $page = WikiPage::provide('page');
  167. $category = WikiCategory::getById($_['category']);
  168. $page->category = $category->id;
  169. $oldPath = $page->path;
  170. $page->path = $category->path.SLASH.WikiPage::path_from_label($page->label).'.md';
  171. $oldPath = WikiPage::workspace().SLASH.wiki_os_encode($oldPath);
  172. $newPath = WikiPage::workspace().SLASH.wiki_os_encode($page->path);
  173. if(file_exists($newPath)) throw new Exception("Ce nom de page pour cette catégorie est déja pris");
  174. if(!file_exists($oldPath)) throw new Exception("Impossible de retrouver l'ancien chemin de la page");
  175. rename($oldPath, $newPath);
  176. $page->save();
  177. });
  178. break;
  179. //tri des pages
  180. case 'wiki_page_sort':
  181. Action::write(function(&$response){
  182. global $myUser,$_;
  183. User::check_access('wiki','edit');
  184. if(empty($_['sort'])) throw new Exception("tri non spécifiée", 400);
  185. require_once(__DIR__.SLASH.'WikiPage.class.php');
  186. foreach ($_['sort'] as $sort => $id) {
  187. $page = WikiPage::getById($id);
  188. $page->sort = $sort;
  189. $page->save();
  190. }
  191. });
  192. break;
  193. //tri des categories
  194. case 'wiki_category_sort':
  195. Action::write(function(&$response){
  196. global $myUser,$_;
  197. User::check_access('wiki','edit');
  198. if(empty($_['sort'])) throw new Exception("tri non spécifiée", 400);
  199. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  200. foreach ($_['sort'] as $sort => $id) {
  201. $page = WikiCategory::getById($id);
  202. $page->sort = $sort;
  203. $page->save();
  204. }
  205. });
  206. break;
  207. //Ajout ou modification d'élément page
  208. case 'wiki_page_save':
  209. Action::write(function(&$response){
  210. global $myUser,$_;
  211. User::check_access('wiki','edit');
  212. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  213. require_once(__DIR__.SLASH.'WikiPage.class.php');
  214. $page = WikiPage::provide();
  215. $page->content = html_entity_decode($_['content']);
  216. if($page->id == 0 && isset($_['category'])){
  217. $category = WikiCategory::getById($_['category']);
  218. $page->state = WikiPage::PUBLISHED;
  219. $page->category = $category->id;
  220. $page->label = 'Nouvelle page - '.date('d/m/y h:i:s');
  221. $page->path = $category->path.SLASH.WikiPage::path_from_label($page->label).'.md';
  222. $page->content = WikiPage::defaultContent();
  223. $page->slug = slugify($page->label);
  224. } else {
  225. $category = WikiCategory::getById($page->category);
  226. if(!isset($_['label']) || empty($_['label'])) throw new Exception("Le nom de la page ne peut être vide");
  227. if($page->label != $_['label']){
  228. $oldPath = WikiPage::workspace().SLASH.wiki_os_encode($page->path);
  229. $page->label = $_['label'];
  230. $page->path = $category->path.SLASH.WikiPage::path_from_label($page->label).'.md';
  231. $page->slug = slugify($page->label);
  232. $newPath = WikiPage::workspace().SLASH.wiki_os_encode($page->path);
  233. if(file_exists($newPath)) throw new Exception("Ce nom de page pour cette catégorie est déja pris");
  234. unlink($oldPath);
  235. }
  236. }
  237. if(isset($page->content)) file_put_contents(WikiPage::workspace().SLASH.wiki_os_encode($page->path),$page->content);
  238. $page->save();
  239. ob_start();
  240. require_once(__DIR__.SLASH.'page.page.php');
  241. $response['content'] = ob_get_clean();
  242. $response['page'] = $page->toArray();
  243. $response['category'] = $category->toArray();
  244. Log::put("Création/Modification de page :".$page->toText(),'Wiki');
  245. });
  246. break;
  247. //Suppression d'élement page
  248. case 'wiki_page_delete':
  249. Action::write(function(&$response){
  250. global $myUser,$_;
  251. User::check_access('wiki','delete');
  252. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  253. $page = WikiPage::getById($_['id']);
  254. $category = WikiCategory::getById($page->category);
  255. $response['category'] = $category->toArray();
  256. WikiPage::deleteById($page->id);
  257. $path = WikiPage::workspace().SLASH.wiki_os_encode($page->path);
  258. if(file_exists($path)) unlink($path);
  259. Log::put("Suppression de page :".$page->toText(),'Wiki');
  260. });
  261. break;
  262. case 'wiki_page_open':
  263. Action::write(function(&$response){
  264. global $myUser,$_;
  265. User::check_access('wiki','read');
  266. require_once(__DIR__.SLASH.'WikiCategory.class.php');
  267. require_once(__DIR__.SLASH.'WikiPage.class.php');
  268. $page = WikiPage::load(array('slug'=>$_['page']));
  269. if(!$page){
  270. $page = new WikiPage();
  271. $page->label = $_['page'];
  272. }
  273. $category = WikiCategory::load(array('slug'=>$_['category']));
  274. ob_start();
  275. require_once(__DIR__.SLASH.'page.page.php');
  276. $response['content'] = ob_get_clean();
  277. $response['categorySlug'] = $category->slug;
  278. if($page->id!=0) $response['pageSlug'] = $page->slug;
  279. Log::put("Consultation de page :".$page->toText(),'Wiki');
  280. });
  281. break;
  282. //Sauvegarde des configurations de wiki
  283. case 'wiki_setting_save':
  284. Action::write(function(&$response){
  285. global $myUser,$_,$conf;
  286. User::check_access('wiki','configure');
  287. foreach(Configuration::setting('wiki') as $key=>$value){
  288. if(!is_array($value)) continue;
  289. $allowed[] = $key;
  290. }
  291. if(!empty($_['fields']['wiki_default_content'])){
  292. $defaultFile = File::dir().'wiki'.SLASH.'default.md';
  293. file_put_contents($defaultFile, $_['fields']['wiki_default_content']);
  294. unset($_['fields']['wiki_default_content']);
  295. }
  296. foreach ($_['fields'] as $key => $value)
  297. if(in_array($key, $allowed)) $conf->put($key,$value);
  298. if(!empty($_FILES['logo']) && $_FILES['logo']['size']!=0 ){
  299. $logo = File::upload('logo','wiki'.SLASH.'logo'.SLASH.'logo.{{ext}}', 1048576, array('jpg','png','jpeg'));
  300. Image::resize($logo['absolute'], 38, 38, false);
  301. Image::toPng($logo['absolute']);
  302. }
  303. Log::put("Enregistrement des réglages : ".implode(', ', $_['fields']),'Wiki');
  304. });
  305. break;
  306. case 'wiki_file_upload':
  307. Action::write(function(&$response){
  308. global $myUser,$_,$conf;
  309. User::check_access('wiki','edit');
  310. if(!isset($_FILES['file']) || empty($_FILES)) return;
  311. require_once(__DIR__.SLASH.'WikiPage.class.php');
  312. $uploads = WikiPage::uploads().SLASH;
  313. if(!file_exists($uploads)) mkdir($uploads,0755,true);
  314. $maxSize = $conf->get('wiki_max_size') * 1048576;
  315. $extensions = explode(',',str_replace(' ', '', $conf->get('wiki_ext')));
  316. $response['rows'] = array();
  317. if(!is_array($_FILES['file']['name'])){
  318. $_FILES['file']['name'] = array($_FILES['file']['name']);
  319. $_FILES['file']['size'] = array($_FILES['file']['size']);
  320. $_FILES['file']['tmp_name'] = array($_FILES['file']['tmp_name']);
  321. }
  322. for ($i=0; $i<count($_FILES['file']['name']); $i++) {
  323. $extension = getExt($_FILES['file']['name'][$i]);
  324. if($_FILES['file']['size'][$i] > $maxSize) throw new Exception("Taille du fichier ".$_FILES['file']['name'][$i]." trop grande, taille maximum :".readable_size($maxSize).' ('.$maxSize.' octets)');
  325. if(!in_array($extension , $extensions)) throw new Exception("Extension '".$extension."' du fichier ".$_FILES['file']['name'][$i]." non permise, autorisé :".implode(', ',$extensions));
  326. $filePath = $uploads.wiki_os_encode($_FILES['file']['name'][$i]);
  327. $u = 0;
  328. while(file_exists($filePath)){
  329. $u++;
  330. $filePath = $uploads.$u.'_'.wiki_os_encode($_FILES['file']['name'][$i]);
  331. }
  332. $row = array(
  333. 'name'=>$_FILES['file']['name'][$i],
  334. 'relative'=>str_replace($uploads,'',$filePath),
  335. 'absolute'=>$filePath,
  336. );
  337. switch($extension){
  338. case 'jpg':
  339. case 'jpeg':
  340. case 'gif':
  341. case 'png':
  342. $row['tag'] = '!['.$row['name'].'](action.php?action=wiki_file_read&file='.base64_encode($row['relative']).')';
  343. rename($_FILES['file']['tmp_name'][$i],$filePath);
  344. break;
  345. case 'md':
  346. $row['tag'] = file_get_contents($_FILES['file']['tmp_name'][$i]);
  347. break;
  348. default:
  349. $row['tag'] = '['.$row['name'].'](action.php?action=wiki_file_read&file='.base64_encode($row['relative']).')';
  350. rename($_FILES['file']['tmp_name'][$i],$filePath);
  351. break;
  352. }
  353. $response['rows'][] = $row;
  354. Log::put("Upload d'un élément : ".$filePath,'Wiki');
  355. }
  356. });
  357. break;
  358. case 'wiki_file_read':
  359. global $myUser,$_,$conf;
  360. User::check_access('wiki','read');
  361. File::downloadFile('file/wiki/uploads/'.base64_decode($_['file']));
  362. break;
  363. case 'wiki_night_mode':
  364. Action::write(function(&$response){
  365. global $myUser,$_,$conf;
  366. if(!$myUser->connected()) throw new Exception("Vous devez être connecté", 401);
  367. $myUser->preference('wiki_night_mode', isset($_['nightmode']) && !empty($_['nightmode'])?true:false);
  368. $myUser->loadPreferences();
  369. });
  370. break;
  371. }
  372. ?>