X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=scripts%2Fcontact.ml;h=16db8709006965e56a8dd2cf5e223504d778eb22;hb=89e8d5757ca111d16ce3dfcc1ce4f2c00a119c85;hp=a13f60e80804edac87e4342c325a3c3f65a2fcd8;hpb=619782929c11102f75892758fd94772bc747dfb0;p=cocanwiki.git diff --git a/scripts/contact.ml b/scripts/contact.ml index a13f60e..16db870 100644 --- a/scripts/contact.ml +++ b/scripts/contact.ml @@ -1,7 +1,7 @@ (* COCANWIKI - a wiki written in Objective CAML. * Written by Richard W.M. Jones . * Copyright (C) 2004 Merjis Ltd. - * $Id: contact.ml,v 1.2 2004/09/17 15:15:50 rich Exp $ + * $Id: contact.ml,v 1.7 2004/10/30 10:16:09 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 @@ -36,25 +36,28 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid {hostname = hostname} user = let fail msg = error ~back_button:true ~title:"Bad form" q (msg ^ " Please contact the owner of the site by email."); - raise CgiExit + 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 @@ -114,7 +117,7 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid {hostname = hostname} user = let username = match user with Anonymous -> "anonymous" - | User (userid, username, _) -> + | User (userid, username, _, _) -> sprintf "%s (%d)" username userid in template#set "ip" ip; @@ -154,4 +157,4 @@ let run r (q : cgi) (dbh : Dbi.connection) hostid {hostname = hostname} user = q "An email was sent and you should receive a reply shortly." let () = - register_script run + register_script ~restrict:[CanView] run