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

blobstore.url.Port.scala Maven / Gradle / Ivy

package blobstore.url

import blobstore.url.exception.{PortParseError, SingleValidationException}
import cats.data.Validated
import cats.data.Validated.{Invalid, Valid}
import cats.kernel.Order
import cats.syntax.all.*
import cats.{ApplicativeThrow, Show}

import scala.util.Try

case class Port private (portNumber: Int) {
  override def toString: String = portNumber.toString
}

object Port {
  val MinPortNumber: Int = 0
  val MaxPortNumber: Int = 65535

  def parse(c: String): Validated[PortParseError, Port] =
    Try(c.toInt).toEither.leftMap(_ => PortParseError.InvalidPort(c)).leftWiden[PortParseError].flatMap(parse(
      _
    ).toEither).toValidated

  def parse(i: Int): Validated[PortParseError, Port] = {
    if (i < MinPortNumber || i > MaxPortNumber) PortParseError.PortNumberOutOfRange(i).asLeft
    else new Port(i).asRight
  }.toValidated

  def parseF[F[_]: ApplicativeThrow](c: String): F[Port] =
    parse(c).toEither.leftMap(SingleValidationException(_)).liftTo[F]

  def parseF[F[_]: ApplicativeThrow](i: Int): F[Port] =
    parse(i).toEither.leftMap(SingleValidationException(_)).liftTo[F]

  def unsafe(c: String): Port = parse(c) match {
    case Valid(p)   => p
    case Invalid(e) => throw SingleValidationException(e) // scalafix:ok
  }

  def unsafe(i: Int): Port = parse(i) match {
    case Valid(p)   => p
    case Invalid(e) => throw SingleValidationException(e) // scalafix:ok
  }

  def compare(one: Port, two: Port): Int = one.portNumber.compare(two.portNumber)

  implicit val ordering: Ordering[Port] = (x: Port, y: Port) => Port.compare(x, y)
  implicit val order: Order[Port]       = Order.fromOrdering
  implicit val show: Show[Port]         = _.portNumber.show
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy