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

sttp.model.Method.scala Maven / Gradle / Ivy

package sttp.model

import internal.Validate._
import sttp.model.internal.Validate
import sttp.model.internal.Rfc2616.validateToken

case class Method(method: String) extends AnyVal {
  override def toString: String = method
}

/** For a description of the behavior of `apply`, `safeApply` and `unsafeApply` methods, see [[sttp.model]].
  */
object Method extends Methods {

  /** @throws IllegalArgumentException If the method value is not a valid token.
    */
  def unsafeApply(method: String): Method = safeApply(method).getOrThrow
  def safeApply(method: String): Either[String, Method] =
    Validate.all(validateToken("Method", method))(apply(method))

  /** An HTTP method is idempotent if an identical request can be made once or several times in a row with the same
    * effect while leaving the server in the same state.
    * @see https://developer.mozilla.org/en-US/docs/Glossary/Idempotent
    */
  def isIdempotent(m: Method): Boolean = idempotent.contains(m)

  /** An HTTP method is safe if it doesn't alter the state of the server.
    * @see https://developer.mozilla.org/en-US/docs/Glossary/safe
    */
  def isSafe(m: Method): Boolean = safe.contains(m)

  private val idempotent: Set[Method] =
    Set(Method.HEAD, Method.TRACE, Method.GET, Method.PUT, Method.OPTIONS, Method.DELETE)
  private val safe: Set[Method] = Set(Method.HEAD, Method.GET, Method.OPTIONS)
}

trait Methods {
  val GET: Method = Method("GET")
  val HEAD: Method = Method("HEAD")
  val POST: Method = Method("POST")
  val PUT: Method = Method("PUT")
  val DELETE: Method = Method("DELETE")
  val OPTIONS: Method = Method("OPTIONS")
  val PATCH: Method = Method("PATCH")
  val CONNECT: Method = Method("CONNECT")
  val TRACE: Method = Method("TRACE")
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy