RealHTTP provides an elegant type-safe interface to build and execute asynchronous HTTP requests.
At the heart of this library there is URLSession, the modern Apple implementation of networking infrastructure.
Best of all, RealHTTP is lightweight and has no external dependencies.
RealHTTP defines the following fundamental objects, such as HTTP client:
HTTPClient
: this is the container where requests are executed. It handles common request configuration options along with session data (cookies, headers and so on). You can create a custom client or use theshared
one.HTTPRequest
: defines a single request along with its configuration, url, parameters, body and so on. It allows you to easily define a single request in a type-safe manner without the hassle of dealing with the raw settings of an http communication (for example it supports multipart, json encoding, different parameter encodings, progress tracking, metrics collection and more).HTTPResponse
: Request'sfetch()
method produces an async response. This object contains all of the relevant information of the response, including error parsing, raw data, and url connection stats. Request'sdecode()
method allows you to transform a raw response to a valid business object.HTTPValidator
: when a request is received it can be validated by the client'svalidators
. Validators can be chained and each one can ask for a retry, transform the result, or handle the custom business logic and error handling of your web service implementations.
This is a simple flow of an http request from the beginning to the end decode phase:
If you need to make mocked requests, for example to test your client implementation, RealHTTP's integrated stubber will become your best friend.
The stubber's main components are:
HTTPStubber
: it's a singleton object where your stub rules are handled. Consider it a sort of local webservice for your client which can handle replies coming from your app. You can enable or disable the stub at anytime.HTTPStubRequest
: this object contains a set of matching rules (matchers
) and the associated responses (responses
) based upon the request's http method. When a new request is received the stubber checks the definedrequests
and if a match is found it uses its responses.HTTPStubMatcher
: this is a protocol you can implement to check if a particular stub request is matched. Typically you will never need to make a custom matcher; RealHTTP offers many built-in matchers including regex, uri template based, and more.HTTPStubResponse
: defines a protocol which produces aURLResponse
based upon a receivedURLRequest
.HTTPStubIgnoreRules
: you can also define one or more ignore rules which should be not handled by the stubber.