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

commonMain.org.jellyfin.sdk.model.ServerVersion.kt Maven / Gradle / Ivy

package org.jellyfin.sdk.model

import kotlinx.serialization.Serializable
import org.jellyfin.sdk.model.ServerVersion.Companion.fromString

/**
 * Model to help with Jellyfin server versions.
 * Use [fromString] to parse strings. The format is similar to SemVer.
 */
@Serializable
public data class ServerVersion(
	val major: Int,
	val minor: Int,
	val patch: Int,
	val build: Int? = null
) : Comparable {
	public override operator fun compareTo(other: ServerVersion): Int = comparator.compare(this, other)

	/**
	 * Convert version to string. Format is "[major].[minor].[patch].[build]".
	 * [build] is omitted if null.
	 * Sample output:
	 * - 1.0.0
	 * - 10.6.4
	 * - 10.7.0.0
	 */
	override fun toString(): String = buildString {
		append(major, '.', minor, '.', patch)
		if (build != null) append('.', build)
	}

	public companion object {
		private val comparator = compareBy(
			{ it.major },
			{ it.minor },
			{ it.patch },
			{ it.build ?: 0 }
		)

		/**
		 * Create an instance of [ServerVersion] from a string. The string must be in the format
		 * "^\d+\.\d+\.\d+(?:\.\d+)?$". Example: 1.0.0, 10.6.4 or 10.7.0.0. Characters are not allowed.
		 */
		public fun fromString(str: String): ServerVersion? {
			// Split into major, minor and patch
			val parts = str.split('.').map(String::toIntOrNull)

			// Check if we found enough parts
			@Suppress("MagicNumber")
			if (parts.size != 3 && parts.size != 4) return null

			// Bad value found
			if (parts.any { it == null }) return null

			// Return server version
			@Suppress("MagicNumber")
			return ServerVersion(
				major = parts[0]!!,
				minor = parts[1]!!,
				patch = parts[2]!!,
				build = parts.getOrNull(3)
			)
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy