package com.epam.wilma.webapp.config.servlet.stub.upload;
/*==========================================================================
Copyright 2013-2017 EPAM Systems
This file is part of Wilma.
Wilma is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Wilma is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Wilma. If not, see <http://www.gnu.org/licenses/>.
===========================================================================*/
import com.epam.wilma.domain.exception.SystemException;
import com.epam.wilma.domain.stubconfig.sequence.SequenceDescriptorHolder;
import com.epam.wilma.router.RoutingService;
import com.epam.wilma.stubconfig.StubDescriptorFactory;
import com.epam.wilma.webapp.helper.UrlAccessLogMessageAssembler;
import com.epam.wilma.webapp.service.command.NewStubDescriptorCommand;
import com.epam.wilma.webapp.service.external.ServiceMap;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import javax.servlet.ServletException;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
/**
* Servlet for uploading an external stub configuration file.
*
* @author Tunde_Kovacs
*/
@Component
public class ExternalStubConfigUploadServlet extends HttpServlet {
private static final Logger LOGGER = LoggerFactory.getLogger(ExternalStubConfigUploadServlet.class);
@Autowired
private UrlAccessLogMessageAssembler urlAccessLogMessageAssembler;
@Autowired
private StubDescriptorFactory stubConfigurationBuilder;
@Autowired
private RoutingService routingService;
@Autowired
private SequenceDescriptorHolder sequenceDescriptorHolder;
@Autowired
private ServiceMap serviceMap;
@Override
protected void doGet(final HttpServletRequest request, final HttpServletResponse response) throws ServletException, IOException {
PrintWriter writer = response.getWriter();
if (request.getContentLength() > 0) {
ServletInputStream inputStream = request.getInputStream();
try {
routingService.performModification(new NewStubDescriptorCommand(inputStream, stubConfigurationBuilder, sequenceDescriptorHolder));
serviceMap.detectServices();
LOGGER.info(urlAccessLogMessageAssembler.assembleMessage(request, "New stub configuration was uploaded to Wilma."));
} catch (ClassNotFoundException | NoClassDefFoundError | SystemException e) {
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
writer.write("Stub config uploading failed: " + e.getMessage());
LOGGER.warn(urlAccessLogMessageAssembler.assembleMessage(request, "Stub config uploading failed: " + e.getMessage()), e);
}
} else {
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
writer.write("Please provide a non-empty stub configuration!");
}
}
@Override
protected void doPost(final HttpServletRequest req, final HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}
}