/containers/jersey-servlet-core/src/main/java/org/glassfish/jersey/servlet/internal/Utils.java

http://github.com/jersey/jersey · Java · 116 lines · 30 code · 10 blank · 76 comment · 1 complexity · 8dd1025eae1056cec15e1be5b5f9a340 MD5 · raw file

  1. /*
  2. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
  3. *
  4. * Copyright (c) 2014-2017 Oracle and/or its affiliates. All rights reserved.
  5. *
  6. * The contents of this file are subject to the terms of either the GNU
  7. * General Public License Version 2 only ("GPL") or the Common Development
  8. * and Distribution License("CDDL") (collectively, the "License"). You
  9. * may not use this file except in compliance with the License. You can
  10. * obtain a copy of the License at
  11. * https://oss.oracle.com/licenses/CDDL+GPL-1.1
  12. * or LICENSE.txt. See the License for the specific
  13. * language governing permissions and limitations under the License.
  14. *
  15. * When distributing the software, include this License Header Notice in each
  16. * file and include the License file at LICENSE.txt.
  17. *
  18. * GPL Classpath Exception:
  19. * Oracle designates this particular file as subject to the "Classpath"
  20. * exception as provided by Oracle in the GPL Version 2 section of the License
  21. * file that accompanied this code.
  22. *
  23. * Modifications:
  24. * If applicable, add the following below the License Header, with the fields
  25. * enclosed by brackets [] replaced by your own identifying information:
  26. * "Portions Copyright [year] [name of copyright owner]"
  27. *
  28. * Contributor(s):
  29. * If you wish your version of this file to be governed by only the CDDL or
  30. * only the GPL Version 2, indicate your decision by adding "[Contributor]
  31. * elects to include this software in this distribution under the [CDDL or GPL
  32. * Version 2] license." If you don't indicate a single choice of license, a
  33. * recipient has the option to distribute your version of this file under
  34. * either the CDDL, the GPL Version 2 or to extend the choice of license to
  35. * its licensees as provided above. However, if you add GPL Version 2 code
  36. * and therefore, elected the GPL Version 2 license, then the option applies
  37. * only if the new code is made subject to such option by the copyright
  38. * holder.
  39. */
  40. package org.glassfish.jersey.servlet.internal;
  41. import java.util.Enumeration;
  42. import java.util.HashMap;
  43. import java.util.Map;
  44. import javax.servlet.ServletContext;
  45. import org.glassfish.jersey.server.ResourceConfig;
  46. /**
  47. * Utility class.
  48. *
  49. * @author Michal Gajdos
  50. */
  51. public final class Utils {
  52. /**
  53. * Internal {@link javax.servlet.ServletContext servlet context} attribute name under which an instance of
  54. * {@link org.glassfish.jersey.server.ResourceConfig resource config} can be stored. The instance is later used to initialize
  55. * servlet in {@link org.glassfish.jersey.servlet.WebConfig} instead of creating a new one.
  56. */
  57. private static final String RESOURCE_CONFIG = "jersey.config.servlet.internal.resourceConfig";
  58. /**
  59. * Store {@link org.glassfish.jersey.server.ResourceConfig resource config} as an attribute of given
  60. * {@link javax.servlet.ServletContext servlet context}. If {@code config} is {@code null} then the previously stored value
  61. * (if any) is removed. The {@code configName} is used as an attribute name suffix.
  62. *
  63. * @param config resource config to be stored.
  64. * @param context servlet context to store the config in.
  65. * @param configName name or id of the resource config.
  66. */
  67. public static void store(final ResourceConfig config, final ServletContext context, final String configName) {
  68. final String attributeName = RESOURCE_CONFIG + "_" + configName;
  69. context.setAttribute(attributeName, config);
  70. }
  71. /**
  72. * Load {@link org.glassfish.jersey.server.ResourceConfig resource config} from given
  73. * {@link javax.servlet.ServletContext servlet context}. If found then the resource config is also removed from servlet
  74. * context. The {@code configName} is used as an attribute name suffix.
  75. *
  76. * @param context servlet context to load resource config from.
  77. * @param configName name or id of the resource config.
  78. * @return previously stored resource config or {@code null} if no resource config has been stored.
  79. */
  80. public static ResourceConfig retrieve(final ServletContext context, final String configName) {
  81. final String attributeName = RESOURCE_CONFIG + "_" + configName;
  82. final ResourceConfig config = (ResourceConfig) context.getAttribute(attributeName);
  83. context.removeAttribute(attributeName);
  84. return config;
  85. }
  86. /**
  87. * Extract context params from {@link ServletContext}.
  88. *
  89. * @param servletContext actual servlet context.
  90. * @return map representing current context parameters.
  91. */
  92. public static Map<String, Object> getContextParams(final ServletContext servletContext) {
  93. final Map<String, Object> props = new HashMap<>();
  94. final Enumeration names = servletContext.getAttributeNames();
  95. while (names.hasMoreElements()) {
  96. final String name = (String) names.nextElement();
  97. props.put(name, servletContext.getAttribute(name));
  98. }
  99. return props;
  100. }
  101. /**
  102. * Prevents instantiation.
  103. */
  104. private Utils() {
  105. }
  106. }