1 (* COCANWIKI - a wiki written in Objective CAML.
2 * Written by Richard W.M. Jones <rich@merjis.com>.
3 * Copyright (C) 2004 Merjis Ltd.
4 * $Id: stats.ml,v 1.1 2004/09/23 15:16:21 rich Exp $
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; see the file COPYING. If not, write to
18 * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 * Boston, MA 02111-1307, USA.
28 open Cocanwiki_template
29 open Cocanwiki_server_settings
31 let run r (q : cgi) (dbh : Dbi.connection) hostid { hostname = hostname } _ =
32 let template = get_template dbh hostid "stats.html" in
34 let page = q#param "page" in
36 (* Get the stats_page. *)
38 match server_settings_stats_page dbh with
39 None -> failwith "no server_settings.stats_page set up for this server"
42 template#set "stats_page" stats_page;
44 (* Get the current business week. Tricky - because GregorianDate isn't
45 * around to help us, it's best to get the database to help us out.
47 * XXX This fails sometimes near New Year. Better to get GD into extlib
51 dbh#prepare_cached "select extract (year from current_date) :: int,
52 extract (week from current_date) :: int" in
55 match sth#fetch1 () with
56 [ `Int year; `Int week ] -> year, week
57 | _ -> assert false in
59 template#set "year" (string_of_int year);
60 template#set "week" (string_of_int week);
62 (* Standard hashing function which we also use in tools/rocket/analysis.ml *)
63 let hash s = Digest.to_hex (Digest.string s) in
65 let url = "/" ^ if page = "index" then "" else page in
68 template#set "page" page;
69 template#set "url" url;
70 template#set "hash" h;
71 template#set "hostname" hostname;
76 register_script ~restrict:[CanEdit] run