(* COCANWIKI - a wiki written in Objective CAML.
* Written by Richard W.M. Jones <rich@merjis.com>.
* Copyright (C) 2004 Merjis Ltd.
- * $Id: contact.ml,v 1.3 2004/09/23 11:56:47 rich Exp $
+ * $Id: contact.ml,v 1.4 2004/09/25 12:53:55 rich Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
return ()
in
- (* Get the id field. *)
- let id =
- try int_of_string (q#param "id")
+ (* Get the name field. *)
+ let name =
+ try q#param "id"
with
- Not_found -> fail "The 'id' field is missing in that form."
- | Failure "int_of_string" ->
- fail "The 'id' field in that form is not a number." in
+ Not_found -> fail "The 'name' field is missing in that form." in
(* Get the contacts / emails from the database. *)
- let sth = dbh#prepare_cached "select subject from contacts
- where hostid = ? and id = ?" in
- sth#execute [`Int hostid; `Int id];
-
- let subject =
- try sth#fetch1string ()
- with Not_found -> fail "There is no such contact id in the database." in
+ let sth = dbh#prepare_cached "select id, subject from contacts
+ where hostid = ? and name = ?" in
+ sth#execute [`Int hostid; `String name];
+
+ let id, subject =
+ try
+ (match sth#fetch1 () with
+ [ `Int id; `String subject ] -> id, subject
+ | _ -> assert false
+ )
+ with Not_found -> fail "There is no such contact form in the database." in
let sth = dbh#prepare_cached "select email from contact_emails
where contactid = ?" in
<pre>
<html>
<form method="post" action="/_contact">
-<input type="hidden" name="id" value="::id::"/>
+<input type="hidden" name="id" value="::name_html::"/>
<table class="left_table">
<tr> <th> Name: </th>
<td> <input name="Name" size="50" /> </td> </tr>