org.conqat.engine.index.shared.ProjectIdBase Maven / Gradle / Ivy
package org.conqat.engine.index.shared;
import java.io.Serializable;
import java.util.Objects;
import java.util.regex.Pattern;
import org.conqat.lib.commons.js_export.ExportToTypeScript;
import org.conqat.lib.commons.string.StringUtils;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.common.base.Preconditions;
/** Abstract base class for project IDs. */
@ExportToTypeScript
public abstract class ProjectIdBase implements IProjectId, Serializable {
private static final long serialVersionUID = 1L;
/** JSON property of the project ID. */
protected static final String PROJECT_ID_PROPERTY = "projectId";
/**
* Pattern for detecting UUIDs (which are used exclusively for internal IDs).
*/
private static final Pattern UUID_PATTERN = Pattern
.compile("^[0-9A-Fa-f]{8}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{4}-[0-9A-Fa-f]{12}$");
/** The project ID. */
@JsonProperty(PROJECT_ID_PROPERTY)
private final String projectId;
protected ProjectIdBase(@JsonProperty(PROJECT_ID_PROPERTY) String projectId) {
Preconditions.checkArgument(!StringUtils.isEmpty(projectId), "Project ID must not be empty");
this.projectId = projectId;
}
/**
* Returns whether this ID conforms to the format expected for an internal ID.
*/
protected boolean isUuidFormat() {
return isUuidIdFormat(projectId);
}
@Override
public String toString() {
return projectId;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
ProjectIdBase that = (ProjectIdBase) o;
return Objects.equals(projectId, that.projectId);
}
@Override
public int hashCode() {
return Objects.hash(projectId);
}
@Override
public int compareTo(IProjectId o) {
return toString().compareTo(o.toString());
}
/**
* Returns whether the given ID conforms to the format expected for an internal
* ID.
*/
private static boolean isUuidIdFormat(String id) {
return UUID_PATTERN.matcher(id).matches();
}
/**
* Converts a given string into a typed representation, based on its format.
* UUIDs are converted into internal IDs, everything else is assumed to be a
* public ID. If the given argument is null
or null
,
* then this returns null
.
*/
public static IProjectId convert(String projectId) {
if (StringUtils.isEmpty(projectId)) {
return null;
}
if (isUuidIdFormat(projectId)) {
return new InternalProjectId(projectId);
}
return new PublicProjectId(projectId);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy