]>
git.immae.eu Git - github/wallabag/wallabag.git/blob - inc/poche/Poche.class.php
3 * poche, a read it later open source system
6 * @author Nicolas Lœuillet <support@inthepoche.com>
8 * @license http://www.wtfpl.net/ see COPYING file
16 function __construct($storage_type)
18 $this->store
= new $storage_type();
22 if(!$this->store
->isInstalled())
30 private function init()
33 putenv('LC_ALL=' . LANG
);
34 setlocale(LC_ALL
, LANG
);
35 bindtextdomain(LANG
, LOCALE
);
39 $loader = new Twig_Loader_Filesystem(TPL
);
40 $this->tpl
= new Twig_Environment($loader, array(
43 $this->tpl
->addExtension(new Twig_Extensions_Extension_I18n());
49 private function install()
51 Tools
::logm('poche still not installed');
52 echo $this->tpl
->render('install.twig', array(
53 'token' => Session
::getToken(),
55 if (isset($_GET['install'])) {
56 if (($_POST['password'] == $_POST['password_repeat'])
57 && $_POST['password'] != "" && $_POST['login'] != "") {
58 # let's rock, install poche baby !
59 $this->store
->install($_POST['login'], Tools
::encodeString($_POST['password'] . $_POST['login']));
67 private function saveUser()
69 $_SESSION['login'] = (isset ($_SESSION['login'])) ? $_SESSION['login'] : $this->store
->getLogin();
70 $_SESSION['pass'] = (isset ($_SESSION['pass'])) ? $_SESSION['pass'] : $this->store
->getPassword();
74 * Call action (mark as fav, archive, delete, etc.)
76 public function action($action, Url
$url, $id = 0)
81 if($parametres_url = $url->fetchContent()) {
82 if ($this->store
->add($url->getUrl(), $parametres_url['title'], $parametres_url['content'])) {
83 Tools
::logm('add link ' . $url->getUrl());
84 $last_id = $this->store
->getLastId();
85 if (DOWNLOAD_PICTURES
) {
86 $content = filtre_picture($parametres_url['content'], $url->getUrl(), $last_id);
88 #$msg->add('s', _('the link has been added successfully'));
91 #$msg->add('e', _('error during insertion : the link wasn\'t added'));
92 Tools
::logm('error during insertion : the link wasn\'t added');
96 #$msg->add('e', _('error during url preparation : the link wasn\'t added'));
97 Tools
::logm('error during content fetch');
101 if ($this->store
->deleteById($id)) {
102 if (DOWNLOAD_PICTURES
) {
103 remove_directory(ABS_PATH
. $id);
105 #$msg->add('s', _('the link has been deleted successfully'));
106 Tools
::logm('delete link #' . $id);
109 #$msg->add('e', _('the link wasn\'t deleted'));
110 Tools
::logm('error : can\'t delete link #' . $id);
114 $this->store
->favoriteById($id);
115 Tools
::logm('mark as favorite link #' . $id);
117 case 'toggle_archive' :
118 $this->store
->archiveById($id);
119 Tools
::logm('archive link #' . $id);
128 function displayView($view, $id = 0)
135 Tools
::logm('install mode');
138 Tools
::logm('import mode');
141 $entries = $this->store
->retrieveAll();
142 // $tpl->assign('export', Tools::renderJson($entries));
143 // $tpl->draw('export');
144 Tools
::logm('export view');
147 Tools
::logm('config view');
150 $entry = $this->store
->retrieveOneById($id);
151 if ($entry != NULL) {
152 Tools
::logm('view link #' . $id);
153 $content = $entry['content'];
154 if (function_exists('tidy_parse_string')) {
155 $tidy = tidy_parse_string($content, array('indent'=>true, 'show-body-only' => true), 'UTF8');
156 $tidy->cleanRepair();
157 $content = $tidy->value
;
161 'content' => $content,
165 Tools
::logm('error in view call : entry is NULL');
169 $entries = $this->store
->getEntriesByView($view);
171 'entries' => $entries,
179 public function updatePassword()
181 if (isset($_POST['password']) && isset($_POST['password_repeat'])) {
182 if ($_POST['password'] == $_POST['password_repeat'] && $_POST['password'] != "") {
184 Tools
::logm('password updated');
185 $this->store
->updatePassword(Tools
::encodeString($_POST['password'] . $_SESSION['login']));
190 Tools
::logm('in demo mode, you can\'t do this');
196 public function login($referer)
198 if (!empty($_POST['login']) && !empty($_POST['password'])) {
199 if (Session
::login($_SESSION['login'], $_SESSION['pass'], $_POST['login'], Tools
::encodeString($_POST['password'] . $_POST['login']))) {
200 Tools
::logm('login successful');
202 if (!empty($_POST['longlastingsession'])) {
203 $_SESSION['longlastingsession'] = 31536000;
204 $_SESSION['expires_on'] = time() +
$_SESSION['longlastingsession'];
205 session_set_cookie_params($_SESSION['longlastingsession']);
207 session_set_cookie_params(0);
209 session_regenerate_id(true);
210 Tools
::redirect($referer);
212 Tools
::logm('login failed');
215 Tools
::logm('login failed');
220 public function logout()
222 Tools
::logm('logout');
227 public function import($from)
229 if ($from == 'pocket') {
230 $html = new simple_html_dom();
231 $html->load_file('./ril_export.html');
235 foreach($html->find('ul') as $ul)
237 foreach($ul->find('li') as $li)
240 $url = new Url($a[0]->href
);
241 $this->action('add', $url);
243 $last_id = $this->store
->lastInsertId();
244 $sql_update = "UPDATE entries SET is_read=~is_read WHERE id=?";
245 $params_update = array($last_id);
246 $query_update = $this->store
->prepare($sql_update);
247 $query_update->execute($params_update);
250 # Pocket génère un fichier HTML avec deux <ul>
251 # Le premier concerne les éléments non lus
252 # Le second concerne les éléments archivés
255 logm('import from pocket completed');
258 else if ($from == 'readability') {
259 # TODO finaliser tout ça ici
260 $str_data = file_get_contents("readability");
261 $data = json_decode($str_data,true);
263 foreach ($data as $key => $value) {
265 foreach ($value as $key2 => $value2) {
266 if ($key2 == 'article__url') {
267 $url = new Url($value2);
271 action_to_do('add', $url);
273 logm('import from Readability completed');
278 public function export()