src/main/java/de/uapcore/lightpit/Functions.java

Wed, 13 May 2020 21:10:23 +0200

author
Mike Becker <universe@uap-core.de>
date
Wed, 13 May 2020 21:10:23 +0200
changeset 45
cc7f082c5ef3
parent 34
824d4042c857
child 47
57cfb94ab99f
permissions
-rw-r--r--

simplifies menu generation, adds submenus and removes VersionsModule (versions will be part of the ProjectsModule)

     1 /*
     2  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
     3  *
     4  * Copyright 2018 Mike Becker. All rights reserved.
     5  *
     6  * Redistribution and use in source and binary forms, with or without
     7  * modification, are permitted provided that the following conditions are met:
     8  *
     9  *   1. Redistributions of source code must retain the above copyright
    10  *      notice, this list of conditions and the following disclaimer.
    11  *
    12  *   2. Redistributions in binary form must reproduce the above copyright
    13  *      notice, this list of conditions and the following disclaimer in the
    14  *      documentation and/or other materials provided with the distribution.
    15  *
    16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
    17  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
    18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
    19  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
    20  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
    21  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
    22  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
    23  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
    24  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
    25  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
    26  * POSSIBILITY OF SUCH DAMAGE.
    27  *
    28  */
    29 package de.uapcore.lightpit;
    31 import org.slf4j.Logger;
    32 import org.slf4j.LoggerFactory;
    34 import javax.servlet.ServletContext;
    35 import javax.servlet.http.HttpServletRequest;
    36 import java.util.Optional;
    38 /**
    39  * Contains common static functions.
    40  */
    41 public final class Functions {
    43     private static final Logger LOG = LoggerFactory.getLogger(Functions.class);
    45     public static Optional<String[]> availableLanguages(ServletContext ctx) {
    46         return Optional.ofNullable(ctx.getInitParameter(Constants.CTX_ATTR_LANGUAGES)).map((x) -> x.split("\\s*,\\s*"));
    47     }
    49     public static String enforceExt(String filename, String ext) {
    50         return filename.endsWith(ext) ? filename : filename + ext;
    51     }
    53     public static String jspPath(String filename) {
    54         return enforceExt(Constants.JSP_PATH_PREFIX + filename, ".jsp");
    55     }
    57     public static String dynFragmentPath(String filename) {
    58         return enforceExt(Constants.DYN_FRAGMENT_PATH_PREFIX + filename, ".jsp");
    59     }
    61     public static String fqn(String base, String name) {
    62         return base + "." + name;
    63     }
    65     public static String fqn(Class<?> clazz, String name) {
    66         return fqn(clazz.getName(), name);
    67     }
    69     public static String fullPath(LightPITModule module, RequestMapping mapping) {
    70         StringBuilder sb = new StringBuilder();
    71         sb.append(module.modulePath());
    72         sb.append('/');
    73         if (!mapping.requestPath().isEmpty()) {
    74             sb.append(mapping.requestPath().isEmpty());
    75             sb.append('/');
    76         }
    77         return sb.toString();
    78     }
    80     public static String fullPath(HttpServletRequest req) {
    81         return req.getServletPath() + Optional.ofNullable(req.getPathInfo()).orElse("");
    82     }
    84     /**
    85      * Returns the module path of the given LightPIT Servlet module.
    86      * <p>
    87      * If you specify a malformed LightPIT servlet, which does not have a module
    88      * annotation, the path to the <code>/error/404.html</code> page is returned.
    89      *
    90      * @param clazz the servlet class
    91      * @return the module path
    92      */
    93     public static String modulePathOf(Class<? extends AbstractLightPITServlet> clazz) {
    94         Optional<LightPITModule> moduleInfo = Optional.ofNullable(clazz.getAnnotation(LightPITModule.class));
    95         if (moduleInfo.isPresent()) {
    96             return moduleInfo.get().modulePath();
    97         } else {
    98             LOG.warn(
    99                     "{} is a LightPIT Servlet but is missing the module annotation.",
   100                     clazz.getName()
   101             );
   102             return "/error/404.html";
   103         }
   104     }
   106     /**
   107      * This class is not instantiatable.
   108      */
   109     private Functions() {
   110     }
   111 }

mercurial