head_contents(blog_title() . $tagline, blog_description(), site_url()), 'bodyclass' => 'noposts', )); die; } render('main', array( 'head_contents' => head_contents(blog_title() . $tagline, blog_description(), site_url()), 'page' => $page, 'posts' => $posts, 'bodyclass' => 'infront', 'breadcrumb' => '', 'pagination' => has_pagination($total, $perpage, $page) )); }); // Get submitted login data post('/login', function () { $proper = (is_csrf_proper(from($_REQUEST, 'csrf_token'))); $captcha = isCaptcha(from($_REQUEST, 'g-recaptcha-response')); $user = from($_REQUEST, 'user'); $pass = from($_REQUEST, 'password'); if ($proper && $captcha && !empty($user) && !empty($pass)) { session($user, $pass); $log = session($user, $pass); if (!empty($log)) { config('views.root', 'system/admin/views'); render('login', array( 'head_contents' => head_contents('Login - ' . blog_title(), 'Login page on ' . blog_title(), site_url()), 'error' => '', 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Login' )); } } else { $message['error'] = ''; if (empty($user)) { $message['error'] .= '
  • User field is required.
  • '; } if (empty($pass)) { $message['error'] .= '
  • Password field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } if (!$captcha) { $message['error'] .= '
  • reCaptcha not correct.
  • '; } config('views.root', 'system/admin/views'); render('login', array( 'head_contents' => head_contents('Login - ' . blog_title(), 'Login page on ' . blog_title(), site_url()), 'error' => '', 'username' => $user, 'password' => $pass, 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Login' )); } }); get("/:static/:sub/edit", function ($static, $sub) { if (login()) { config('views.root', 'system/admin/views'); $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; $page = get_static_sub_post($static, $sub); if (!$page) { not_found(); } $page = $page[0]; render('edit-page', array( 'head_contents' => head_contents('Edit page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'editpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title . ' » ', 'p' => $page, 'type' => 'staticpage', )); } else { $login = site_url() . 'login'; header("location: $login"); } }); post("/:static/:sub/edit", function ($static, $sub) { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if (!login()) { $login = site_url() . 'login'; header("location: $login"); } $title = from($_REQUEST, 'title'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $oldfile = from($_REQUEST, 'oldfile'); $destination = from($_GET, 'destination'); $description = from($_REQUEST, 'description'); if ($destination === null) { $destination = $static . "/" . $sub; } if ($proper && !empty($title) && !empty($content)) { if (!empty($url)) { edit_page($title, $url, $content, $oldfile, $destination, $description); } else { $url = $title; edit_page($title, $url, $content, $oldfile, $destination, $description); } } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('edit-page', array( 'head_contents' => head_contents('Edit page - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'oldfile' => $oldfile, 'postTitle' => $title, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'editpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Edit page' )); } }); get("/:static/:sub/delete", function ($static, $sub) { if (login()) { config('views.root', 'system/admin/views'); $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; $page = get_static_sub_post($static, $sub); if (!$page) { not_found(); } $page = $page[0]; render('delete-page', array( 'head_contents' => head_contents('Delete page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'deletepage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title . '' . $page->title, 'p' => $page, 'type' => 'staticpage', )); } else { $login = site_url() . 'login'; header("location: $login"); } }); post("/:static/:sub/delete", function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if ($proper && login()) { $file = from($_REQUEST, 'file'); $destination = from($_GET, 'destination'); delete_page($file, $destination); } }); // The blog post page get('/:year/:month/:name', function ($year, $month, $name) { if (config("views.counter") != "true") { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } } $post = find_post($year, $month, $name); $current = $post['current']; if (!$current) { not_found(); } if (config("views.counter") == "true") { add_view($current->file); if (!login()) { file_cache($_SERVER['REQUEST_URI']); } } $bio = get_bio($current->author); if (isset($bio[0])) { $bio = $bio[0]; } else { $bio = default_profile($current->author); } if (array_key_exists('prev', $post)) { $prev = $post['prev']; } else { $prev = array(); } if (array_key_exists('next', $post)) { $next = $post['next']; } else { $next = array(); } render('post', array( 'head_contents' => head_contents($current->title . ' - ' . blog_title(), $current->description, $current->url), 'p' => $current, 'authorinfo' => authorinfo($bio->title, $bio->body), 'bodyclass' => 'inpost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $current->tagb . ' » ' . $current->title, 'prev' => has_prev($prev), 'next' => has_next($next), 'type' => 'blogpost', )); }); // Edit blog post get('/:year/:month/:name/edit', function ($year, $month, $name) { if (login()) { $user = $_SESSION[config("site.url")]['user']; $role = user('role', $user); config('views.root', 'system/admin/views'); $post = find_post($year, $month, $name); if (!$post) { not_found(); } $current = $post['current']; if ($user === $current->author || $role === 'admin') { render('edit-post', array( 'head_contents' => head_contents('Edit post - ' . blog_title(), blog_description(), site_url()), 'p' => $current, 'bodyclass' => 'editpost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $current->tagb . ' » ' . $current->title )); } else { render('denied', array( 'head_contents' => head_contents('Edit post - ' . blog_title(), blog_description(), site_url()), 'p' => $current, 'bodyclass' => 'denied', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $current->tagb . ' » ' . $current->title )); } } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get edited data for blog post post('/:year/:month/:name/edit', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $title = from($_REQUEST, 'title'); $img = from($_REQUEST, 'img'); $vid = from($_REQUEST, 'vid'); $tag = from($_REQUEST, 'tag'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $oldfile = from($_REQUEST, 'oldfile'); $destination = from($_GET, 'destination'); $description = from($_REQUEST, 'description'); $date = from($_REQUEST, 'date'); $time = from($_REQUEST, 'time'); $dateTime = null; if ($date !== null && $time !== null) { $dateTime = $date . ' ' . $time; } if ($proper && !empty($title) && !empty($tag) && !empty($content)) { if (empty($url)) { $url = $title; } edit_post($title, $tag, $url, $content, $oldfile, $destination, $description, $dateTime, $img, $vid); } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($tag)) { $message['error'] .= '
  • Tag field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('edit-post', array( 'head_contents' => head_contents('Edit post - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'oldfile' => $oldfile, 'postTitle' => $title, 'postImg' => $img, 'postVid' => $vid, 'postTag' => $tag, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'editpost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Edit post' )); } }); // Delete blog post get('/:year/:month/:name/delete', function ($year, $month, $name) { if (login()) { $user = $_SESSION[config("site.url")]['user']; $role = user('role', $user); config('views.root', 'system/admin/views'); $post = find_post($year, $month, $name); if (!$post) { not_found(); } $current = $post['current']; if ($user === $current->author || $role === 'admin') { render('delete-post', array( 'head_contents' => head_contents('Delete post - ' . blog_title(), blog_description(), site_url()), 'p' => $current, 'bodyclass' => 'deletepost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $current->tagb . ' » ' . $current->title )); } else { render('denied', array( 'head_contents' => head_contents('Delete post - ' . blog_title(), blog_description(), site_url()), 'p' => $current, 'bodyclass' => 'deletepost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $current->tagb . ' » ' . $current->title )); } } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get deleted data for blog post post('/:year/:month/:name/delete', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if ($proper && login()) { $file = from($_REQUEST, 'file'); $destination = from($_GET, 'destination'); delete_post($file, $destination); } }); // The author page get('/author/:profile', function ($profile) { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('profile.perpage'); $posts = get_profile($profile, $page, $perpage); $total = get_count($profile, 'dirname'); $bio = get_bio($profile); if (isset($bio[0])) { $bio = $bio[0]; } else { $bio = default_profile($profile); } if (empty($posts) || $page < 1) { render('profile', array( 'head_contents' => head_contents('Profile for: ' . $bio->title . ' - ' . blog_title(), 'Profile page and all posts by ' . $bio->title . ' on ' . blog_title() . '.', site_url() . 'author/' . $profile), 'page' => $page, 'posts' => null, 'bio' => $bio->body, 'name' => $bio->title, 'bodyclass' => 'inprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Profile for: ' . $bio->title, 'pagination' => has_pagination($total, $perpage, $page) )); die; } render('profile', array( 'head_contents' => head_contents('Profile for: ' . $bio->title . ' - ' . blog_title(), 'Profile page and all posts by ' . $bio->title . ' on ' . blog_title() . '.', site_url() . 'author/' . $profile), 'page' => $page, 'posts' => $posts, 'bio' => $bio->body, 'name' => $bio->title, 'bodyclass' => 'inprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Profile for: ' . $bio->title, 'pagination' => has_pagination($total, $perpage, $page) )); }); // Edit the profile get('/edit/profile', function () { if (login()) { config('views.root', 'system/admin/views'); render('edit-profile', array( 'head_contents' => head_contents('Edit profile - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Edit profile', )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get edited data for static page post('/edit/profile', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $user = $_SESSION[config("site.url")]['user']; $title = from($_REQUEST, 'title'); $content = from($_REQUEST, 'content'); if ($proper && !empty($title) && !empty($content)) { edit_profile($title, $content, $user); } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('edit-profile', array( 'head_contents' => head_contents('Edit profile - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'postTitle' => $title, 'postContent' => $content, 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Edit profile' )); } }); get('/admin/posts', function () { $user = $_SESSION[config("site.url")]['user']; $role = user('role', $user); if (login()) { config('views.root', 'system/admin/views'); if ($role === 'admin') { config('views.root', 'system/admin/views'); $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = 20; $posts = get_posts(null, $page, $perpage); $total = ''; if (empty($posts) || $page < 1) { // a non-existing page render('no-posts', array( 'head_contents' => head_contents('All blog posts - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'noposts', )); die; } $tl = blog_tagline(); if ($tl) { $tagline = ' - ' . $tl; } else { $tagline = ''; } render('posts-list', array( 'head_contents' => head_contents('All blog posts - ' . blog_title(), blog_description(), site_url()), 'heading' => 'All blog posts', 'page' => $page, 'posts' => $posts, 'bodyclass' => 'all-posts', 'breadcrumb' => '', 'pagination' => has_pagination($total, $perpage, $page) )); } else { render('denied', array( 'head_contents' => head_contents('All blog posts - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'denied', 'breadcrumb' => '', )); } } else { $login = site_url() . 'login'; header("location: $login"); } }); // The author page get('/admin/mine', function () { if (login()) { config('views.root', 'system/admin/views'); $profile = $_SESSION[config("site.url")]['user']; $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('profile.perpage'); $posts = get_profile($profile, $page, $perpage); $total = get_count($profile, 'dirname'); $bio = get_bio($profile); if (isset($bio[0])) { $bio = $bio[0]; } else { $bio = default_profile($profile); } if (empty($posts) || $page < 1) { render('user-posts', array( 'head_contents' => head_contents('My blog posts - ' . blog_title(), blog_description(), site_url()), 'page' => $page, 'heading' => 'My posts', 'posts' => null, 'bio' => $bio->body, 'name' => $bio->title, 'bodyclass' => 'userposts', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Profile for: ' . $bio->title, 'pagination' => has_pagination($total, $perpage, $page) )); die; } render('user-posts', array( 'head_contents' => head_contents('My blog posts - ' . blog_title(), blog_description(), site_url()), 'heading' => 'My posts', 'page' => $page, 'posts' => $posts, 'bio' => $bio->body, 'name' => $bio->title, 'bodyclass' => 'userposts', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Profile for: ' . $bio->title, 'pagination' => has_pagination($total, $perpage, $page) )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // The static page get('/:static', function ($static) { if ($static === 'sitemap.xml' || $static === 'sitemap.base.xml' || $static === 'sitemap.post.xml' || $static === 'sitemap.static.xml' || $static === 'sitemap.tag.xml' || $static === 'sitemap.archive.xml' || $static === 'sitemap.author.xml') { header('Content-Type: text/xml'); if ($static === 'sitemap.xml') { generate_sitemap('index'); } elseif ($static === 'sitemap.base.xml') { generate_sitemap('base'); } elseif ($static === 'sitemap.post.xml') { generate_sitemap('post'); } elseif ($static === 'sitemap.static.xml') { generate_sitemap('static'); } elseif ($static === 'sitemap.tag.xml') { generate_sitemap('tag'); } elseif ($static === 'sitemap.archive.xml') { generate_sitemap('archive'); } elseif ($static === 'sitemap.author.xml') { generate_sitemap('author'); } die; } elseif ($static === 'admin') { if (login()) { config('views.root', 'system/admin/views'); render('main', array( 'head_contents' => head_contents('Admin - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'adminfront', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Admin' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; } elseif ($static === 'login') { config('views.root', 'system/admin/views'); render('login', array( 'head_contents' => head_contents('Login - ' . blog_title(), 'Login page from ' . blog_title() . '.', site_url() . '/login'), 'bodyclass' => 'inlogin', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Login' )); die; } elseif ($static === 'logout') { if (login()) { config('views.root', 'system/admin/views'); render('logout', array( 'head_contents' => head_contents('Logout - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'inlogout', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Logout' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; } else { if (config("views.counter") != "true") { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } } $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; if (config("views.counter") == "true") { add_view($post->file); if (!login()) { file_cache($_SERVER['REQUEST_URI']); } } render('static', array( 'head_contents' => head_contents($post->title . ' - ' . blog_title(), $post->description, $post->url), 'bodyclass' => 'inpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title, 'p' => $post, 'type' => 'staticpage', )); } }); // Edit the static page get('/:static/edit', function ($static) { if (login()) { config('views.root', 'system/admin/views'); $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; render('edit-page', array( 'head_contents' => head_contents('Edit page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'editpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title, 'p' => $post, 'type' => 'staticpage', )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get edited data for static page post('/:static/edit', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if (!login()) { $login = site_url() . 'login'; header("location: $login"); } $title = from($_REQUEST, 'title'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $oldfile = from($_REQUEST, 'oldfile'); $destination = from($_GET, 'destination'); $description = from($_REQUEST, 'description'); if ($proper && !empty($title) && !empty($content)) { if (!empty($url)) { edit_page($title, $url, $content, $oldfile, $destination, $description); } else { $url = $title; edit_page($title, $url, $content, $oldfile, $destination, $description); } } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('edit-page', array( 'head_contents' => head_contents('Edit page - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'oldfile' => $oldfile, 'postTitle' => $title, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'editpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Edit page' )); } }); // Deleted the static page get('/:static/delete', function ($static) { if (login()) { config('views.root', 'system/admin/views'); $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; render('delete-page', array( 'head_contents' => head_contents('Delete page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'deletepage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title, 'p' => $post, 'type' => 'staticpage', )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get deleted data for static page post('/:static/delete', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if ($proper && login()) { $file = from($_REQUEST, 'file'); $destination = from($_GET, 'destination'); delete_page($file, $destination); } }); // Add blog post get('/add/post', function () { if (login()) { config('views.root', 'system/admin/views'); render('add-post', array( 'head_contents' => head_contents('Add post - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'addpost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Add post' )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get submitted blog post data post('/add/post', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $title = from($_REQUEST, 'title'); $img = from($_REQUEST, 'img'); $vid = from($_REQUEST, 'vid'); $tag = from($_REQUEST, 'tag'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $description = from($_REQUEST, 'description'); $user = $_SESSION[config("site.url")]['user']; if ($proper && !empty($title) && !empty($tag) && !empty($content)) { if (!empty($url)) { add_post($title, $tag, $url, $content, $user, $description, $fi, $vid); } else { $url = $title; add_post($title, $tag, $url, $content, $user, $description, $fi, $vid); } } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($tag)) { $message['error'] .= '
  • Tag field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('add-post', array( 'head_contents' => head_contents('Add post - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'postTitle' => $title, 'postFi' => $fi, 'postVid' => $vid, 'postTag' => $tag, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'addpost', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Add post' )); } }); // Add the static page get('/add/page', function () { if (login()) { config('views.root', 'system/admin/views'); render('add-page', array( 'head_contents' => head_contents('Add page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'addpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Add page' )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Add the static page get('/add/page', function () { if (login()) { config('views.root', 'system/admin/views'); render('add-page', array( 'head_contents' => head_contents('Add page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'addpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Add page' )); } else { $login = site_url() . 'login'; header("location: $login"); } }); // Get submitted static page data post('/add/page', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $title = from($_REQUEST, 'title'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $description = from($_REQUEST, 'description'); if ($proper && !empty($title) && !empty($content) && login()) { if (!empty($url)) { add_page($title, $url, $content, $description); } else { $url = $title; add_page($title, $url, $content, $description); } } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('add-page', array( 'head_contents' => head_contents('Add page - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'postTitle' => $title, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'addpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Add page' )); } }); // Import page get('/admin/import', function () { if (login()) { config('views.root', 'system/admin/views'); render('import', array( 'head_contents' => head_contents('Import feed - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'importfeed', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Import feed' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // Get import post post('/admin/import', function () { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $url = from($_REQUEST, 'url'); $credit = from($_REQUEST, 'credit'); if (login() && !empty($url) && $proper) { get_feed($url, $credit); $log = get_feed($url, $credit); if (!empty($log)) { config('views.root', 'system/admin/views'); render('import', array( 'head_contents' => head_contents('Import feed - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Import feed' )); } } else { $message['error'] = ''; if (empty($url)) { $message['error'] .= '
  • You need to specify the feed url.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('import', array( 'head_contents' => head_contents('Import feed - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'url' => $url, 'bodyclass' => 'editprofile', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Login' )); } }); // Config page get('/admin/config', function () { if (login()) { config('views.root', 'system/admin/views'); render('config', array( 'head_contents' => head_contents('Config - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'config', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Config' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // Config page post('/admin/config', function () { error_reporting(E_ALL); ini_set("display_errors", 1); $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); if (login() && $proper) { $newKey = from($_REQUEST, 'newKey'); $newValue = from($_REQUEST, 'newValue'); $new_config = array(); $new_Keys = array(); if (!empty($newKey)) { $new_Keys[$newKey] = $newValue; } foreach ($_POST as $name => $value) { if (substr($name, 0, 8) == "-config-") { $name = str_replace("_", ".", substr($name, 8)); $new_config[$name] = $value; } } save_config($new_config, $new_Keys); $login = site_url() . 'admin/config'; header("location: $login"); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // Backup page get('/admin/backup', function () { if (login()) { config('views.root', 'system/admin/views'); render('backup', array( 'head_contents' => head_contents('Backup content - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'backup', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Backup' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // Create Zip file get('/admin/backup-start', function () { if (login()) { config('views.root', 'system/admin/views'); render('backup-start', array( 'head_contents' => head_contents('Backup content started - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'startbackup', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Backup started' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // Delete all cache get('/admin/clear-cache', function () { if (login()) { config('views.root', 'system/admin/views'); render('clear-cache', array( 'head_contents' => head_contents('Clearing cache started - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'clearcache', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Clearing cache started' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); // The tag page get('/tag/:tag', function ($tag) { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('tag.perpage'); $posts = get_tag($tag, $page, $perpage, false); $total = get_count($tag, 'filename'); if (empty($posts) || $page < 1) { // a non-existing page not_found(); } render('main', array( 'head_contents' => head_contents('Posts tagged: ' . $tag . ' - ' . blog_title(), 'All posts tagged: ' . $tag . ' on ' . blog_title() . '.', site_url() . 'tag/' . $tag), 'page' => $page, 'posts' => $posts, 'bodyclass' => 'intag', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Posts tagged: ' . $tag, 'pagination' => has_pagination($total, $perpage, $page) )); }); // The archive page get('/archive/:req', function ($req) { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('archive.perpage'); $posts = get_archive($req, $page, $perpage); $total = get_count($req, 'filename'); if (empty($posts) || $page < 1) { // a non-existing page not_found(); } $time = explode('-', $req); $date = strtotime($req); if (isset($time[0]) && isset($time[1]) && isset($time[2])) { $timestamp = date('d F Y', $date); } elseif (isset($time[0]) && isset($time[1])) { $timestamp = date('F Y', $date); } else { $timestamp = $req; } if (!$date) { // a non-existing page not_found(); } render('main', array( 'head_contents' => head_contents('Archive for: ' . $timestamp . ' - ' . blog_title(), 'Archive page for: ' . $timestamp . ' on ' . blog_title() . '.', site_url() . 'archive/' . $req), 'page' => $page, 'posts' => $posts, 'bodyclass' => 'inarchive', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Archive for: ' . $timestamp, 'pagination' => has_pagination($total, $perpage, $page) )); }); // The search page get('/search/:keyword', function ($keyword) { if (!login()) { file_cache($_SERVER['REQUEST_URI']); } $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('search.perpage'); $posts = get_keyword($keyword, $page, $perpage); $total = keyword_count($keyword); if (empty($posts) || $page < 1) { // a non-existing page render('404-search', null, false); die; } render('main', array( 'head_contents' => head_contents('Search results for: ' . $keyword . ' - ' . blog_title(), 'Search results for: ' . $keyword . ' on ' . blog_title() . '.', site_url() . 'search/' . $keyword), 'page' => $page, 'posts' => $posts, 'bodyclass' => 'insearch', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Search results for: ' . $keyword, 'pagination' => has_pagination($total, $perpage, $page) )); }); // The JSON API get('/api/json', function () { header('Content-type: application/json'); $page = from($_GET, 'page'); $page = $page ? (int)$page : 1; $perpage = config('json.count'); echo generate_json(get_posts(null, $page, $perpage)); }); // Show the RSS feed get('/feed/rss', function () { header('Content-Type: application/rss+xml'); // Show an RSS feed with the 30 latest posts echo generate_rss(get_posts(null, 1, config('rss.count'))); }); // Generate OPML file get('/feed/opml', function () { header('Content-Type: text/xml'); // Generate OPML file for the RSS echo generate_opml(); }); // Update page get('/admin/update', function () { if (login()) { config('views.root', 'system/admin/views'); render('update', array( 'head_contents' => head_contents('Check for Update - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'updatepage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » Update HTMLy' )); } else { $login = site_url() . 'login'; header("location: $login"); } die; }); get('/admin/update/now/:csrf', function ($CSRF) { $proper = is_csrf_proper($CSRF); $updater = new \Kanti\HubUpdater(array( 'name' => 'danpros/htmly', 'prerelease' => !!config("prerelease"), )); if (login() && $proper && $updater->able()) { $updater->update(); config('views.root', 'system/admin/views'); render('updated-to', array( 'head_contents' => head_contents('Updated - ' . blog_title(), blog_description(), site_url()), 'info' => $updater->getCurrentInfo(), )); } else { $login = site_url() . 'login'; header("location: $login"); } }); get('/:static/add', function ($static) { if (login()) { config('views.root', 'system/admin/views'); $post = get_static_post($static); if (!$post) { not_found(); } $post = $post[0]; render('add-page', array( 'head_contents' => head_contents('Add page - ' . blog_title(), blog_description(), site_url()), 'bodyclass' => 'addpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title . ' Add page' )); } else { $login = site_url() . 'login'; header("location: $login"); } }); post('/:static/add', function ($static) { $proper = is_csrf_proper(from($_REQUEST, 'csrf_token')); $title = from($_REQUEST, 'title'); $url = from($_REQUEST, 'url'); $content = from($_REQUEST, 'content'); $description = from($_REQUEST, 'description'); if ($proper && !empty($title) && !empty($content) && login()) { if (!empty($url)) { add_sub_page($title, $url, $content, $static, $description); } else { $url = $title; add_sub_page($title, $url, $content, $static, $description); } } else { $message['error'] = ''; if (empty($title)) { $message['error'] .= '
  • Title field is required.
  • '; } if (empty($content)) { $message['error'] .= '
  • Content field is required.
  • '; } if (!$proper) { $message['error'] .= '
  • CSRF Token not correct.
  • '; } config('views.root', 'system/admin/views'); render('add-page', array( 'head_contents' => head_contents('Add page - ' . blog_title(), blog_description(), site_url()), 'error' => '', 'postTitle' => $title, 'postUrl' => $url, 'postContent' => $content, 'bodyclass' => 'addpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $post->title . ' Add page' )); } }); get('/:static/:sub', function ($static, $sub) { $father_post = get_static_post($static); if (!$father_post) { not_found(); } $post = get_static_sub_post($static, $sub); if (!$post) { not_found(); } $post = $post[0]; if (config("views.counter") == "true") { add_view($post->file); } if (!login()) { file_cache($_SERVER['REQUEST_URI']); } render('static', array( 'head_contents' => head_contents($post->title . ' - ' . blog_title(), $post->description, $post->url), 'bodyclass' => 'inpage', 'breadcrumb' => '' . config('breadcrumb.home') . ' » ' . $father_post[0]->title . ' » ' . $post->title, 'p' => $post, 'type' => 'staticpage', )); }); // If we get here, it means that // nothing has been matched above get('.*', function () { not_found(); }); // Serve the blog dispatch();