Project

General

Profile

1 5211 jones
/**
2
 *  '$RCSfile$'
3
 *  Copyright: 2000 Regents of the University of California and the
4
 *              National Center for Ecological Analysis and Synthesis
5
 *
6
 *   '$Author: Serhan AKIN $'
7
 *     '$Date: 2009-06-13 13:28:21 +0300  $'
8
 *
9
 * This program is free software; you can redistribute it and/or modify
10
 * it under the terms of the GNU General Public License as published by
11
 * the Free Software Foundation; either version 2 of the License, or
12
 * (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with this program; if not, write to the Free Software
21
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
22
 */
23
package edu.ucsb.nceas.metacat.restservice;
24
25
import java.io.IOException;
26
27
import javax.servlet.ServletConfig;
28
import javax.servlet.ServletException;
29
import javax.servlet.http.HttpServlet;
30
import javax.servlet.http.HttpServletRequest;
31
import javax.servlet.http.HttpServletResponse;
32
33
import org.apache.log4j.Logger;
34
35
/**
36
 * Metacat implemantation of Earthgrid (Ecogrid) REST API as a servlet. In each request
37 6267 leinfelder
 * REST Servlet initialize a D1ResourceHandler object and then D1ResourceHandler object
38 5211 jones
 * handles with request and writes approriate response.
39
 *
40
 */
41 6267 leinfelder
public class D1RestServlet extends HttpServlet {
42 5211 jones
43 6247 leinfelder
    protected Logger logMetacat;
44 6267 leinfelder
    protected D1ResourceHandler handler;
45 5211 jones
46
    /**
47 6247 leinfelder
     * Subclasses should override this method to provide the appropriate handler subclass
48
     * @param request
49
     * @param response
50
     * @return
51
     * @throws ServletException
52
     * @throws IOException
53
     */
54 6267 leinfelder
    protected D1ResourceHandler createHandler(HttpServletRequest request, HttpServletResponse response)
55 6247 leinfelder
		throws ServletException, IOException {
56 6267 leinfelder
	    D1ResourceHandler handler = new D1ResourceHandler(getServletContext(), request, response);
57 6247 leinfelder
	    return handler;
58
	}
59
60
    /**
61 5211 jones
     * Initalize servlet by setting logger
62
     */
63
    @Override
64
    public void init(ServletConfig config) throws ServletException {
65
        logMetacat = Logger.getLogger(this.getClass());
66
        super.init(config);
67
    }
68
69
    /** Handle "GET" method requests from HTTP clients */
70
    @Override
71
    protected void doGet(HttpServletRequest request,
72
            HttpServletResponse response) throws ServletException, IOException {
73
        System.out.println("HTTP Verb: GET");
74 10202 tao
        logMetacat.info("D1RestServlet.doGet - HTTP Verb: GET");
75 6247 leinfelder
        handler = createHandler(request, response);
76 6267 leinfelder
        handler.handle(D1ResourceHandler.GET);
77 5211 jones
    }
78
79
    /** Handle "POST" method requests from HTTP clients */
80
    @Override
81
    protected void doPost(HttpServletRequest request,
82
            HttpServletResponse response) throws ServletException, IOException {
83
        System.out.println("HTTP Verb: POST");
84 10202 tao
        logMetacat.info("D1RestServlet.doPost - HTTP Verb: POST");
85 6247 leinfelder
        handler = createHandler(request, response);
86 6267 leinfelder
        handler.handle(D1ResourceHandler.POST);
87 5211 jones
    }
88
89
    /** Handle "DELETE" method requests from HTTP clients */
90
    @Override
91
    protected void doDelete(HttpServletRequest request,
92
            HttpServletResponse response) throws ServletException, IOException {
93
        System.out.println("HTTP Verb: DELETE");
94 10202 tao
        logMetacat.info("D1RestServlet.doDelete - HTTP Verb: DELETE");
95 6247 leinfelder
        handler = createHandler(request, response);
96 6267 leinfelder
        handler.handle(D1ResourceHandler.DELETE);
97 5211 jones
    }
98
99
    /** Handle "PUT" method requests from HTTP clients */
100
    @Override
101
    protected void doPut(HttpServletRequest request,
102
            HttpServletResponse response) throws ServletException, IOException {
103
        System.out.println("HTTP Verb: PUT");
104 10202 tao
        logMetacat.info("D1RestServlet.doPut - HTTP Verb: PUT");
105 6247 leinfelder
        handler = createHandler(request, response);
106 6267 leinfelder
        handler.handle(D1ResourceHandler.PUT);
107 5211 jones
    }
108
109 5651 berkley
    /** Handle "PUT" method requests from HTTP clients */
110
    @Override
111
    protected void doHead(HttpServletRequest request,
112
            HttpServletResponse response) throws ServletException, IOException {
113
        System.out.println("HTTP Verb: HEAD");
114 10202 tao
        logMetacat.info("D1RestServlet.doHead - HTTP Verb: HEAD");
115 6247 leinfelder
        handler = createHandler(request, response);
116 6267 leinfelder
        handler.handle(D1ResourceHandler.HEAD);
117 5651 berkley
    }
118 5211 jones
}