Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Plug documentation edits #1161

Merged
merged 6 commits into from
Nov 16, 2023
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 14 additions & 15 deletions lib/plug.ex
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,9 @@ defmodule Plug do

### Function plugs

A function plug is any function that receives a connection and a set of
options and returns a connection. Its type signature must be:
A function plug is by definition any function that receives a connection
and a set of options and returns a connection. Function plugs must have
the following type signature:

(Plug.Conn.t, Plug.opts) :: Plug.Conn.t

Expand Down Expand Up @@ -52,8 +53,7 @@ defmodule Plug do

## The Plug pipeline

The `Plug.Builder` module provides conveniences for building plug
pipelines.
The `Plug.Builder` module provides conveniences for building plug pipelines.
"""

@type opts ::
Expand All @@ -72,26 +72,25 @@ defmodule Plug do
require Logger

@doc """
Run a series of Plugs at runtime.
Run a series of plugs at runtime.

The plugs given here can be either a tuple, representing a module plug
and their options, or a simple function that receives a connection and
returns a connection.

If any of the plugs halt, the remaining plugs are not invoked. If the
given connection was already halted, none of the plugs are invoked
either.
If any plug halts, the connection won't invoke the remaining plugs. If the
given connection was already halted, none of the plugs are invoked either.

While `Plug.Builder` works at compile-time, this is a straight-forward
alternative that works at runtime.
While Plug.Builder is designed to operate at compile-time, the `run` function
serves as a straightforward alternative for runtime executions.

## Examples

Plug.run(conn, [{Plug.Head, []}, &IO.inspect/1])

## Options

* `:log_on_halt` - a log level to be used if a Plug halts
* `:log_on_halt` - a log level to be used if a plug halts

"""
@spec run(Plug.Conn.t(), [{module, opts} | (Plug.Conn.t() -> Plug.Conn.t())], Keyword.t()) ::
Expand Down Expand Up @@ -135,11 +134,11 @@ defmodule Plug do
defp do_run(conn, [], _level), do: conn

@doc """
Forwards requests to another Plug setting the connection to a trailing subpath of the request.
Forwards requests to another plug while setting the connection to a trailing subpath of the request.

The `path_info` on the forwarded connection will only include the trailing segments
of the request path supplied to forward, while `conn.script_name` will
retain the correct base path for e.g. url generation.
The `path_info` on the forwarded connection will only include the request path trailing segments
supplied to the `forward` function. The `conn.script_name` attribute retains the correct base path,
e.g., url generation.

## Example

Expand Down
Loading