X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=scripts%2Frestore.ml;h=471b8fcd8d98e43909e093f5a2e4afc35f47c22e;hb=f303d3e2bc355bdca4147d21441d6a13d4748d1a;hp=64b5f47f531311fbba7682af5e4c43385417ffce;hpb=714e5e5b4b585da1eca55274e3903ee9a1dbf0d6;p=cocanwiki.git diff --git a/scripts/restore.ml b/scripts/restore.ml index 64b5f47..471b8fc 100644 --- a/scripts/restore.ml +++ b/scripts/restore.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: restore.ml,v 1.2 2004/09/07 13:40:10 rich Exp $ + * $Id: restore.ml,v 1.9 2004/09/24 15:53:57 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. *) open Apache @@ -9,14 +24,12 @@ open Registry open Cgi open Printf -open Merjisforwiki - open Cocanwiki open Cocanwiki_ok open Cocanwiki_diff open Cocanwiki_emailnotify -let run r (q : cgi) (dbh : Dbi.connection) (hostid, hostname, _) _ = +let run r (q : cgi) (dbh : Dbi.connection) hostid {hostname = hostname} user = let version = int_of_string (q#param "version") in let page = q#param "page" in @@ -26,6 +39,11 @@ let run r (q : cgi) (dbh : Dbi.connection) (hostid, hostname, _) _ = try `String (Connection.remote_ip (Request.connection r)) with Not_found -> `Null in + let logged_user = + match user with + | User (id, _, _) -> `Int id + | _ -> `Null in + (* Copy the old version of the page to be live. *) let sth = dbh#prepare_cached "select title, description, creation_date, redirect, css @@ -41,7 +59,9 @@ let run r (q : cgi) (dbh : Dbi.connection) (hostid, hostname, _) _ = | _ -> assert false in let sth = - dbh#prepare_cached "set constraints pages_redirect_cn deferred" in + dbh#prepare_cached + "set constraints pages_redirect_cn, sitemenu_url_cn, + page_emails_url_cn deferred" in sth#execute []; let sth = dbh#prepare_cached "update pages set url_deleted = url, @@ -51,10 +71,10 @@ let run r (q : cgi) (dbh : Dbi.connection) (hostid, hostname, _) _ = let sth = dbh#prepare_cached "insert into pages (hostid, url, title, description, creation_date, logged_ip, - redirect, css) - values (?, ?, ?, ?, ?, ?, ?, ?)" in + logged_user, redirect, css) + values (?, ?, ?, ?, ?, ?, ?, ?, ?)" in sth#execute [`Int hostid; `String page; title; description; - creation_date; logged_ip; redirect; css ]; + creation_date; logged_ip; logged_user; redirect; css ]; let pageid = sth#serial "pages_id_seq" in @@ -86,4 +106,4 @@ let run r (q : cgi) (dbh : Dbi.connection) (hostid, hostname, _) _ = q#redirect ("http://" ^ hostname ^ "/" ^ page) let () = - register_script run + register_script ~restrict:[CanEdit] run