]>
Commit | Line | Data |
---|---|---|
1 | <?php | |
2 | /** | |
3 | * Shaarli - The personal, minimalist, super-fast, database free, bookmarking service. | |
4 | * | |
5 | * Friendly fork by the Shaarli community: | |
6 | * - https://github.com/shaarli/Shaarli | |
7 | * | |
8 | * Original project by sebsauvage.net: | |
9 | * - http://sebsauvage.net/wiki/doku.php?id=php:shaarli | |
10 | * - https://github.com/sebsauvage/Shaarli | |
11 | * | |
12 | * Licence: http://www.opensource.org/licenses/zlib-license.php | |
13 | */ | |
14 | ||
15 | require_once 'inc/rain.tpl.class.php'; | |
16 | require_once __DIR__ . '/vendor/autoload.php'; | |
17 | ||
18 | // Shaarli library | |
19 | require_once 'application/bookmark/LinkUtils.php'; | |
20 | require_once 'application/config/ConfigPlugin.php'; | |
21 | require_once 'application/http/HttpUtils.php'; | |
22 | require_once 'application/http/UrlUtils.php'; | |
23 | require_once 'application/TimeZone.php'; | |
24 | require_once 'application/Utils.php'; | |
25 | ||
26 | require_once __DIR__ . '/init.php'; | |
27 | ||
28 | use Shaarli\Config\ConfigManager; | |
29 | use Shaarli\Container\ContainerBuilder; | |
30 | use Shaarli\Languages; | |
31 | use Shaarli\Security\CookieManager; | |
32 | use Shaarli\Security\LoginManager; | |
33 | use Shaarli\Security\SessionManager; | |
34 | use Slim\App; | |
35 | ||
36 | $conf = new ConfigManager(); | |
37 | ||
38 | // In dev mode, throw exception on any warning | |
39 | if ($conf->get('dev.debug', false)) { | |
40 | // See all errors (for debugging only) | |
41 | error_reporting(-1); | |
42 | ||
43 | set_error_handler(function ($errno, $errstr, $errfile, $errline, array $errcontext) { | |
44 | throw new ErrorException($errstr, 0, $errno, $errfile, $errline); | |
45 | }); | |
46 | } | |
47 | ||
48 | $sessionManager = new SessionManager($_SESSION, $conf, session_save_path()); | |
49 | $sessionManager->initialize(); | |
50 | $cookieManager = new CookieManager($_COOKIE); | |
51 | $loginManager = new LoginManager($conf, $sessionManager, $cookieManager); | |
52 | $loginManager->generateStaySignedInToken($_SERVER['REMOTE_ADDR']); | |
53 | ||
54 | // Sniff browser language and set date format accordingly. | |
55 | if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { | |
56 | autoLocale($_SERVER['HTTP_ACCEPT_LANGUAGE']); | |
57 | } | |
58 | ||
59 | new Languages(setlocale(LC_MESSAGES, 0), $conf); | |
60 | ||
61 | $conf->setEmpty('general.timezone', date_default_timezone_get()); | |
62 | $conf->setEmpty('general.title', t('Shared bookmarks on '). escape(index_url($_SERVER))); | |
63 | ||
64 | RainTPL::$tpl_dir = $conf->get('resource.raintpl_tpl').'/'.$conf->get('resource.theme').'/'; // template directory | |
65 | RainTPL::$cache_dir = $conf->get('resource.raintpl_tmp'); // cache directory | |
66 | ||
67 | date_default_timezone_set($conf->get('general.timezone', 'UTC')); | |
68 | ||
69 | $loginManager->checkLoginState(client_ip_id($_SERVER)); | |
70 | ||
71 | $containerBuilder = new ContainerBuilder($conf, $sessionManager, $cookieManager, $loginManager); | |
72 | $container = $containerBuilder->build(); | |
73 | $app = new App($container); | |
74 | ||
75 | // Main Shaarli routes | |
76 | $app->group('', function () { | |
77 | $this->get('/install', '\Shaarli\Front\Controller\Visitor\InstallController:index')->setName('displayInstall'); | |
78 | $this->get('/install/session-test', '\Shaarli\Front\Controller\Visitor\InstallController:sessionTest'); | |
79 | $this->post('/install', '\Shaarli\Front\Controller\Visitor\InstallController:save')->setName('saveInstall'); | |
80 | ||
81 | /* -- PUBLIC --*/ | |
82 | $this->get('/', '\Shaarli\Front\Controller\Visitor\BookmarkListController:index'); | |
83 | $this->get('/shaare/{hash}', '\Shaarli\Front\Controller\Visitor\BookmarkListController:permalink'); | |
84 | $this->get('/login', '\Shaarli\Front\Controller\Visitor\LoginController:index')->setName('login'); | |
85 | $this->post('/login', '\Shaarli\Front\Controller\Visitor\LoginController:login')->setName('processLogin'); | |
86 | $this->get('/picture-wall', '\Shaarli\Front\Controller\Visitor\PictureWallController:index'); | |
87 | $this->get('/tags/cloud', '\Shaarli\Front\Controller\Visitor\TagCloudController:cloud'); | |
88 | $this->get('/tags/list', '\Shaarli\Front\Controller\Visitor\TagCloudController:list'); | |
89 | $this->get('/daily', '\Shaarli\Front\Controller\Visitor\DailyController:index'); | |
90 | $this->get('/daily-rss', '\Shaarli\Front\Controller\Visitor\DailyController:rss')->setName('rss'); | |
91 | $this->get('/feed/atom', '\Shaarli\Front\Controller\Visitor\FeedController:atom')->setName('atom'); | |
92 | $this->get('/feed/rss', '\Shaarli\Front\Controller\Visitor\FeedController:rss'); | |
93 | $this->get('/open-search', '\Shaarli\Front\Controller\Visitor\OpenSearchController:index'); | |
94 | ||
95 | $this->get('/add-tag/{newTag}', '\Shaarli\Front\Controller\Visitor\TagController:addTag'); | |
96 | $this->get('/remove-tag/{tag}', '\Shaarli\Front\Controller\Visitor\TagController:removeTag'); | |
97 | $this->get('/links-per-page', '\Shaarli\Front\Controller\Visitor\PublicSessionFilterController:linksPerPage'); | |
98 | $this->get('/untagged-only', '\Shaarli\Front\Controller\Admin\PublicSessionFilterController:untaggedOnly'); | |
99 | })->add('\Shaarli\Front\ShaarliMiddleware'); | |
100 | ||
101 | $app->group('/admin', function () { | |
102 | $this->get('/logout', '\Shaarli\Front\Controller\Admin\LogoutController:index'); | |
103 | $this->get('/tools', '\Shaarli\Front\Controller\Admin\ToolsController:index'); | |
104 | $this->get('/password', '\Shaarli\Front\Controller\Admin\PasswordController:index'); | |
105 | $this->post('/password', '\Shaarli\Front\Controller\Admin\PasswordController:change'); | |
106 | $this->get('/configure', '\Shaarli\Front\Controller\Admin\ConfigureController:index'); | |
107 | $this->post('/configure', '\Shaarli\Front\Controller\Admin\ConfigureController:save'); | |
108 | $this->get('/tags', '\Shaarli\Front\Controller\Admin\ManageTagController:index'); | |
109 | $this->post('/tags', '\Shaarli\Front\Controller\Admin\ManageTagController:save'); | |
110 | $this->get('/add-shaare', '\Shaarli\Front\Controller\Admin\ManageShaareController:addShaare'); | |
111 | $this->get('/shaare', '\Shaarli\Front\Controller\Admin\ManageShaareController:displayCreateForm'); | |
112 | $this->get('/shaare/{id:[0-9]+}', '\Shaarli\Front\Controller\Admin\ManageShaareController:displayEditForm'); | |
113 | $this->post('/shaare', '\Shaarli\Front\Controller\Admin\ManageShaareController:save'); | |
114 | $this->get('/shaare/delete', '\Shaarli\Front\Controller\Admin\ManageShaareController:deleteBookmark'); | |
115 | $this->get('/shaare/visibility', '\Shaarli\Front\Controller\Admin\ManageShaareController:changeVisibility'); | |
116 | $this->get('/shaare/{id:[0-9]+}/pin', '\Shaarli\Front\Controller\Admin\ManageShaareController:pinBookmark'); | |
117 | $this->patch( | |
118 | '/shaare/{id:[0-9]+}/update-thumbnail', | |
119 | '\Shaarli\Front\Controller\Admin\ThumbnailsController:ajaxUpdate' | |
120 | ); | |
121 | $this->get('/export', '\Shaarli\Front\Controller\Admin\ExportController:index'); | |
122 | $this->post('/export', '\Shaarli\Front\Controller\Admin\ExportController:export'); | |
123 | $this->get('/import', '\Shaarli\Front\Controller\Admin\ImportController:index'); | |
124 | $this->post('/import', '\Shaarli\Front\Controller\Admin\ImportController:import'); | |
125 | $this->get('/plugins', '\Shaarli\Front\Controller\Admin\PluginsController:index'); | |
126 | $this->post('/plugins', '\Shaarli\Front\Controller\Admin\PluginsController:save'); | |
127 | $this->get('/token', '\Shaarli\Front\Controller\Admin\TokenController:getToken'); | |
128 | $this->get('/thumbnails', '\Shaarli\Front\Controller\Admin\ThumbnailsController:index'); | |
129 | ||
130 | $this->get('/visibility/{visibility}', '\Shaarli\Front\Controller\Admin\SessionFilterController:visibility'); | |
131 | })->add('\Shaarli\Front\ShaarliAdminMiddleware'); | |
132 | ||
133 | ||
134 | // REST API routes | |
135 | $app->group('/api/v1', function () { | |
136 | $this->get('/info', '\Shaarli\Api\Controllers\Info:getInfo')->setName('getInfo'); | |
137 | $this->get('/links', '\Shaarli\Api\Controllers\Links:getLinks')->setName('getLinks'); | |
138 | $this->get('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:getLink')->setName('getLink'); | |
139 | $this->post('/links', '\Shaarli\Api\Controllers\Links:postLink')->setName('postLink'); | |
140 | $this->put('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:putLink')->setName('putLink'); | |
141 | $this->delete('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:deleteLink')->setName('deleteLink'); | |
142 | ||
143 | $this->get('/tags', '\Shaarli\Api\Controllers\Tags:getTags')->setName('getTags'); | |
144 | $this->get('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:getTag')->setName('getTag'); | |
145 | $this->put('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:putTag')->setName('putTag'); | |
146 | $this->delete('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:deleteTag')->setName('deleteTag'); | |
147 | ||
148 | $this->get('/history', '\Shaarli\Api\Controllers\HistoryController:getHistory')->setName('getHistory'); | |
149 | })->add('\Shaarli\Api\ApiMiddleware'); | |
150 | ||
151 | $response = $app->run(true); | |
152 | ||
153 | $app->respond($response); |