ewe
IP Address
Information
Builder
- new
- bind
- bind_all
- listening
- listening_random
- enable_ipv6
- enable_tls
- with_name
- quiet
- idle_timeout
- on_start
- on_crash
Server
Request
Response
Chunked Response
Websocket
- upgrade_websocket
- send_binary_frame
- send_text_frame
- websocket_continue
- websocket_continue_with_selector
- websocket_stop
- websocket_stop_abnormal
Server-Sent Events
Types
Possible errors that can occur when reading a body.
pub type BodyError {
  BodyTooLarge
  InvalidBody
}Constructors
- 
          BodyTooLargeBody is larger than the provided limit. 
- 
          InvalidBodyBody is malformed. 
Ewe’s server builder. Contains all server configurations. Can be adjusted with the following functions:
- ewe.bind
- ewe.bind_all
- ewe.listening
- ewe.listening_random
- ewe.enable_ipv6
- ewe.enable_tls
- ewe.with_name
- ewe.on_start
- ewe.quiet
- ewe.on_crash
- ewe.idle_timeout
pub opaque type BuilderRepresents a chunked response body. This type is used to send a chunked response to the client.
pub type ChunkedBody =
  @internal ChunkedBodyRepresents an instruction on how chunked response should be processed.
- continue processing the chunked response.
- stop the chunked response normally.
- stop the chunked response with abnormal reason.
pub opaque type ChunkedNext(user_state)Represents a default body stored inside a Request type. Contains
important information for retrieving the original request body or client’s
information. Can be converted to a BitArray using ewe.read_body.
pub type Connection =
  @internal ConnectionPossible errors that can occur when setting response body from a file.
pub type FileError {
  NoEntry
  NoAccess
  IsDirectory
  UnknownFileError(dynamic.Dynamic)
}Constructors
- 
          NoEntryFile does not exist. 
- 
          NoAccessMissing permission for reading the file, or for searching one of the parents directories. 
- 
          IsDirectoryThe named file is a directory. 
- 
          UnknownFileError(dynamic.Dynamic)Untypical file error. 
Represents an IP address of a client/server.
pub type IpAddress {
  IpV4(Int, Int, Int, Int)
  IpV6(Int, Int, Int, Int, Int, Int, Int, Int)
}Constructors
- 
          IpV4(Int, Int, Int, Int)
- 
          IpV6(Int, Int, Int, Int, Int, Int, Int, Int)
A convenient alias for a HTTP request with a Connection as the body.
pub type Request =
  request.Request(Connection)A convenient alias for a HTTP response with a ResponseBody as the body.
pub type Response =
  response.Response(ResponseBody)Represents possible response body options.
Types for direct usage:
- Regular data: TextData,BytesData,BitsData,StringTreeData,Empty
- Chunked data: ChunkedData
Types that should not be used directly:
- File: see- ewe.fileto construct it.
- ChunkedData: indicates that response body is being sent in chunks with- chunkedtransfer encoding.
- Websocket: indicates that request is being upgraded to a WebSocket connection.
- SSE: indicates that request is being upgraded to a Server-Sent Events connection.
pub type ResponseBody {
  TextData(String)
  BytesData(bytes_tree.BytesTree)
  BitsData(BitArray)
  StringTreeData(string_tree.StringTree)
  Empty
  File(descriptor: @internal IoDevice, offset: Int, size: Int)
  Chunked
  Websocket
  SSE
}Constructors
- 
          TextData(String)Allows to set response body from a string. 
- 
          BytesData(bytes_tree.BytesTree)Allows to set response body from bytes. 
- 
          BitsData(BitArray)Allows to set response body from bits. 
- 
          StringTreeData(string_tree.StringTree)Allows to set response body from a string tree. 
- 
          EmptyAllows to set empty response body. 
- 
          File(descriptor: @internal IoDevice, offset: Int, size: Int)Allows to set response body from a file more efficiently rather than sending contents in regular data types. 
- 
          ChunkedIndicates that response body is being sent in chunks with chunkedtransfer encoding.
- 
          WebsocketIndicates that request is being upgraded to a WebSocket connection. 
- 
          SSEIndicates that request is being upgraded to a Server-Sent Events connection. 
Represents a Server-Sent Events connection between a client and a server.
pub type SSEConnection =
  @internal SSEConnectionRepresents a Server-Sent Events event. The event fields are:
