$Log$
+ Revision 1.18 2003/11/18 04:58:34 ajc
+ * Added ctdlelements.php ... this is to be used for functions which fetch
+ Citadel protocol data and convert it to insertable HTML.
+ * Implemented a first cut of a "read message" function.
+
Revision 1.17 2003/11/14 17:15:19 ajc
* Identify our message format preference (HTML followed by plain text)
to the server upon connection, so MSG4 commands run properly.
Revision 1.1 2003/10/31 03:47:13 ajc
* Initial CVS import
-
--- /dev/null
+<?PHP
+
+// $Id$
+//
+// Translates Citadel protocol data to insertable HTML snippets. You can
+// use these directly, or you can bypass them completely.
+//
+// Copyright (c) 2003 by Art Cancro <ajc@uncensored.citadel.org>
+// This program is released under the terms of the GNU General Public License.
+
+
+//
+// Fetch and display a message.
+//
+function display_message($msgnum) {
+
+ echo '<TABLE border=0 width=100% bgcolor="#DDDDDD"><TR><TD>' ;
+ // Fetch the message from the server
+ list($ok, $response, $fields) = ctdl_fetch_message($msgnum);
+
+ // Bail out gracefully if the message isn't there.
+ if (!$ok) {
+ echo "Error: " . htmlspecialchars($response) . "<BR>" ;
+ echo '</TD></TR></TABLE>' ;
+ return;
+ }
+
+ // Begin header
+ echo "<B><I>" .
+ strftime("%b %d %Y %I:%M%p ", $fields["time"]) .
+ " from " . htmlspecialchars($fields["from"]) .
+ "</I></B><BR>\n" ;
+
+ // Do message text
+ echo $fields["text"] . "<BR>";
+
+ echo '</TD></TR></TABLE><BR>' ;
+}
+
+
+
+?>
}
+// Load a message from the server.
+function ctdl_fetch_message($msgnum) {
+ global $clientsocket;
+
+ serv_puts("MSG4 " . $msgnum);
+ $response = serv_gets();
+
+ if (substr($response, 0, 1) != "1") {
+ return array(FALSE, substr($response, 4), NULL);
+ }
+
+ $fields = array();
+ while (strcmp($buf = serv_gets(), "000")) {
+ if (substr($buf, 0, 4) == "text") {
+ // We're in the text body. New loop here.
+ $fields["text"] = ctdl_msg4_from_server();
+ return array(TRUE, substr($response, 4), $fields);
+ }
+ else {
+ $fields[substr($buf, 0, 4)] = substr($buf, 5);
+ }
+ }
+
+ // Message terminated prematurely (no text body)
+ return array(FALSE, substr($response, 4), $fields);
+}
+
+// Support function for ctdl_fetch_message(). This handles the text body
+// portion of the message, converting various formats to HTML as
+// appropriate.
+function ctdl_msg4_from_server() {
+
+ $txt = "";
+ $msgformat = "text/plain";
+ $in_body = FALSE;
+
+ $previous_line = "";
+ while (strcmp($buf = serv_gets(), "000")) {
+ if ($in_body == FALSE) {
+ if (strlen($buf) == 0) {
+ $in_body = TRUE;
+ }
+ else {
+ if (!strncasecmp($buf, "content-type: ", 14)) {
+ $msgformat = substr($buf, 14);
+ }
+ }
+ }
+ else {
+ if (!strcasecmp($msgformat, "text/html")) {
+ $txt .= $buf;
+ }
+ else if (!strcasecmp($msgformat, "text/plain")) {
+ $txt .= "<TT>" . htmlspecialchars($buf) . "</TT><BR>\n" ;
+ }
+ else if (!strcasecmp($msgformat, "text/x-citadel-variformat")) {
+ if (substr($previous_line, 0, 1) == " ") {
+ $txt .= "<BR>\n" ;
+ }
+ $txt .= htmlspecialchars($buf);
+ }
+ else {
+ $txt .= htmlspecialchars($buf);
+ }
+ $previous_line = $buf;
+ }
+ }
+
+ return($txt);
+}
+
+
?>