89ee6380f96d477ebf165649190159cdb8e58804
[perl4caml.git] / wrappers / pl_HTTP_Request_Common.ml
1 (** Wrapper around Perl [HTTP::Request::Common] class. *)
2 (*  Copyright (C) 2003 Merjis Ltd.
3
4     This library is free software; you can redistribute it and/or
5     modify it under the terms of the GNU Library General Public
6     License as published by the Free Software Foundation; either
7     version 2 of the License, or (at your option) any later version.
8
9     This library is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12     Library General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this library; see the file COPYING.  If not, write to
16     the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17     Boston, MA 02111-1307, USA.
18
19     $Id: pl_HTTP_Request_Common.ml,v 1.2 2008-03-01 13:02:21 rich Exp $
20   *)
21
22 open Perl
23
24 open Pl_HTTP_Request
25
26 let _ = eval "use HTTP::Request::Common"
27
28 let get, head, put =
29   let dofn fn url headers =
30     let args =
31       sv_of_string url ::
32         List.fold_right (fun (k, v) rest ->
33                            sv_of_string k :: sv_of_string v :: rest)
34         headers [] in
35     new http_request (call ~fn args)
36   in
37   let get = dofn "GET" in
38   let head = dofn "HEAD" in
39   let put = dofn "PUT" in
40   get, head, put
41
42 let post url ?form headers =
43   let hv = hv_empty () in
44   (match form with
45      | None -> ()
46      | Some xs -> List.iter (fun (k, v) -> hv_set hv k (sv_of_string v)) xs);
47   let args =
48     sv_of_string url :: hashref hv ::
49       List.fold_right (fun (k, v) rest ->
50                          sv_of_string k :: sv_of_string v :: rest)
51       headers [] in
52   new http_request (call ~fn:"POST" args)