- event: a string identifying the type of event described.
- data: the data field for the message.
- id: event ID.
- retry: The reconnection time. If the connection to the server is lost, the browser will wait for the specified time before attempting to reconnect.
Can be created using ewe.event and modified with ewe.event_name,
ewe.event_id, and ewe.event_retry.
pub type SSEEvent =
  @internal SSEEventRepresents an instruction on how Server-Sent Events connection should proceed.
- continue processing the Server-Sent Events connection.
- stop the Server-Sent Events connection.
- stop the Server-Sent Events connection with abnormal reason.
pub opaque type SSENext(user_state)Represents a WebSocket connection between a client and a server.
pub type WebsocketConnection =
  @internal WebsocketConnectionRepresents a WebSocket message received from the client.
pub type WebsocketMessage(user_message) {
  Text(String)
  Binary(BitArray)
  User(user_message)
}Constructors
- 
          Text(String)Indicate that text frame has been received. 
- 
          Binary(BitArray)Indicate that binary frame has been received. 
- 
          User(user_message)Indicate that user message has been received from WebSocket selector. 
Represents an instruction on how WebSocket connection should proceed.
- continue processing the WebSocket connection.
- continue processing the WebSocket connection with selector for custom messages.
- stop the WebSocket connection.
- stop the WebSocket connection with abnormal reason.
pub opaque type WebsocketNext(user_state, user_message)Values
pub fn bind(
  builder: Builder,
  interface interface: String,
) -> BuilderBinds server to a specific interface. Crashes program if the interface is invalid.
pub fn chunked_body(
  req: request.Request(Connection),
  resp: response.Response(a),
  on_init on_init: fn(process.Subject(user_message)) -> user_state,
  handler handler: fn(ChunkedBody, user_state, user_message) -> ChunkedNext(
    user_state,
  ),
  on_close on_close: fn(ChunkedBody, user_state) -> Nil,
) -> response.Response(ResponseBody)Sets up the connection for chunked response.
on_init function is called once the chunked response process is
initialized. The argument is subject that can be used to send chunks to the
client. It must return initial state.
handler function is called for every message received. It must return
instruction on how chunked response should proceed.
on_close function is called when the chunked response process is going to be stopped.
pub fn chunked_continue(
  user_state: user_state,
) -> ChunkedNext(user_state)Instructs chunked response to continue processing.
pub fn chunked_stop() -> ChunkedNext(user_state)Instructs chunked response to stop normally.
pub fn chunked_stop_abnormal(
  reason: String,
) -> ChunkedNext(user_state)Instructs chunked response to stop with abnormal reason.
pub fn enable_tls(
  builder: Builder,
  certificate_file certificate_file: String,
  key_file key_file: String,
) -> BuilderEnables TLS support, requires certificate and key file.
pub fn event(data: String) -> SSEEventCreates a new SSE event with the given data. Use ewe.event_name,
ewe.event_id, and ewe.event_retry to modify other fields of the event.
pub fn file(
  path: String,
  offset offset: option.Option(Int),
  limit limit: option.Option(Int),
) -> Result(ResponseBody, FileError)Sets response body from file, sets content-length header.
pub fn get_client_info(
  connection connection: Connection,
) -> Result(SocketAddress, Nil)Attempts to get the client’s socket address using request’s connection.
pub fn get_server_info(
  listener_name name: process.Name(@internal Message),
) -> SocketAddressRetrieves server’s socket address. Requires the same name as the one used in
ewe.with_name and server to be started.
pub fn idle_timeout(
  builder: Builder,
  idle_timeout: Int,
) -> BuilderSets a custom idle timeout in milliseconds for connections. If provided timeout is less than 0, 10_000ms will be used instead.
pub fn ip_address_to_string(address address: IpAddress) -> StringConverts an IpAddress to a String.
pub fn listening_random(builder: Builder) -> BuilderSets listening port for server to a random port. Useful for testing.
pub fn new(
  handler: fn(request.Request(Connection)) -> response.Response(
    ResponseBody,
  ),
) -> BuilderCreates new server builder with handler provided.
Default configuration:
- port: 8080
- interface: 127.0.0.1
- No ipv6 support
- No TLS support
- Default listener name for server information retrieval
- on_start: prints Listening on <scheme>://<ip_address>:<port>
- on_crash: empty 500 response
- idle_timeout: connection is closed after 10_000ms of inactivity
pub fn on_crash(
  builder: Builder,
  on_crash: response.Response(ResponseBody),
) -> BuilderSets a custom response that will be sent when server crashes.
pub fn on_start(
  builder: Builder,
  on_start: fn(http.Scheme, SocketAddress) -> Nil,
) -> BuilderSets a custom handler that will be called after server starts.
pub fn read_body(
  req: request.Request(Connection),
  bytes_limit bytes_limit: Int,
) -> Result(request.Request(BitArray), BodyError)Reads body from the request. If request body is malformed, InvalidBody
error is returned. On success, returns a request with body converted to
BitArray.
- When transfer-encodingheader set aschunked,BodyTooLargeerror is returned if accumulated body is larger thansize_limit.
- Ensures that content-lengthis insize_limitscope.
pub fn send_binary_frame(
  conn: WebsocketConnection,
  bits: BitArray,
) -> Result(Nil, socket.SocketReason)Sends a binary frame to the websocket client.
pub fn send_chunk(
  body: ChunkedBody,
  chunk: BitArray,
) -> Result(Nil, socket.SocketReason)Sends a chunk to the client.
pub fn send_event(
  conn: SSEConnection,
  event: SSEEvent,
) -> Result(Nil, socket.SocketReason)Sends a Server-Sent Events event to the client.
pub fn send_text_frame(
  conn: WebsocketConnection,
  text: String,
) -> Result(Nil, socket.SocketReason)Sends a text frame to the websocket client.
pub fn sse(
  req: request.Request(Connection),
  on_init on_init: fn(process.Subject(user_message)) -> user_state,
  handler handler: fn(SSEConnection, user_state, user_message) -> SSENext(
    user_state,
  ),
  on_close on_close: fn(SSEConnection, user_state) -> Nil,
) -> response.Response(ResponseBody)Sets up the connection for Server-Sent Events.
on_init function is called once process that handles SSE connection
is initialized. The argument is subject that can be used to send messages
to the client. It must return initial state.
handler function is called for every subject’s message received. It must
return instruction on how SSE connection should proceed.
on_close function is called when SSE process is going to be stopped.
pub fn sse_continue(
  user_state: user_state,
) -> SSENext(user_state)Instructs Server-Sent Events connection to continue processing.
pub fn sse_stop() -> SSENext(user_state)Instructs Server-Sent Events connection to stop.
pub fn sse_stop_abnormal(reason: String) -> SSENext(user_state)Instructs Server-Sent Events connection to stop with abnormal reason.
pub fn start(
  builder: Builder,
) -> Result(
  actor.Started(static_supervisor.Supervisor),
  actor.StartError,
)Starts the server with the provided configuration.
pub fn stream_body(
  req: request.Request(Connection),
) -> Result(fn(Int) -> Result(Stream, BodyError), BodyError)Returns the consumer function that reads N amount of bytes from the
request body stream.
pub fn supervised(
  builder: Builder,
) -> supervision.ChildSpecification(static_supervisor.Supervisor)Creates a supervisor with the provided configuration that is a child of a supervision tree.
pub fn upgrade_websocket(
  req: request.Request(Connection),
  on_init on_init: fn(
    WebsocketConnection,
    process.Selector(user_message),
  ) -> #(user_state, process.Selector(user_message)),
  handler handler: fn(
    WebsocketConnection,
    user_state,
    WebsocketMessage(user_message),
  ) -> WebsocketNext(user_state, user_message),
  on_close on_close: fn(WebsocketConnection, user_state) -> Nil,
) -> response.Response(ResponseBody)Upgrade request to a WebSocket connection. If the initial request is not valid for WebSocket upgrade, 400 response is sent.
on_init function is called once process that handles WebSocket connection
is initialized. It must return a tuple with initial state and selector for
custom messages. If there is no custom messages, user can pass the same
selector from the argument
handler function is called for every WebSocket message received. It must
return instruction on how WebSocket connection should proceed.
on_close function is called when WebSocket process is going to be stopped.
pub fn websocket_continue(
  user_state: user_state,
) -> WebsocketNext(user_state, user_message)Instructs WebSocket connection to continue processing.
pub fn websocket_continue_with_selector(
  user_state: user_state,
  selector: process.Selector(user_message),
) -> WebsocketNext(user_state, user_message)Instructs WebSocket connection to continue processing, including selector for custom messages.
pub fn websocket_stop() -> WebsocketNext(user_state, user_message)Instructs WebSocket connection to stop.
pub fn websocket_stop_abnormal(
  reason: String,
) -> WebsocketNext(user_state, user_message)Instructs WebSocket connection to stop with abnormal reason.
pub fn with_name(
  builder: Builder,
  name: process.Name(@internal Message),
) -> BuilderSets a custom process name for server information retrieval, allowing to
use ewe.get_server_info after the server starts.