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

net.nemerosa.ontrack.model.structure.NameDescription.kt Maven / Gradle / Ivy

package net.nemerosa.ontrack.model.structure

import javax.validation.constraints.NotNull
import javax.validation.constraints.Pattern

data class NameDescription(
        @get:NotNull(message = "The name is required.")
        @get:Pattern(regexp = NAME, message = "The name $NAME_MESSAGE_SUFFIX")
        val name: String,
        val description: String?
) {

    companion object {

        /**
         * List of allowed characters
         */
        private const val ALLOWED_CHARS = "A-Za-z0-9\\._-"

        /**
         * Regular expression to validate a name.
         */
        const val NAME = "[$ALLOWED_CHARS]+"

        /**
         * Valid name regular expression
         */
        private val VALID_NAME_REGEX = NAME.toRegex()

        /**
         * Regular expression object for the non matching characters
         */
        private val UNALLOWED_CHARS_REGEX = "[^$ALLOWED_CHARS]".toRegex()

        /**
         * Message associated with the regular expression
         */
        const val NAME_MESSAGE_SUFFIX = "can only have letters, digits, dots (.), dashes (-) or underscores (_)."


        /**
         * Simple builder
         */
        @JvmStatic
        fun nd(name: String, description: String?) = NameDescription(name, description)

        /**
         * Makes sure the given name is escaped properly before being used as a valid name.
         *
         * @param name Name to convert
         * @return Name which is safe to use
         * @see #NAME
         */
        @JvmStatic
        fun escapeName(name: String?): String =
                when {
                    name.isNullOrBlank() -> throw IllegalArgumentException("Blank or null is not a valid name.")
                    VALID_NAME_REGEX.matches(name) -> name
                    else -> name.replace(UNALLOWED_CHARS_REGEX, "-")
                }

    }

    @JvmOverloads
    fun asState(disabled: Boolean = false) = NameDescriptionState(name, description, disabled)

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy