org.conqat.engine.service.shared.client.ServiceClientUris Maven / Gradle / Ivy
/*
* Copyright (c) CQSE GmbH
*
* 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 org.conqat.engine.service.shared.client;
import static org.conqat.lib.commons.collections.ListMap.fromNonEmptyPairs;
import java.util.List;
import org.conqat.engine.index.shared.CommitDescriptor;
import org.conqat.engine.index.shared.PublicProjectId;
import org.conqat.engine.service.shared.ServiceUtils;
import org.conqat.lib.commons.collections.ListMap;
import org.conqat.lib.commons.collections.Pair;
import org.conqat.lib.commons.string.StringUtils;
import org.conqat.lib.commons.uniformpath.UniformPath;
import org.conqat.lib.commons.version.Version;
/** Methods to build Teamscale service URIs. */
public class ServiceClientUris {
/** Prefix used to recognize projects. */
public static final String LEGACY_PROJECT_PREFIX = "p/";
/**
* Name of the boolean query parameter used to indicate recursive queries.
*/
public static final String RECURSIVE_PARAMETER = "recursive";
/** Baselines parameter for findings service. */
public static final String BASELINE_PARAMETER = "baseline";
/** Include changed code findings parameter. */
public static final String INCLUDE_CHANGED_CODE_FINDINGS_PARAMETER = "include-changed-code-findings";
/** Principal metric index parameter for metric distribution service */
public static final String PRINCIPAL_METRIC_INDEX_PARAMETER = "principal-metric-index";
/** Metric index parameter for metric distribution service */
public static final String METRIC_INDEXES_PARAMETER = "metric-indexes";
/** Boundaries parameter for metric distribution service */
public static final String BOUNDARY_PARAMETER = "boundaries";
/** Name of the timestamp parameter. */
public static final String TIMESTAMP_PARAMETER_NAME = "t";
private ServiceClientUris() {
// Utils class should not be instantiated
}
/** Constructs a global service uri for services with api prefix. */
public static String getGlobal(String serviceName, ServerDetails serverDetails, Pair, ?>... options) {
return getGlobal(serviceName, serverDetails, fromNonEmptyPairs(options));
}
/** Constructs a global service uri for services with api prefix and version. */
public static String getGlobal(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
Pair, ?>... options) {
return getGlobal(serviceName, serverDetails, teamscaleVersion, fromNonEmptyPairs(options));
}
/** Constructs a global service uri for services with api prefix and version. */
public static String getGlobal(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
ListMap options) {
return StringUtils.ensureEndsWith(serverDetails.getUrl(), "/") + "api/v" + teamscaleVersion.toString() + "/"
+ serviceName + createOptionString(options);
}
/** Constructs a global service uri for services with api prefix. */
public static String getGlobal(String serviceName, ServerDetails serverDetails, ListMap options) {
return StringUtils.ensureEndsWith(serverDetails.getUrl(), "/") + "api/" + serviceName
+ createOptionString(options);
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
Pair, ?>... options) {
return getProject(serviceName, serverDetails, projectName, fromNonEmptyPairs(options));
}
/**
* Constructs a project service uri for services with api prefix and version.
*/
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, Pair, ?>... options) {
return getProject(serviceName, serverDetails, teamscaleVersion, projectName, fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
ListMap options) {
return getProject(serviceName, serverDetails, projectName, StringUtils.EMPTY_STRING, options);
}
/**
* Constructs a project service uri for services with api prefix and version.
*/
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, ListMap options) {
return getProject(serviceName, serverDetails, teamscaleVersion, projectName, StringUtils.EMPTY_STRING, options);
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
UniformPath uniformPath, Pair, ?>... options) {
return getProject(serviceName, serverDetails, projectName, uniformPath.toString(), options);
}
/**
* Constructs a project service uri for services with api prefix and version.
*/
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, UniformPath uniformPath, Pair, ?>... options) {
return getProject(serviceName, serverDetails, teamscaleVersion, projectName, uniformPath.toString(), options);
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
String uniformPath, Pair, ?>... options) {
return getProject(serviceName, serverDetails, projectName, uniformPath, fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, String uniformPath, Pair, ?>... options) {
return getProject(serviceName, serverDetails, teamscaleVersion, projectName, uniformPath,
fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
UniformPath uniformPath, ListMap options) {
return getProject(serviceName, serverDetails, projectName, uniformPath.toString(), options);
}
/**
* Constructs a project service uri for services with api prefix and version.
*/
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, UniformPath uniformPath, ListMap options) {
return getProject(serviceName, serverDetails, teamscaleVersion, projectName, uniformPath.toString(), options);
}
/** Constructs a project service uri for services with api prefix. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
String uniformPath, ListMap options) {
return StringUtils.ensureEndsWith(serverDetails.getUrl(), "/") + "api/projects/" + projectName + "/"
+ serviceName + "/" + ServiceUtils.encodePathSegment(uniformPath) + createOptionString(options);
}
/**
* Constructs a project service uri for services with api prefix and version.
*/
public static String getProject(String serviceName, ServerDetails serverDetails, Version teamscaleVersion,
PublicProjectId projectName, String uniformPath, ListMap options) {
return StringUtils.ensureEndsWith(serverDetails.getUrl(), "/") + "api/v" + teamscaleVersion + "/projects/"
+ projectName + "/" + serviceName + "/" + ServiceUtils.encodePathSegment(uniformPath)
+ createOptionString(options);
}
/** Class for building URI's for legacy services. */
public static class Legacy {
/** Constructs a global service uri for services of the legacy framework. */
public static String getGlobal(String serviceName, ServerDetails serverDetails, Pair, ?>... options) {
return getGlobal(serviceName, serverDetails, fromNonEmptyPairs(options));
}
/** Constructs a global service uri for services of the legacy framework. */
public static String getGlobal(String serviceName, ServerDetails serverDetails,
ListMap options) {
return getServiceUrl(serverDetails, null, serviceName) + createOptionString(options);
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
Pair, ?>... options) {
return getProject(serviceName, serverDetails, projectName, fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
String uniformPath, Pair, ?>... options) {
return getProject(serviceName, serverDetails, projectName, uniformPath, fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
String uniformPath, ListMap options) {
return getServiceUrl(serverDetails, projectName, serviceName) //
+ ServiceUtils.encodeUniformPath(uniformPath) //
+ createOptionString(options);
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
UniformPath uniformPath, Pair, ?> options) {
return getProject(serviceName, serverDetails, projectName, uniformPath, fromNonEmptyPairs(options));
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
UniformPath uniformPath, ListMap options) {
return getProject(serviceName, serverDetails, projectName, uniformPath.toString(), options);
}
/** Constructs a project service uri for services of the legacy framework. */
public static String getProject(String serviceName, ServerDetails serverDetails, PublicProjectId projectName,
ListMap options) {
return getServiceUrl(serverDetails, projectName, serviceName) //
+ createOptionString(options);
}
/** Constructs the URL of a service. */
private static String getServiceUrl(ServerDetails serverDetails, PublicProjectId projectName,
String serviceName) {
String url = serverDetails.getUrl();
url = StringUtils.ensureEndsWith(url, "/");
if (projectName != null) {
url += StringUtils.ensureEndsWith(LEGACY_PROJECT_PREFIX + projectName, "/");
}
url = StringUtils.ensureEndsWith(url, "/");
url += serviceName;
url = StringUtils.ensureEndsWith(url, "/");
return url;
}
}
/**
* Creates an encoded URL options string starting with ?
from the
* given options. The given parameters are interpreted as parameter names and
* values, where each odd numbered parameter is a parameter name and each even
* one is the corresponding value.
*/
public static String createOptionString(String... parametersAndValues) {
return createOptionString(ListMap.of(parametersAndValues));
}
/**
* Creates an encoded URL options string starting with ?
from the
* given options.
*/
private static String createOptionString(ListMap options) {
StringBuilder sb = new StringBuilder();
if (options != null) {
String separator = "?";
for (String option : options.getKeys()) {
List values = options.getCollection(option);
for (String value : values) {
value = ServiceUtils.encodeQueryParameter(value);
sb.append(separator).append(option).append('=').append(value);
separator = "&";
}
}
}
return sb.toString();
}
/**
* Creates a timestamp parameter pair. When the timestamp is null the method
* returns null
.
*/
public static Pair createCommitDescriptorOption(CommitDescriptor commitDescriptor) {
if (commitDescriptor == null) {
return null;
}
return Pair.createPair(TIMESTAMP_PARAMETER_NAME, commitDescriptor.toServiceCallFormat());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy