Adding a hook on the signout page within the HTML output.
[squirrelmail.git] / src / signout.php
index 3197d198f6cf5e0feb5116a2708303dc79ef2ab7..d7258a77c2c50c9fbaebf159bc9daabb9e1ff00e 100644 (file)
@@ -1,41 +1,84 @@
-<?
-       /**
-        **  signout.php
-        **
-        **  Clears the cookie, and logs them out.
-        **
-        **/
-       
-       $username = "";
-       $key = "";
-       $logged_in = 0;
-       
-       setcookie("username", "", time(), "/");
-       setcookie("key", "", time(), "/");
-       setcookie("logged_in", 0, time(), "/");
+<?php
+   /**
+    **  signout.php -- cleans up session and logs the user out
+    **
+    **  Copyright (c) 1999-2000 The SquirrelMail development team
+    **  Licensed under the GNU GPL. For full terms see the file COPYING.
+    **
+    **  Cleans up after the user. Resets cookies and terminates
+    **  session.
+    **
+    **  $Id$
+    **/
+
+   include('../src/validate.php');
+   include ('../functions/prefs.php');
+   include ('../functions/plugin.php');
+
+   // Erase any lingering attachments
+   if (! isset($attachments)) {
+       $attachments = array();
+   }
+   foreach ($attachments as $info) {
+       if (file_exists($attachment_dir . $info['localfilename'])) {
+           unlink($attachment_dir . $info['localfilename']);
+       }
+   }
+
+   // If a user hits reload on the last page, $base_uri isn't set
+   // because it was deleted with the session.
+   if (! isset($base_uri)) {
+       ereg ("(^.*/)[^/]+/[^/]+$", $PHP_SELF, $regs);
+       $base_uri = $regs[1];
+   }
+
+   do_hook('logout');
+   setcookie('username', '', 0, $base_uri);
+   setcookie('key', '', 0, $base_uri);
+   session_destroy();
+
+   if ($signout_page) {
+       header("Status: 303 See Other");
+       header("Location: $signout_page");
+       exit; /* we send no content if we're redirecting. */
+   }
 ?>
 <HTML>
-<BODY BGCOLOR=FFFFFF>
-<?
-   echo "<BR><BR><TABLE BGCOLOR=FFFFFF BORDER=0 COLS=1 WIDTH=50% CELLSPACING=0 CELLPADDING=2 ALIGN=CENTER>";
-   echo "   <TR BGCOLOR=A0B8C8 WIDTH=100%>";
-   echo "      <TD ALIGN=CENTER>";
-   echo "         <FONT FACE=\"Arial,Helvetica\"><B>Sign Out</B></FONT>";
-   echo "      </TD>";
-   echo "   </TR>";
-   echo "   <TR BGCOLOR=FFFFFF WIDTH=100%>";
-   echo "      <TD ALIGN=CENTER>";
-   echo "         <FONT FACE=\"Arial,Helvetica\"><BR>You have been successfully signed out.<BR></FONT>";
-   echo "         <FONT FACE=\"Arial,Helvetica\">Click here to <A HREF=\"login.php\" TARGET=_top>log back in.</A></FONT><BR><BR>";
-   echo "      </TD>";
-   echo "   </TR>";
-   echo "   <TR BGCOLOR=DCDCDC WIDTH=100%>";
-   echo "      <TD ALIGN=CENTER>";
-   echo "         <FONT FACE=\"Arial,Helvetica\"><BR></FONT>";
-   echo "      </TD>";
-   echo "   </TR>";
-   echo "</TABLE>";
+   <HEAD>
+<?php
+   if ($theme_css != '') {
+?>
+<LINK REL="stylesheet" TYPE="text/css" HREF="<?php echo $theme_css ?>">
+<?php
+   }
 ?>
+<TITLE><?php echo $org_title ?> - Signout</TITLE>
+</HEAD>
+<BODY TEXT="<?php echo $color[8] ?>" BGCOLOR="<?php echo $color[4] ?>" 
+LINK="<?php echo $color[7] ?>" VLINK="<?php echo $color[7] ?>"
+ALINK="<?php echo $color[7] ?>">
+<BR><BR>
+<TABLE BGCOLOR="FFFFFF" BORDER="0" COLS="1" WIDTH="50%" CELLSPACING="0" 
+CELLPADDING="2" ALIGN="CENTER">
+  <TR BGCOLOR="<?php echo $color[0] ?>" WIDTH=100%>
+    <TD ALIGN="CENTER">
+      <B><?php echo _("Sign Out") ?></B>
+    </TD>
+  </TR>
+  <TR BGCOLOR="<?php echo $color[4] ?>" WIDTH=100%>
+    <TD ALIGN="CENTER">
+      <?php do_hook('logout_above_text'); ?>
+      <?php echo _("You have been successfully signed out.") ?><BR>
+      <A HREF="login.php" TARGET="_top">
+      <?php echo _("Click here to log back in.") ?>
+      </A><BR><BR>
+    </TD>
+  </TR>
+  <TR BGCOLOR="<?php echo $color[0] ?>" WIDTH=100%>
+    <TD ALIGN="CENTER">
+      <BR>
+    </TD>
+  </TR>
+</TABLE>
 </BODY>
 </HTML>
-