$this->make_hook('url', AUTH_PUBLIC), 'admin/url' => $this->make_hook('admin_url', AUTH_PASSWD, 'admin') ); } function handler_url($page, $alias) { http_redirect(Platal::globals()->core->base_url_shortener . $alias); } function handler_admin_url($page) { $page->changeTpl('urlshortener/admin.tpl'); if (!Post::has('url')) { return; } $url = Post::t('url'); $alias = Post::t('alias'); $url_regex = '{^(https?|ftp)://[a-zA-Z0-9._%#+/?=&~-]+$}i'; if (strlen($url) > 255 || !preg_match($url_regex, $url)) { $page->trigError("L'url donnée n'est pas valide."); return; } $page->assign('url', $url); if ($alias != '') { if (!preg_match('/^[a-zA-Z0-9\-\/]+$/i', $alias)) { $page->trigError("L'alias proposé n'est pas valide."); return; } if (preg_match('/^a\//i', $alias)) { $page->trigError("L'alias commence par le préfixe 'a/' qui est réservé et donc non autorisé."); return; } $page->assign('alias', $alias); $used = XDB::fetchOneCell('SELECT COUNT(*) FROM url_shortener WHERE alias = {?}', $alias); if ($used != 0) { $page->trigError("L'alias proposé est déjà utilisé."); return; } } else { do { $alias = 'a/' . rand_token(6); $used = XDB::fetchOneCell('SELECT COUNT(*) FROM url_shortener WHERE alias = {?}', $alias); } while ($used != 0); $page->assign('alias', $alias); } XDB::execute('INSERT INTO url_shortener (url, alias) VALUES ({?}, {?})', $url, $alias); $page->trigSuccess("L'url « " . $url . ' » est maintenant accessible depuis « http://u.w4x.org/' . $alias . ' ».'); } } // vim:set et sw=4 sts=4 sws=4 foldmethod=marker fenc=utf-8: ?>