]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/sup.php
add bookmarklet to main help
[quix0rs-gnu-social.git] / actions / sup.php
index 3c9cbea2cb6cc73a500112b986f2811c941829c2..246b3299d32e975db9faa02648a3b18cade8335e 100644 (file)
 
 if (!defined('LACONICA')) { exit(1); }
 
-class SupAction extends Action {
-    
-    function handle($args) {
-        
+class SupAction extends Action
+{
+    function handle($args)
+    {
         parent::handle($args);
-        
+
         $seconds = $this->trimmed('seconds');
-        
+
         if (!$seconds) {
             $seconds = 15;
         }
 
-        $updates = $this->get_updates($seconds);
-        
+        $updates = $this->getUpdates($seconds);
+
         header('Content-Type: application/json; charset=utf-8');
-        
+
         print json_encode(array('updated_time' => date('c'),
                                 'since_time' => date('c', time() - $seconds),
-                                'available_periods' => $this->available_periods(),
+                                'available_periods' => $this->availablePeriods(),
                                 'period' => $seconds,
                                 'updates' => $updates));
     }
-    
-    function available_periods() {
+
+    function availablePeriods()
+    {
         static $periods = array(86400, 43200, 21600, 7200,
-                                3600, 1800,    600, 300, 120,
-                                60, 30, 15); 
+                                3600, 1800, 600, 300, 120,
+                                60, 30, 15);
         $available = array();
         foreach ($periods as $period) {
             $available[$period] = common_local_url('sup',
                                                    array('seconds' => $period));
         }
-        
+
         return $available;
     }
-    
-    function get_updates($seconds) {
+
+    function getUpdates($seconds)
+    {
         $notice = new Notice();
 
         # XXX: cache this. Depends on how big this protocol becomes;
@@ -63,19 +65,22 @@ class SupAction extends Action {
 
         $notice->query('SELECT profile_id, max(id) AS max_id ' .
                        'FROM notice ' .
-                       'WHERE created > (now() - ' . $seconds . ') ' .
+                        ((common_config('db','type') == 'pgsql') ?
+                       'WHERE extract(epoch from created) > (extract(epoch from now()) - ' . $seconds . ') ' :
+                       'WHERE created > (now() - ' . $seconds . ') ' ) .
                        'GROUP BY profile_id');
-        
+
         $updates = array();
-        
+
         while ($notice->fetch()) {
             $updates[] = array($notice->profile_id, $notice->max_id);
         }
-        
+
         return $updates;
     }
-    
-    function is_readonly() {
+
+    function isReadOnly()
+    {
         return true;
     }
 }