2 * Written by Richard W.M. Jones <rich@merjis.com>.
3 * Copyright (C) 2004 Merjis Ltd.
4 * $Id: history.ml,v 1.6 2004/09/09 09:35:33 rich Exp $
13 open Cocanwiki_template
16 let run r (q : cgi) (dbh : Dbi.connection) hostid _ _ =
17 let template = get_template dbh hostid "history.html" in
19 let page = q#param "page" in
20 let page = if page = "" then "index" else page in
24 "select id, url, url_deleted, title, last_modified_date, logged_ip
26 where hostid = ? and (url = ? or url_deleted = ?)
27 order by last_modified_date desc" in
28 sth#execute [`Int hostid; `String page; `String page];
33 | [`Int version; `String url; _; `String title;
34 `Timestamp last_modified_date; logged_ip ] ->
35 let date = printable_date_time last_modified_date in
36 let has_logged_ip, logged_ip =
39 | `String ip -> true, ip
40 | _ -> assert false in
41 [ "version", Template.VarString (string_of_int version);
42 "url", Template.VarString url;
43 "title", Template.VarString title;
44 "last_modified_date", Template.VarString date;
45 "has_logged_ip", Template.VarConditional has_logged_ip;
46 "logged_ip", Template.VarString logged_ip;
47 "is_live", Template.VarConditional true ]
48 | [`Int version; `Null; `String url; `String title;
49 `Timestamp last_modified_date; logged_ip ] ->
50 let date = printable_date_time last_modified_date in
51 let has_logged_ip, logged_ip =
54 | `String ip -> true, ip
55 | _ -> assert false in
56 [ "version", Template.VarString (string_of_int version);
57 "url", Template.VarString url;
58 "title", Template.VarString title;
59 "last_modified_date", Template.VarString date;
60 "has_logged_ip", Template.VarConditional has_logged_ip;
61 "logged_ip", Template.VarString logged_ip;
62 "is_live", Template.VarConditional false ]
63 | _ -> assert false) in
65 template#table "history" table;
70 register_script ~restrict:[CanEdit] run