First fast port of banana to PlWizard
[platal.git] / include / banana / hooks.inc.php
index 4c92e09..05d43cc 100644 (file)
@@ -28,7 +28,7 @@ function hook_formatDisplayHeader($_header, $_text, $in_spool = false)
         $addresses = preg_split("/ *, */", $_text);
         $text = '';
         foreach ($addresses as $address) {
-            $address = BananaMessage::formatFrom(trim($address));
+            $address = BananaMessage::formatFrom(trim($address), Banana::$message->getHeaderValue('subject'));
             if ($_header == 'from') {
                 if ($id = Banana::$message->getHeaderValue('x-org-id')) {
                     return $address . ' <a href="profile/' . $id . '" class="popup2" title="' . $id . '">'
@@ -39,7 +39,7 @@ function hook_formatDisplayHeader($_header, $_text, $in_spool = false)
                         . '<img src="images/icons/user_suit.gif" title="fiche" alt="" /></a>';
                 } else {
                     return $address;
-                }    
+                }
             }
             if (!empty($text)) {
                 $text .= ', ';
@@ -113,7 +113,8 @@ function hook_platalMessageLink($params)
 
 function hook_makeImg($img, $alt, $height, $width)
 {
-    $url = 'images/banana/' . $img;
+    global $globals;
+    $url = $globals->baseurl . '/images/banana/' . $img;
 
     if (!is_null($width)) {
         $width = ' width="' . $width . '"';
@@ -140,24 +141,26 @@ function hook_makeLink($params)
             return $base . '/' . $params['page'];
         }
         if (@$params['action'] == 'subscribe') {
-            return $base . '/subscription';
+            return $base . '/subscribe';
         }
-    
+
         if (!isset($params['group'])) {
             return $base;
         }
         $base .= '/' . $params['group'];
     } else if (Banana::$protocole->name() == 'NNTP' && $xnet) {
         if ($feed) {
-            return 'http://www.polytechnique.org/banana' . hook_platalRSS(@$params['group']);
-        }   
-        $base = $globals->baseurl . '/' . $platal->ns . 'forum';        
+            return $globals->baseurl . '/banana' . hook_platalRSS(@$params['group']);
+        }
+        $base = $globals->baseurl . '/' . $platal->ns . 'forum';
     } else if (Banana::$protocole->name() == 'MLArchives') {
-        $base = $globals->baseurl . '/' . $platal->ns . 'lists/archives';
         if ($feed) {
-            return $base . hook_platalRSS(MLBanana::$listname);
+            return $globals->baseurl . '/' . $platal->ns . hook_platalRSS(MLBanana::$listname);
+        } elseif (php_sapi_name() == 'cli') {
+            $base = "http://listes.polytechnique.org/archives/" . str_replace('@', '_', $params['group']);
+        } else {
+            $base = $globals->baseurl . '/' . $platal->ns . 'lists/archives/' . MLBanana::$listname;
         }
-        $base .= '/' . MLBanana::$listname;
     }
     $base = $base . hook_platalMessageLink($params);
     if (@$params['action'] == 'showext') {
@@ -167,6 +170,56 @@ function hook_makeLink($params)
 }
 }
 
+function hook_hasXFace($headers)
+{
+    return isset($headers['x-org-id']) || isset($headers['x-org-mail']);
+}
+
+function hook_getXFace($headers)
+{
+    $login = @$headers['x-org-id'];
+    if (!$login) {
+        @list($login, ) = explode('@', $headers['x-org-mail']);
+    }
+    if (!$login) {
+        return false;
+    }
+    if (isset($headers['x-face'])) {
+        $res = XDB::query("SELECT  p.uid
+                             FROM  forums.profils AS p
+                       INNER JOIN  aliases AS a ON (p.uid = a.id)
+                            WHERE  FIND_IN_SET('xface', p.flags) AND a.alias = {?}",
+                          $login);
+        if ($res->numRows()) {
+            return false;
+        }
+    }
+    global $globals;
+    http_redirect($global->baseurl . '/photo/' . $login);
+}
+
+function hook_makeJs($src)
+{
+    global $page;
+    $page->addJsLink("$src.js");
+    return ' ';
+}
+
+function make_Organization()
+{
+    global $globals;
+    $perms = S::v('perms');
+    $group = $globals->asso('nom');
+    if (S::has_perms()) {
+        return "Administrateur de Polytechnique.org";
+    } else if ($group && $perms->hasFlag('groupadmin')) {
+        return "Animateur de $group";
+    } else if ($group && $perms->hasFlag('groupmember')) {
+        return "Membre de $group";
+    }
+    return "Utilisateur de Polytechnique.org";
+}
+
 function get_banana_params(array &$get, $group = null, $action = null, $artid = null)
 {
     if (!is_null($group)) {
@@ -174,9 +227,9 @@ function get_banana_params(array &$get, $group = null, $action = null, $artid =
     }
     if (!is_null($action)) {
         if ($action == 'new') {
-            $get['action'] = 'new'; 
+            $get['action'] = 'new';
         } elseif (!is_null($artid)) {
-            $get['artid'] = $artid; 
+            $get['artid'] = $artid;
             if ($action == 'reply') {
                 $get['action'] = 'new';
             } elseif ($action == 'cancel') {
@@ -193,10 +246,52 @@ function get_banana_params(array &$get, $group = null, $action = null, $artid =
             } elseif ($action) {
                 $get['part'] = str_replace('.', '/', $action);
             }
-            if (Get::v('action') == 'showext') { 
-                $get['action'] = 'showext'; 
-            }   
+            if (Get::v('action') == 'showext') {
+                $get['action'] = 'showext';
+            }
+        }
+    }
+}
+
+class PlatalBananaPage extends BananaPage
+{
+    public function __construct()
+    {
+        Banana::$withtabs = false;
+        parent::__construct();
+    }
+
+    protected function prepare()
+    {
+        $tpl = parent::prepare();
+        global $wiz, $page;
+        $wiz = new PlWizard('Banana', 'core/plwizard.tpl', true, false);
+        foreach ($this->pages as $name=>&$mpage) {
+            $wiz->addPage('BananaHandler', $mpage['text'], $name);
         }
+        $wiz->apply($page, 'banana', $this->page);
+        return $tpl;
+    }
+}
+
+class BananaHandler
+{
+    public function __construct(PlWizard &$wiz)
+    {
+    }
+
+    public function template()
+    {
+        return 'banana/index.tpl';
+    }
+
+    public function prepare(PlatalPage &$page, $id)
+    {
+    }
+
+    public function process()
+    {
+        return PlWizard::CURRENT_PAGE;
     }
 }
 
@@ -217,7 +312,7 @@ function run_banana(&$page, $class, array $args)
     $bt = $banana->backtrace();
     if ($bt) {
         new PlBacktrace(Banana::$protocole->name(), $banana->backtrace(), 'response', 'time');
-    }    
+    }
 }
 
 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: