X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=scripts%2Fadmin%2Fcreate_host_form.ml;h=6b559271c9e392a772e4ec9cf6727c7a1fb859f2;hb=d393f7e88c96b944d447a959935cfe84722a72b7;hp=777bf7e583eebff0c52285c4cc101f7c8887da05;hpb=4e3e7c6443e7dbe1570e8a2c18a71e5d4f5c8d89;p=cocanwiki.git diff --git a/scripts/admin/create_host_form.ml b/scripts/admin/create_host_form.ml index 777bf7e..6b55927 100644 --- a/scripts/admin/create_host_form.ml +++ b/scripts/admin/create_host_form.ml @@ -1,7 +1,22 @@ -(* COCANWIKI scripts. +(* COCANWIKI - a wiki written in Objective CAML. * Written by Richard W.M. Jones . * Copyright (C) 2004 Merjis Ltd. - * $Id: create_host_form.ml,v 1.3 2004/09/08 15:46:53 rich Exp $ + * $Id: create_host_form.ml,v 1.5 2004/09/25 11:45:59 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 + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + * Boston, MA 02111-1307, USA. * * NB. Because there might not be any hosts existing when this Wiki * is created, this is not a normal Cocanwiki.register_script script. @@ -17,7 +32,20 @@ let template = Cocanwiki_template._get_template "admin/create_host_form.html" let run r = let q = new cgi r in - (* let dbh = Cocanwiki._get_dbh r in *) + let dbh = Cocanwiki._get_dbh r in + + (* Get the template hosts. *) + let sth = dbh#prepare_cached "select id, canonical_hostname from hosts + where is_template order by 2" in + sth#execute []; + + let table = sth#map (function [`Int id; `String canonical_hostname] -> + [ "id", Template.VarString (string_of_int id); + "canonical_hostname", + Template.VarString canonical_hostname ] + | _ -> assert false) in + template#table "templates" table; + q#template template let () =