Enhance HTTP call logging
[pithos-web-client] / src / gr / grnet / pithos / web / client / rest / PostRequest.java
1 /*
2  * Copyright 2011-2013 GRNET S.A. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or
5  * without modification, are permitted provided that the following
6  * conditions are met:
7  *
8  *   1. Redistributions of source code must retain the above
9  *      copyright notice, this list of conditions and the following
10  *      disclaimer.
11  *
12  *   2. Redistributions in binary form must reproduce the above
13  *      copyright notice, this list of conditions and the following
14  *      disclaimer in the documentation and/or other materials
15  *      provided with the distribution.
16  *
17  * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
18  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
21  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
24  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
27  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28  * POSSIBILITY OF SUCH DAMAGE.
29  *
30  * The views and conclusions contained in the software and
31  * documentation are those of the authors and should not be
32  * interpreted as representing official policies, either expressed
33  * or implied, of GRNET S.A.
34  */
35
36 package gr.grnet.pithos.web.client.rest;
37
38 import gr.grnet.pithos.web.client.Helpers;
39 import gr.grnet.pithos.web.client.Pithos;
40 import gr.grnet.pithos.web.client.Resource;
41
42 import java.util.HashMap;
43 import java.util.Map;
44
45 import com.google.gwt.core.client.GWT;
46 import com.google.gwt.core.client.Scheduler.ScheduledCommand;
47 import com.google.gwt.http.client.Request;
48 import com.google.gwt.http.client.RequestBuilder;
49 import com.google.gwt.http.client.RequestException;
50 import com.google.gwt.http.client.Response;
51
52 public abstract class PostRequest implements ScheduledCommand {
53
54     private String api;
55
56     protected String owner;
57
58     private String path;
59     
60     String data = "";
61
62     private Map<String, String> headers = new HashMap<String, String>();
63
64     public abstract void onSuccess(Resource result);
65
66     public abstract void onError(Throwable t);
67
68     public PostRequest(String api, String owner, String path) {
69         this.api = api;
70         this.owner = owner;
71         this.path = path;
72     }
73
74     public PostRequest(String api, String owner, String path, String data) {
75         this.api = api;
76         this.owner = owner;
77         this.path = path;
78         this.data = data;
79     }
80
81     @Override
82     public void execute() {
83         Pithos.LOG("POST ", api + owner + path);
84
85         RequestBuilder builder = new RequestBuilder(RequestBuilder.POST, api + owner + path);
86         Helpers.setHeaders(builder, headers);
87
88         try {
89             builder.sendRequest(data, new RestRequestCallback<Resource>(api + owner + path, Response.SC_ACCEPTED) {
90                 @Override
91                 public void onSuccess(Resource object) {
92                     PostRequest.this.onSuccess(object);
93                 }
94
95                 @Override
96                 public Resource deserialize(Response response) {
97                     return Resource.createFromResponse(Resource.class, owner, response, null);
98                 }
99
100                 @Override
101                 public void onError(Request request, Throwable throwable) {
102                     PostRequest.this.onError(throwable);
103                 }
104
105                                 @Override
106                                 public void onUnauthorized(Response response) {
107                                         PostRequest.this.onUnauthorized(response);
108                                 }
109             });
110         }
111         catch (RequestException e) {
112                 Pithos.LOG(e);
113         }
114     }
115
116     protected abstract void onUnauthorized(Response response);
117
118         public void setHeader(String header, String value) {
119         headers.put(header, value);
120     }
121 }