/* * Copyright 2012 The Solmix Project * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.gnu.org/licenses/ * or see the FSF site: http://www.fsf.org. */ package org.solmix.web.internal; import static org.osgi.framework.Constants.SERVICE_ID; import static org.osgi.framework.Constants.SERVICE_PID; import java.util.Map; import javax.servlet.Servlet; import javax.servlet.ServletContext; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceReference; import org.solmix.api.request.SlxHttpServletRequest; import org.solmix.api.servlet.ServletManager; /** * * @author solmix.f@gmail.com * @version 110035 2012-4-16 */ public class ServletManagerImpl implements ServletManager { private BundleContext bundleContext; private Map<Servlet, String> servletMap; private ServletContext servletContext; private ServletManagerTracker tracker; private String servletPrifix; /** The list of property names checked by {@link #getName(ServiceReference)} */ private static final String[] NAME_PROPERTIES = { SERVLET_NAME, SERVICE_PID, SERVICE_ID }; public void init() { tracker = new ServletManagerTracker(bundleContext, this.servletContext); tracker.open(); } public void destroy() { if (tracker != null) tracker.close(); } /** * {@inheritDoc} * * @see org.solmix.api.servlet.ServletManager#resolveServlet(org.solmix.api.request.SlxHttpServletRequest) */ @Override public Servlet resolveServlet(SlxHttpServletRequest request) { String url = request.getPathInfo(); if (url != null && url.startsWith(servletPrifix)) { url = url.substring(servletPrifix.length()); } Servlet servlet = tracker.getServlet(url); return servlet == null ? tracker.getDefaultServlet() : servlet; } /** * {@inheritDoc} * * @see org.solmix.api.servlet.ServletManager#resolveServlet(java.lang.String) */ @Override public Servlet resolveServlet(String requestStr) { Servlet servlet = tracker.getServlet(requestStr); return servlet == null ? tracker.getDefaultServlet() : servlet; } /** * @return the servletContext */ public ServletContext getServletContext() { return servletContext; } /** * @param servletContext the servletContext to set */ public void setServletContext(ServletContext servletContext) { this.servletContext = servletContext; } /** * @return the bundleContext */ public BundleContext getBundleContext() { return bundleContext; } /** * @param bundleContext the bundleContext to set */ public void setBundleContext(BundleContext bundleContext) { this.bundleContext = bundleContext; } /** * Looks for a name value in the service reference properties. See the class comment at the top for the list of * properties checked by this method. */ public static String getName(ServiceReference reference) { String servletName = null; for (int i = 0; i < NAME_PROPERTIES.length && (servletName == null || servletName.length() == 0); i++) { Object prop = reference.getProperty(NAME_PROPERTIES[i]); if (prop != null) { servletName = String.valueOf(prop); } } return servletName; } /** * @return the servletPrifix */ public String getServletPrifix() { return servletPrifix; } /** * @param servletPrifix the servletPrifix to set */ public void setServletPrifix(String servletPrifix) { this.servletPrifix = servletPrifix; } /** * {@inheritDoc} * * @see org.solmix.api.servlet.ServletManager#getDefault() */ @Override public Servlet getDefault() { return tracker.getDefaultServlet(); } }