Class/Object

fr.hmil.roshttp

HttpRequest

Related Docs: object HttpRequest | package roshttp

Permalink

final class HttpRequest extends AnyRef

Builds an HTTP request.

The request is sent using send. A request can be sent multiple times.

Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. HttpRequest
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. val backendConfig: BackendConfig

    Permalink
  6. val body: Option[BodyPart]

    Permalink
  7. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. val crossDomainCookies: Boolean

    Permalink
  9. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  10. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  11. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  12. def get()(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request with the GET method.

    Sends this request with the GET method.

    See also

    send

  13. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  14. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  15. val headers: HeaderMap[String]

    Permalink
  16. val host: String

    Permalink
  17. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  18. val longPath: String

    Permalink

    The path with the query string or just the path if there is no query string

  19. val method: Method

    Permalink
  20. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  21. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  22. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  23. def options(body: BodyPart)(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request with the OPTIONS method and a body

    Sends this request with the OPTIONS method and a body

    body

    The body to send with the request

    See also

    post

  24. val path: String

    Permalink
  25. val port: Option[Int]

    Permalink
  26. def post(body: BodyPart)(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request with the POST method and a body

    Sends this request with the POST method and a body

    body

    The body to send with the request

    See also

    send

  27. val protocol: Protocol

    Permalink
  28. def put(body: BodyPart)(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request with the PUT method and a body

    Sends this request with the PUT method and a body

    body

    The body to send with the request

    See also

    post

  29. val queryString: Option[String]

    Permalink
  30. def send(body: BodyPart)(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request with a body.

    Sends this request with a body.

    This method should not be used directly. If you want to post or put some data, you should use the appropriate methods. If you do not want to send data with the request, you should use post without arguments.

    body

    The body to send.

  31. def send()(implicit scheduler: Scheduler): Future[SimpleHttpResponse]

    Permalink

    Sends this request.

    Sends this request.

    A request can be sent multiple times. When a request is sent, it returns a Future[HttpResponse] which either succeeds with an HttpResponse or fails.]]

  32. def stream()(implicit scheduler: Scheduler): Future[StreamHttpResponse]

    Permalink
  33. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  34. val timeout: FiniteDuration

    Permalink
  35. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  36. val url: String

    Permalink

    The target url for this request

  37. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  38. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  39. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  40. def withBackendConfig(backendConfig: BackendConfig): HttpRequest

    Permalink

    Use the provided backend configuration when executing the request

  41. def withBody(body: BodyPart): HttpRequest

    Permalink

    Attaches a body to this request and sets the Content-Type header.

    Attaches a body to this request and sets the Content-Type header.

    The body will be sent with the request regardless of other parameters once send() is invoked. Any subsequent call to withBody(), send(BodyPart), post(BodyPart), put(BodyPart) or similar methods will override the request body.

    The Content-Type header is set to this body's content-type. It can still be manually overridden using a method of the withHeader() family.

    Note that the HTTP spec forbids sending data with some methods. In case you need to deal with a broken backend, this library allows you to do so anyway. **Beware that in this case, the JVM can still enforce a compliant HTTP method**.

  42. def withCrossDomainCookies(toggle: Boolean): HttpRequest

    Permalink

    Allows browser to add a cookie to a cross-domain request, if one was received prior from the server.

    Allows browser to add a cookie to a cross-domain request, if one was received prior from the server.

    toggle

    If true, browser is allowed to add cookie to cross-domain request.

    returns

    A copy of this HttpRequest with an updated header set.

  43. def withDefaultPort(): HttpRequest

    Permalink

    Discards changes introduced by any call to withPort

    Discards changes introduced by any call to withPort

    returns

    A copy of this HttpRequest with no explicit port.

  44. def withHeader(key: String, value: String): HttpRequest

    Permalink

    Adds or updates a header to the current set of headers.

    Adds or updates a header to the current set of headers.

    key

    The header key (case insensitive)

    value

    The header value

    returns

    A copy of this HttpRequest with an updated header set.

  45. def withHeaders(newHeaders: (String, String)*): HttpRequest

    Permalink

    Adds or updates multiple headers to the current set of headers.

    Adds or updates multiple headers to the current set of headers.

    newHeaders

    The headers to add.

    returns

    A copy of this HttpRequest with an updated header set.

  46. def withHost(host: String): HttpRequest

    Permalink

    Sets the host used in the request URI.

    Sets the host used in the request URI.

    host

    The new host

    returns

    A copy of this HttpRequest with an updated host

  47. def withMethod(method: Method): HttpRequest

    Permalink

    Sets the HTTP method.

    Sets the HTTP method. Defaults to GET.

    Beware of browser limitations when using exotic methods.

    method

    The new method

    returns

    A copy of this HttpRequest with an updated method

  48. def withPath(path: String): HttpRequest

    Permalink

    Sets the path used in the request URI.

    Sets the path used in the request URI.

    The path is the part that lies between the host (or port if present) and the query string or the end of the request. Note that the query string is not part of the path.

    path

    The new path, including the leading '/' and excluding any '?' or '#' and subsequent characters

    returns

    A copy of this HttpRequest with an updated path

  49. def withPort(port: Int): HttpRequest

    Permalink

    Sets the port used in the request URI.

    Sets the port used in the request URI.

    port

    The new port

    returns

    A copy of this HttpRequest with an updated port

  50. def withProtocol(protocol: Protocol): HttpRequest

    Permalink

    Sets the protocol used in the request URL.

    Sets the protocol used in the request URL.

    Setting the protocol also sets the port accordingly (80 for HTTP, 443 for HTTPS).

    protocol

    The HTTP or HTTPS protocol

    returns

    A copy of this HttpRequest with an updated protocol and port

  51. def withQueryObjectParameter(key: String, values: Seq[(String, String)]): HttpRequest

    Permalink

    Adds an object made of key/value pairs to the query string.

    Adds an object made of key/value pairs to the query string.

    Although this is not part of a spec, most servers recognize bracket indices in a query string as object keys. The same key can appear multiple times as some server will interpret this as multiple elements in an array for that key.

    example: ?obj[foo]=bar&obj[baz]=42

    key

    The unescaped parameter key

    values

    The unescaped parameter map values

    returns

    A copy of this HttpRequest with an updated query string.

  52. def withQueryParameter(key: String, value: String): HttpRequest

    Permalink

    Adds a query parameter key/value pair.

    Adds a query parameter key/value pair.

    Query parameters end up in the query string as key=value pairs separated by ampersands. Both the key and parameter are escaped to ensure proper query string format.

    key

    The unescaped parameter key

    value

    The unescaped parameter value

    returns

    A copy of this HttpRequest with an updated query string.

  53. def withQueryParameters(parameters: (String, String)*): HttpRequest

    Permalink

    Adds multiple query parameters.

    Adds multiple query parameters.

    parameters

    A sequence of new, unescaped parameters.

    returns

    A copy of this HttpRequest with an updated query string.

  54. def withQuerySeqParameter(key: String, values: Seq[String]): HttpRequest

    Permalink

    Adds a query array parameter.

    Adds a query array parameter.

    Although this is not part of a spec, most servers recognize bracket indices in a query string as array indices or object keys.

    example: ?list[0]=foo&list[1]=bar

    This method formats array values according to the above example.

    key

    The unescaped parameter key

    values

    The unescaped parameter array values

    returns

    A copy of this HttpRequest with an updated query string.

  55. def withQueryString(queryString: String): HttpRequest

    Permalink

    Sets the query string.

    Sets the query string.

    The argument is escaped by this method. If you want to bypass the escaping, use withQueryStringRaw.

    Escaping also means that the queryString property will generally not be equal to what you passed as argument to withQueryString.

    For instance: request.withQueryString("äéuô").queryString.get != "%C3%A4%C3%A9u%C3%B4"

    queryString

    The unescaped query string.

    returns

    A copy of this HttpRequest with an updated queryString

  56. def withQueryStringRaw(queryString: String): HttpRequest

    Permalink

    Sets the query string without escaping.

    Sets the query string without escaping.

    Raw query strings must only contain legal characters as per rfc3986. Adding special characters yields undefined behaviour.

    In most cases, withQueryString should be preferred.

    queryString

    The raw, escaped query string

    returns

    A copy of this HttpRequest with an updated queryString

  57. def withTimeout(timeout: FiniteDuration): HttpRequest

    Permalink

    Specifies the request timeout.

    Specifies the request timeout.

    When a request takes longer than timeout to complete, the future is rejected with a fr.hmil.roshttp.exceptions.TimeoutException.

    timeout

    The duration to wait before throwing a timeout exception.

    returns

    A copu of this HttpRequest with an updated timeout setting.

  58. def withURL(url: String): HttpRequest

    Permalink

    Updates request protocol, host, port, path and queryString according to a url.

    Updates request protocol, host, port, path and queryString according to a url.

    url

    A valid HTTP url

    returns

    A copy of this HttpRequest with updated URL-related attributes.

  59. def withoutQueryString(): HttpRequest

    Permalink

    Removes the query string.

    Removes the query string.

    returns

    A copy of this HttpRequest without query string

Inherited from AnyRef

Inherited from Any

Ungrouped