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

org.apiaddicts.apitools.dosonarapi.api.PathUtils Maven / Gradle / Ivy

/*
 * doSonarAPI: SonarQube OpenAPI Plugin
 * Copyright (C) 2021-2022 Apiaddicts
 * contacta AT apiaddicts DOT org
 *
 * This program 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 3 of the License, or (at your option) any later version.
 *
 * This program 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 should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 */
package org.apiaddicts.apitools.dosonarapi.api;

import java.util.function.Predicate;
import java.util.regex.Pattern;

public class PathUtils {
  public static final Pattern SPINAL_CASE_PATTERN = Pattern.compile("[a-z0-9-]+");

  public static boolean isVariable(String fragment) {
    return fragment.startsWith("{") && fragment.endsWith("}");
  }

  private PathUtils() {
    // Hidden utility type constructor
  }

  public static boolean checkPath(String path, Predicate segmentChecker) {
    for (String fragment : path.split("/")) {
      if (fragment.isEmpty() || isVariable(fragment)) {
        continue;
      }
      if (!segmentChecker.test(fragment)) {
        return false;
      }
    }
    return true;
  }

  public static boolean isSpinalCase(String fragment) {
    return SPINAL_CASE_PATTERN.matcher(fragment).matches();
  }

  /**
   * A resource path is a path that does not end with a variable.
   * Examples:
   * 
    *
  • {@code /some/parrots/{parrotId}} is not resource
  • *
  • {@code /some/parrots/{parrotId}} is not a resource
  • *
  • {@code /some/parrots/{parrotId}/head-color} is a resource
  • *
* @param path the path to examine * @return true if the path is a resource path */ public static boolean isResourcePath(String path) { String[] fragments = path.split("/"); if (fragments.length == 0) { return true; } return !isVariable(fragments[fragments.length - 1]); } public static String terminalSegment(String path) { path = trimTrailingSlash(path); String[] split = path.split("/"); return split[split.length - 1]; } public static String trimTrailingSlash(String path) { if (path.endsWith("/")) { return path.substring(0, path.length() - 1); } else { return path; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy