2013-04-03 15:14:01 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* poche, a read it later open source system
|
|
|
|
*
|
|
|
|
* @category poche
|
2013-04-13 11:08:31 +02:00
|
|
|
* @author Nicolas Lœuillet <support@inthepoche.com>
|
2013-04-03 15:14:01 +02:00
|
|
|
* @copyright 2013
|
|
|
|
* @license http://www.wtfpl.net/ see COPYING file
|
|
|
|
*/
|
|
|
|
|
2013-04-09 15:18:39 +02:00
|
|
|
include dirname(__FILE__).'/inc/config.php';
|
2013-04-03 15:14:01 +02:00
|
|
|
|
2013-04-21 18:42:20 +02:00
|
|
|
myTool::initPhp();
|
2013-04-21 19:32:19 +02:00
|
|
|
|
2013-04-19 11:41:12 +02:00
|
|
|
# XSRF protection with token
|
|
|
|
if (!empty($_POST)) {
|
|
|
|
if (!Session::isToken($_POST['token'])) {
|
|
|
|
die('Wrong token.');
|
|
|
|
}
|
|
|
|
unset($_SESSION['tokens']);
|
|
|
|
}
|
|
|
|
|
2013-04-20 10:22:00 +02:00
|
|
|
$ref = empty($_SERVER['HTTP_REFERER']) ? '' : $_SERVER['HTTP_REFERER'];
|
|
|
|
|
2013-04-19 11:41:12 +02:00
|
|
|
if (isset($_GET['login'])) {
|
|
|
|
// Login
|
|
|
|
if (!empty($_POST['login']) && !empty($_POST['password'])) {
|
2013-05-31 22:55:52 +02:00
|
|
|
if (Session::login($_SESSION['login'], $_SESSION['pass'], $_POST['login'], encode_string($_POST['password'] . $_POST['login']))) {
|
2013-04-19 11:41:12 +02:00
|
|
|
logm('login successful');
|
2013-05-31 22:55:52 +02:00
|
|
|
$msg->add('s', 'welcome in your poche!');
|
2013-04-19 11:41:12 +02:00
|
|
|
if (!empty($_POST['longlastingsession'])) {
|
|
|
|
$_SESSION['longlastingsession'] = 31536000;
|
|
|
|
$_SESSION['expires_on'] = time() + $_SESSION['longlastingsession'];
|
|
|
|
session_set_cookie_params($_SESSION['longlastingsession']);
|
|
|
|
} else {
|
|
|
|
session_set_cookie_params(0); // when browser closes
|
|
|
|
}
|
|
|
|
session_regenerate_id(true);
|
2013-04-04 19:51:24 +02:00
|
|
|
|
2013-04-20 10:22:00 +02:00
|
|
|
MyTool::redirect($ref);
|
2013-04-19 11:41:12 +02:00
|
|
|
}
|
|
|
|
logm('login failed');
|
|
|
|
die("Login failed !");
|
|
|
|
} else {
|
|
|
|
logm('login failed');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
elseif (isset($_GET['logout'])) {
|
|
|
|
logm('logout');
|
|
|
|
Session::logout();
|
|
|
|
MyTool::redirect();
|
|
|
|
}
|
2013-06-01 08:23:37 +02:00
|
|
|
elseif (isset($_GET['config'])) {
|
|
|
|
if (isset($_POST['password']) && isset($_POST['password_repeat'])) {
|
|
|
|
if ($_POST['password'] == $_POST['password_repeat'] && $_POST['password'] != "") {
|
|
|
|
logm('password updated');
|
|
|
|
$store->updatePassword(encode_string($_POST['password'] . $_SESSION['login']));
|
|
|
|
$msg->add('s', 'your password has been updated');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
$msg->add('e', 'your password can\'t be empty and you have to repeat it in the second field');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
$msg->add('e', 'error in your password update');
|
|
|
|
}
|
2013-04-19 11:41:12 +02:00
|
|
|
|
|
|
|
# Traitement des paramètres et déclenchement des actions
|
|
|
|
$view = (isset ($_REQUEST['view'])) ? htmlentities($_REQUEST['view']) : 'index';
|
|
|
|
$full_head = (isset ($_REQUEST['full_head'])) ? htmlentities($_REQUEST['full_head']) : 'yes';
|
|
|
|
$action = (isset ($_REQUEST['action'])) ? htmlentities($_REQUEST['action']) : '';
|
|
|
|
$_SESSION['sort'] = (isset ($_REQUEST['sort'])) ? htmlentities($_REQUEST['sort']) : 'id';
|
|
|
|
$id = (isset ($_REQUEST['id'])) ? htmlspecialchars($_REQUEST['id']) : '';
|
|
|
|
$url = (isset ($_GET['url'])) ? $_GET['url'] : '';
|
|
|
|
|
|
|
|
$tpl->assign('isLogged', Session::isLogged());
|
|
|
|
$tpl->assign('referer', $ref);
|
|
|
|
$tpl->assign('view', $view);
|
2013-04-21 18:42:20 +02:00
|
|
|
$tpl->assign('poche_url', myTool::getUrl());
|
2013-04-15 09:38:41 +02:00
|
|
|
$tpl->assign('title', 'poche, a read it later open source system');
|
2013-04-16 11:52:25 +02:00
|
|
|
|
2013-04-18 15:39:34 +02:00
|
|
|
if (Session::isLogged()) {
|
2013-04-19 11:41:12 +02:00
|
|
|
action_to_do($action, $url, $id);
|
|
|
|
display_view($view, $id, $full_head);
|
2013-04-18 15:39:34 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$tpl->draw('login');
|
2013-04-20 10:22:00 +02:00
|
|
|
}
|