rest-api/src/jetbrains/buildServer/server/rest/RequestPathTransformInfo.java (67 lines of code) (raw):

/* * Copyright 2000-2024 JetBrains s.r.o. * * 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 jetbrains.buildServer.server.rest; import java.util.Collections; import java.util.Map; import java.util.Set; import jetbrains.buildServer.server.rest.jersey.provider.annotated.JerseyInjectable; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import org.springframework.stereotype.Component; /** * @author Yegor.Yarko * Date: 15.11.2009 */ @Component @JerseyInjectable public class RequestPathTransformInfo implements PathTransformator { @NotNull private Map<String, String> myPathMapping; public RequestPathTransformInfo() { } public void setPathMapping(@Nullable final Map<String, String> pathMapping) { myPathMapping = pathMapping != null ? pathMapping : Collections.emptyMap(); } @Override public String toString() { return "Path mapping: " + myPathMapping; } /** * <pre> * Examples: * (abacaba, [a, ab, ba, aba, ca]) -> "aba" * (abacaba, [foo, bar]) -> "" * (abacaba, []) -> "" * (abacaba, [abacaba, abacaba]) -> "abacaba" * </pre> * * If {@code path} contains multiple {@code substrings} then any of then could be returned. */ @NotNull private static String getLargestMatchingSubstring(@NotNull final String path, final Set<String> substrings) { String result = ""; for (String substring : substrings) { boolean matches = path.contains(substring); if (matches && result.length() < substring.length()) { result = substring; } } return result; } @NotNull public String getTransformedPath(@NotNull final String path) { String matching = getLargestMatchingSubstring(path, myPathMapping.keySet()); if (matching.length() == 0){ return path; } return replaceFirstSubstring(path, matching, myPathMapping.get(matching)); } private static String replaceFirstSubstring(final String s, final String from, final String to) { final int i = s.indexOf(from); return s.substring(0, i) + to + s.substring(i+ from.length()); } @NotNull public PathTransformator getReverseTransformator(@NotNull final String originalPath, final boolean prefixSupported) { final String matching = getLargestMatchingSubstring(originalPath, myPathMapping.keySet()); if (matching.length() == 0){ return path -> path; } final String prefix = prefixSupported ? originalPath.substring(0, originalPath.indexOf(matching)) : ""; final String prefixWithNewPart = prefix + myPathMapping.get(matching); return path -> { if (!path.startsWith(prefixWithNewPart)){ return path; //some wrong path } if (path.startsWith(prefix + matching)){ return path; //path already in due form. Should generally not happen, however } if (path.startsWith(matching)){ return prefix + path; //path already partly in due form. Should generally not happen, however } return prefix + matching + path.substring(prefixWithNewPart.length()); }; } }