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

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