Statistics
| Branch: | Tag: | Revision:

root / web_client / src / gr / grnet / pithos / web / client / rest / RestCallback.java @ 58777026

History | View | Annotate | Download (3.2 kB)

1
/*
2
 * Copyright 2011 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
package gr.grnet.pithos.web.client.rest;
36

    
37
import com.google.gwt.http.client.Request;
38
import com.google.gwt.http.client.RequestCallback;
39
import com.google.gwt.http.client.Response;
40

    
41

    
42
public abstract class RestCallback  implements RequestCallback {
43

    
44
        private static final int HTTP_OK = 200;
45
        private String path;
46
        private int okcode = -1;
47

    
48
        public RestCallback(String aPath) {
49
                path = aPath;
50
        }
51

    
52
        public RestCallback(String aPath, int okCode) {
53
                path = aPath;
54
                okcode = okCode;
55
        }
56

    
57
        @Override
58
        public void onError(Request request, Throwable exception) {
59
                handleError(request, exception);
60
        }
61

    
62
        @Override
63
        public void onResponseReceived(Request request, Response response) {
64
                try {
65
                        if (okcode == -1 && response.getStatusCode() == HTTP_OK)
66
                                handleSuccess(deserialize(response));
67
                        //this one is only used for trash handling where empty trash has 201 status code
68
                        else if(okcode !=-1 && (response.getStatusCode() == okcode || response.getStatusCode() == HTTP_OK))
69
                                handleSuccess(deserialize(response));
70
                        else if(response.getStatusCode() == 403)
71
                                RestCommand.sessionExpired();
72
                        else {
73
                                String statusText = "";
74
                                String text = "";
75
                                // Ignore JavaScript errors caused by non-existent text.
76
                                try {
77
                                        statusText = response.getStatusText();
78
                                } catch (Exception e) {        }
79
                                try {
80
                                        text = response.getText();
81
                                } catch (Exception e) {        }
82
                                handleError(request, new RestException(path, response.getStatusCode(), statusText, text));
83
                        }
84
                } catch (Exception e) {
85
                        handleError(request,e);
86
                }
87
        }
88

    
89
        public abstract void handleSuccess(Object object);
90

    
91
        public abstract void handleError(Request request, Throwable exception);
92

    
93
        public abstract Object deserialize(Response response);
94

    
95
}