01: /***************************************************************
02: * This file is part of the [fleXive](R) project.
03: *
04: * Copyright (c) 1999-2007
05: * UCS - unique computing solutions gmbh (http://www.ucs.at)
06: * All rights reserved
07: *
08: * The [fleXive](R) project is free software; you can redistribute
09: * it and/or modify it under the terms of the GNU General Public
10: * License as published by the Free Software Foundation;
11: * either version 2 of the License, or (at your option) any
12: * later version.
13: *
14: * The GNU General Public License can be found at
15: * http://www.gnu.org/copyleft/gpl.html.
16: * A copy is found in the textfile GPL.txt and important notices to the
17: * license from the author are found in LICENSE.txt distributed with
18: * these libraries.
19: *
20: * This library is distributed in the hope that it will be useful,
21: * but WITHOUT ANY WARRANTY; without even the implied warranty of
22: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23: * GNU General Public License for more details.
24: *
25: * For further information about UCS - unique computing solutions gmbh,
26: * please see the company website: http://www.ucs.at
27: *
28: * For further information about [fleXive](R), please see the
29: * project website: http://www.flexive.org
30: *
31: *
32: * This copyright notice MUST APPEAR in all copies of the file!
33: ***************************************************************/package com.flexive.war.webdav;
34:
35: import javax.servlet.http.HttpServletRequest;
36: import javax.servlet.http.HttpServletResponse;
37: import java.io.IOException;
38:
39: /**
40: * Process a POST request for the specified resource.
41: * <p/>
42: * A PUT that would result in the creation of a resource without an appropriately scoped parent collection MUST
43: * fail with a 409 (Conflict).<br><br>
44: * Collections:<br>
45: * As defined in the HTTP/1.1 specification [RFC2068], the "PUT method requests that the enclosed entity be
46: * stored under the supplied Request-URI." Since submission of an entity representing a collection would implicitly
47: * encode creation and deletion of resources, this specification intentionally does not define a transmission format
48: * for creating a collection using PUT. Instead, the MKCOL method is defined to create collections.
49: * <br>
50: * When the PUT operation creates a new non-collection resource all ancestors MUST already exist. If all ancestors
51: * do not exist, the method MUST fail with a 409 (Conflict) status code. For example, if resource /a/b/c/d.html
52: * is to be created and /a/b/c/ does not exist, then the request must fail.
53: *
54: * @author Gregor Schober (gregor.schober@flexive.com), UCS - unique computing solutions gmbh (http://www.ucs.at)
55: * @version $Rev: 1 $
56: */
57: class OperationPut extends Operation {
58:
59: public OperationPut(HttpServletRequest req,
60: HttpServletResponse resp, boolean readonly) {
61: super (req, resp, readonly);
62: }
63:
64: void writeResponse() throws IOException {
65: int resultCode = FxWebDavServlet.getDavContext()
66: .createResource(request, path);
67: if (resultCode == FxWebDavStatus.SC_CREATED) {
68: response.setStatus(FxWebDavStatus.SC_CREATED);
69: } else {
70: response.sendError(resultCode,
71: "Failed to create the resource");
72: }
73: }
74: }
|