wallabag.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <?php
  2. /**
  3. * Plugin Wallabag.
  4. */
  5. require_once 'WallabagInstance.php';
  6. /**
  7. * Init function, return an error if the server is not set.
  8. *
  9. * @param $conf ConfigManager instance.
  10. *
  11. * @return array Eventual error.
  12. */
  13. function wallabag_init($conf)
  14. {
  15. $wallabagUrl = $conf->get('plugins.WALLABAG_URL');
  16. if (empty($wallabagUrl)) {
  17. $error = 'Wallabag plugin error: '.
  18. 'Please define the "WALLABAG_URL" setting in the plugin administration page.';
  19. return array($error);
  20. }
  21. }
  22. /**
  23. * Add wallabag icon to link_plugin when rendering linklist.
  24. *
  25. * @param mixed $data Linklist data.
  26. * @param ConfigManager $conf Configuration Manager instance.
  27. *
  28. * @return mixed - linklist data with wallabag plugin.
  29. */
  30. function hook_wallabag_render_linklist($data, $conf)
  31. {
  32. $wallabagUrl = $conf->get('plugins.WALLABAG_URL');
  33. if (empty($wallabagUrl)) {
  34. return $data;
  35. }
  36. $version = $conf->get('plugins.WALLABAG_VERSION');
  37. $wallabagInstance = new WallabagInstance($wallabagUrl, $version);
  38. $wallabagHtml = file_get_contents(PluginManager::$PLUGINS_PATH . '/wallabag/wallabag.html');
  39. foreach ($data['links'] as &$value) {
  40. $wallabag = sprintf(
  41. $wallabagHtml,
  42. $wallabagInstance->getWallabagUrl(),
  43. urlencode($value['url']),
  44. PluginManager::$PLUGINS_PATH
  45. );
  46. $value['link_plugin'][] = $wallabag;
  47. }
  48. return $data;
  49. }