All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aspectran.web.service.WebService Maven / Gradle / Ivy

There is a newer version: 8.1.5
Show newest version
/*
 * Copyright (c) 2008-2024 The Aspectran 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.aspectran.web.service;

import com.aspectran.core.context.ActivityContext;
import com.aspectran.core.service.CoreService;
import com.aspectran.utils.Assert;
import com.aspectran.utils.annotation.jsr305.NonNull;
import com.aspectran.utils.annotation.jsr305.Nullable;
import jakarta.servlet.ServletContext;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;

import java.io.IOException;

/**
 * The Interface WebService.
 *
 * 

Created: 2017. 10. 28.

*/ public interface WebService extends CoreService { /** * ServletContext attribute name used to obtain the root WebService object. */ String ROOT_WEB_SERVICE_ATTR_NAME = WebService.class.getName() + ".ROOT"; /** * The prefix of the ServletContext property name used to get the standalone WebService object. */ String STANDALONE_WEB_SERVICE_ATTR_PREFIX = WebService.class.getName() + ".STANDALONE:"; /** * Returns a reference to the {@link ServletContext} in which this WebService is running. * @return a {@link ServletContext} object, used by this WebService to interact with * its servlet container */ ServletContext getServletContext(); /** * Executes web activity. * @param request current HTTP servlet request * @param response current HTTP servlet response * @throws IOException If an error occurs during Activity execution */ void service(HttpServletRequest request, HttpServletResponse response) throws IOException; /** * Find the root web service from ServletContext. * @param servletContext ServletContext to find the root web service for * @return the root web service */ @NonNull static DefaultWebService findWebService(ServletContext servletContext) { DefaultWebService webService = findWebService(servletContext, ROOT_WEB_SERVICE_ATTR_NAME); if (webService == null) { throw new IllegalStateException("No root WebService found"); } return webService; } /** * Finds the root web service from the ServletContext and returns its ActivityContext. * @param servletContext ServletContext to find the root web service for * @return ActivityContext of root web service */ @NonNull static ActivityContext findActivityContext(ServletContext servletContext) { return findWebService(servletContext).getActivityContext(); } /** * Finds the standalone web service from the ServletContext and returns its ActivityContext. * @param servlet the servlet * @return ActivityContext of standalone web service */ @NonNull static ActivityContext findActivityContext(HttpServlet servlet) { Assert.notNull(servlet, "servlet must not be null"); ServletContext servletContext = servlet.getServletContext(); String attrName = STANDALONE_WEB_SERVICE_ATTR_PREFIX + servlet.getServletName(); DefaultWebService webService = findWebService(servletContext, attrName); if (webService != null) { return webService.getActivityContext(); } else { return findActivityContext(servletContext); } } /** * Find the root web service from ServletContext. * @param servletContext ServletContext to find the root web service for * @param attrName the name of the ServletContext attribute to look for * @return the root web service */ @Nullable private static DefaultWebService findWebService(@NonNull ServletContext servletContext, String attrName) { Object attr = servletContext.getAttribute(attrName); if (attr == null) { return null; } if (!(attr instanceof DefaultWebService defaultWebService)) { throw new IllegalStateException("Context attribute [" + attr + "] is not of type [" + DefaultWebService.class.getName() + "]"); } return defaultWebService; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy