RestApiServlet: Add AcceptsDelete direct on collection resource
In some rare cases we need to accept delete direct on collection resource. One use case is delete change edit: DELETE /changes/<id>/edit Note that change edit is itself a collection resource. Change-Id: Ib3b99e91d1729e7d9a30d0fc939f531f1bf75238
This commit is contained in:
		| @@ -0,0 +1,35 @@ | |||||||
|  | // Copyright (C) 2014 The Android Open Source Project | ||||||
|  | // | ||||||
|  | // Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | // you may not use this file except in compliance with the License. | ||||||
|  | // You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | // http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | // Unless required by applicable law or agreed to in writing, software | ||||||
|  | // distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | // See the License for the specific language governing permissions and | ||||||
|  | // limitations under the License. | ||||||
|  |  | ||||||
|  | package com.google.gerrit.extensions.restapi; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Optional interface for {@link RestCollection}. | ||||||
|  |  * <p> | ||||||
|  |  * Collections that implement this interface can accept a {@code DELETE} directly | ||||||
|  |  * on the collection itself. | ||||||
|  |  */ | ||||||
|  | public interface AcceptsDelete<P extends RestResource> { | ||||||
|  |   /** | ||||||
|  |    * Handle deletion of a child resource by DELETE on the collection. | ||||||
|  |    * | ||||||
|  |    * @param parent parent collection handle. | ||||||
|  |    * @param id id of the resource being created (optional). | ||||||
|  |    * @return a view to perform the deletion. | ||||||
|  |    * @throws RestApiException the view cannot be constructed. | ||||||
|  |    */ | ||||||
|  |   <I> RestModifyView<P, I> delete(P parent, IdString id) | ||||||
|  |       throws RestApiException; | ||||||
|  | } | ||||||
| @@ -21,6 +21,7 @@ import static java.nio.charset.StandardCharsets.UTF_8; | |||||||
| import static javax.servlet.http.HttpServletResponse.SC_BAD_REQUEST; | import static javax.servlet.http.HttpServletResponse.SC_BAD_REQUEST; | ||||||
| import static javax.servlet.http.HttpServletResponse.SC_CONFLICT; | import static javax.servlet.http.HttpServletResponse.SC_CONFLICT; | ||||||
| import static javax.servlet.http.HttpServletResponse.SC_CREATED; | import static javax.servlet.http.HttpServletResponse.SC_CREATED; | ||||||
|  | import static javax.servlet.http.HttpServletResponse.SC_NO_CONTENT; | ||||||
| import static javax.servlet.http.HttpServletResponse.SC_FORBIDDEN; | import static javax.servlet.http.HttpServletResponse.SC_FORBIDDEN; | ||||||
| import static javax.servlet.http.HttpServletResponse.SC_INTERNAL_SERVER_ERROR; | import static javax.servlet.http.HttpServletResponse.SC_INTERNAL_SERVER_ERROR; | ||||||
| import static javax.servlet.http.HttpServletResponse.SC_METHOD_NOT_ALLOWED; | import static javax.servlet.http.HttpServletResponse.SC_METHOD_NOT_ALLOWED; | ||||||
| @@ -50,6 +51,7 @@ import com.google.gerrit.common.Nullable; | |||||||
| import com.google.gerrit.extensions.registration.DynamicItem; | import com.google.gerrit.extensions.registration.DynamicItem; | ||||||
| import com.google.gerrit.extensions.registration.DynamicMap; | import com.google.gerrit.extensions.registration.DynamicMap; | ||||||
| import com.google.gerrit.extensions.restapi.AcceptsCreate; | import com.google.gerrit.extensions.restapi.AcceptsCreate; | ||||||
|  | import com.google.gerrit.extensions.restapi.AcceptsDelete; | ||||||
| import com.google.gerrit.extensions.restapi.AcceptsPost; | import com.google.gerrit.extensions.restapi.AcceptsPost; | ||||||
| import com.google.gerrit.extensions.restapi.AuthException; | import com.google.gerrit.extensions.restapi.AuthException; | ||||||
| import com.google.gerrit.extensions.restapi.BadRequestException; | import com.google.gerrit.extensions.restapi.BadRequestException; | ||||||
| @@ -254,6 +256,10 @@ public class RestApiServlet extends HttpServlet { | |||||||
|             @SuppressWarnings("unchecked") |             @SuppressWarnings("unchecked") | ||||||
|             AcceptsPost<RestResource> ac = (AcceptsPost<RestResource>) c; |             AcceptsPost<RestResource> ac = (AcceptsPost<RestResource>) c; | ||||||
|             viewData = new ViewData(null, ac.post(rsrc)); |             viewData = new ViewData(null, ac.post(rsrc)); | ||||||
|  |           } else if (c instanceof AcceptsDelete && "DELETE".equals(req.getMethod())) { | ||||||
|  |             @SuppressWarnings("unchecked") | ||||||
|  |             AcceptsDelete<RestResource> ac = (AcceptsDelete<RestResource>) c; | ||||||
|  |             viewData = new ViewData(null, ac.delete(rsrc, null)); | ||||||
|           } else { |           } else { | ||||||
|             throw new MethodNotAllowedException(); |             throw new MethodNotAllowedException(); | ||||||
|           } |           } | ||||||
| @@ -273,6 +279,13 @@ public class RestApiServlet extends HttpServlet { | |||||||
|               AcceptsCreate<RestResource> ac = (AcceptsCreate<RestResource>) c; |               AcceptsCreate<RestResource> ac = (AcceptsCreate<RestResource>) c; | ||||||
|               viewData = new ViewData(viewData.pluginName, ac.create(rsrc, id)); |               viewData = new ViewData(viewData.pluginName, ac.create(rsrc, id)); | ||||||
|               status = SC_CREATED; |               status = SC_CREATED; | ||||||
|  |             } else if (c instanceof AcceptsDelete | ||||||
|  |                 && path.isEmpty() | ||||||
|  |                 && "DELETE".equals(req.getMethod())) { | ||||||
|  |               @SuppressWarnings("unchecked") | ||||||
|  |               AcceptsDelete<RestResource> ac = (AcceptsDelete<RestResource>) c; | ||||||
|  |               viewData = new ViewData(viewData.pluginName, ac.delete(rsrc, id)); | ||||||
|  |               status = SC_NO_CONTENT; | ||||||
|             } else { |             } else { | ||||||
|               throw e; |               throw e; | ||||||
|             } |             } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 David Ostrovsky
					David Ostrovsky