/*
* #%L
* ACS AEM Commons Bundle
* %%
* Copyright (C) 2013 Adobe
* %%
* 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.
* #L%
*/
package com.adobe.acs.commons.workflow.bulk.impl.servlets;
import com.adobe.acs.commons.workflow.bulk.BulkWorkflowEngine;
import org.apache.felix.scr.annotations.Reference;
import org.apache.felix.scr.annotations.sling.SlingServlet;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.servlets.SlingAllMethodsServlet;
import org.apache.sling.commons.json.JSONException;
import org.apache.sling.commons.json.JSONObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.ServletException;
import java.io.IOException;
@SlingServlet(
label = "ACS AEM Commons - Bulk Workflow Manager - Resume Servlet",
methods = { "POST" },
resourceTypes = { BulkWorkflowEngine.SLING_RESOURCE_TYPE },
selectors = { "resume" },
extensions = { "json" }
)
public class ResumeServlet extends SlingAllMethodsServlet {
private static final Logger log = LoggerFactory.getLogger(ResumeServlet.class);
@Reference
private BulkWorkflowEngine bulkWorkflowEngine;
@Override
protected final void doPost(SlingHttpServletRequest request, SlingHttpServletResponse response)
throws ServletException, IOException {
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
final JSONObject params;
try {
params = new JSONObject(request.getParameter("params"));
final long interval = params.optLong(BulkWorkflowEngine.KEY_INTERVAL, -1);
if (interval < 1) {
bulkWorkflowEngine.resume(request.getResource());
} else {
bulkWorkflowEngine.resume(request.getResource(), interval);
}
response.sendRedirect(request.getResourceResolver().map(request.getResource().getPath()) + ".status.json");
} catch (JSONException e) {
log.error("Could not resume Bulk Workflow due to: {}", e.getMessage());
HttpErrorUtil.sendJSONError(response, SlingHttpServletResponse.SC_INTERNAL_SERVER_ERROR,
"Could not resume Bulk Workflow.",
e.getMessage());
}
}
}