]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
changement de la structure de la base sqlite
authornicosomb <nicolas@loeuillet.org>
Thu, 4 Apr 2013 17:51:24 +0000 (19:51 +0200)
committernicosomb <nicolas@loeuillet.org>
Thu, 4 Apr 2013 17:51:24 +0000 (19:51 +0200)
index.php
poche.sqlite

index d89fa41c3bc2ff5d4125797824c326695fc8d12b..be1ebef97cd913d6bba938360cee143f2fc2af93 100755 (executable)
--- a/index.php
+++ b/index.php
@@ -30,10 +30,12 @@ try
 }
 catch (Exception $e)
 {
-    die('error : '.$e->getMessage());
+    die('database error : '.$e->getMessage());
 }
 
 $action = (isset ($_GET['action'])) ? htmlspecialchars($_GET['action']) : '';
+$view = (isset ($_GET['view'])) ? htmlspecialchars($_GET['view']) : '';
+$id = (isset ($_GET['id'])) ? htmlspecialchars($_GET['id']) : '';
 
 switch ($action) {
     case 'add':
@@ -42,9 +44,13 @@ switch ($action) {
         $query = $db_handle->prepare('INSERT INTO entries ( url, title ) VALUES (?, ?)');
         $query->execute(array($url, $title));
         break;
-    case 'archive':
+    case 'toggle_fav' :
+        $sql_action = "UPDATE entries SET is_fav=~is_fav WHERE id=?";
+        $params_action = array($id);
         break;
-    case 'fav' :
+    case 'toggle_archive' :
+        $sql_action = "UPDATE entries SET is_read=~is_read WHERE id=?";
+        $params_action = array($id);
         break;
     case 'delete':
         break;
@@ -52,13 +58,55 @@ switch ($action) {
         break;
 }
 
-function url(){
-  $protocol = "http";
-  if(isset($_SERVER['HTTPS']))
-    if($_SERVER['HTTPS'] != "off")
-      $protocol = "https";
-  
-  return $protocol . "://" . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
+try
+{
+    # action query
+    if (isset($sql_action)) {
+        $query = $db_handle->prepare($sql_action);
+        $query->execute($params_action);
+    }
+}
+catch (Exception $e)
+{
+    die('query error : '.$e->getMessage());
+}
+
+switch ($view) {
+    case 'archive':
+        $sql = "SELECT * FROM entries WHERE is_read=?";
+        $params = array(-1);
+        break;
+    case 'fav' :
+        $sql = "SELECT * FROM entries WHERE is_fav=?";
+        $params = array(-1);
+        break;
+    default:
+        $sql = "SELECT * FROM entries WHERE is_read=?";
+        $params = array(0);
+        break;
+}
+
+# view query
+try
+{
+    $query = $db_handle->prepare($sql);
+    $query->execute($params);
+    $entries = $query->fetchAll();
+}
+catch (Exception $e)
+{
+    die('query error : '.$e->getMessage());
+}
+
+function url() {
+    $protocol = "http";
+    if(isset($_SERVER['HTTPS'])) {
+        if($_SERVER['HTTPS'] != "off") {
+            $protocol = "https";
+        }
+    }
+
+    return $protocol . "://" . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
 }
 ?>
 <!DOCTYPE html>
@@ -76,31 +124,26 @@ function url(){
         <link rel="stylesheet" href="css/style.css" media="all">
     </head>
     <body>
-       <header>
-                       <h1>poche, a read it later open source system</h1>
-               </header>
-               <div id="main" class="w800p">
-                       <ul id="links">
-                               <li><a href="index.php">home</a></li>
-                               <li><a href="#">favorites</a></li>
-                               <li><a href="#">archive</a></li>
-                <li><a href="javascript:(function(){var%20url%20=%20location.href;var%20title%20=%20document.title%20||%20url;window.open('<?php echo url()?>?action=add&url='%20+%20encodeURIComponent(url),'_self');})();">poche it !</a></li>
-                       </ul>
-               <?php
-                       $query = $db_handle->prepare("SELECT * FROM entries WHERE read=?");
-                       $query->execute(array('FALSE'));
-                       $entries = $query->fetchAll();
-               ?>
-                       <ul id="entries">
-                               <?php
-                               foreach ($entries as $entry) {
-                                       echo '<li><a href="readityourself.php?url='.urlencode($entry['url']).'">' . $entry['title'] . '</a> <a href="#" title="toggle delete" class="tool">&#10003;</a> <a href="#" title="toggle favorite" class="tool">&#9734;</a> <a href="#" title="toggle mark as read" class="tool">&#10799;</a></li>';
-                               }
-                               ?>
-                       </ul>
-               </div>
-               <footer class="mr2 mt3">
+        <header>
+            <h1>poche, a read it later open source system</h1>
+        </header>
+        <div id="main" class="w800p">
+            <ul id="links">
+                <li><a href="index.php">home</a></li>
+                <li><a href="?view=fav">favorites</a></li>
+                <li><a href="?view=archive">archive</a></li>
+                <li><a title="i am a bookmarklet, use me !" href="javascript:(function(){var%20url%20=%20location.href;var%20title%20=%20document.title%20||%20url;window.open('<?php echo url()?>?action=add&url='%20+%20encodeURIComponent(url),'_self');})();">poche it !</a></li>
+            </ul>
+            <ul id="entries">
+                <?php
+                foreach ($entries as $entry) {
+                    echo '<li><a href="readityourself.php?url='.urlencode($entry['url']).'">' . $entry['title'] . '</a> <a href="?action=toggle_archive&id='.$entry['id'].'" title="toggle mark as read" class="tool">&#10003;</a> <a href="?action=toggle_fav&id='.$entry['id'].'" title="toggle favorite" class="tool">'.(($entry['is_fav'] == 0) ? '&#9734;' : '&#9733;' ).'</a> <a href="#" title="toggle delete" class="tool">&#10799;</a></li>';
+                }
+                ?>
+            </ul>
+        </div>
+        <footer class="mr2 mt3">
             <p class="smaller"><a href="http://github.com/nicosomb/poche">poche</a> is a read it later open source system, based on <a href="http://www.memiks.fr/readityourself/">ReadItYourself</a>. poche is developed by <a href="http://nicolas.loeuillet.org">Nicolas LÅ“uillet</a> under the <a href="http://www.wtfpl.net/">Do What the Fuck You Want to Public License</a></p>
         </footer>
-       </body>
+    </body>
 </html>
\ No newline at end of file
index 0eea873f2d3c9254fc702ddb52a8f8059c1ace81..9ae63ec00c94ad66fc6d9c741fa6affd292cce5c 100755 (executable)
Binary files a/poche.sqlite and b/poche.sqlite differ