[](https://circleci.com/gh/GrappigPanda/paseto_plug/tree/master)
[](https://hex.pm/packages/paseto_plug)
[HexDocs](https://hexdocs.pm/paseto_plug/api-reference.html)
# paseto_plug
A Phoenix authentication plug that validates Paseto (Platform Agnostic Security Tokens).
## Installation
This package can be installed by adding `paseto_plug` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:paseto_plug, "~> 0.1.0"}
]
end
```
## Using the plug
This plug, solely, handles taking a Paseto and validating it was issued by your key(-pair).
Should you need more information on generating a Paseto, take a look at my other project over here:
https://github.com/GrappigPanda/paseto
So, in order to use the plug, you will need to include the following in your `router.ex` file.
```elixir
plug PasetoPlug, key_provider: &KeyProvider.get_key/0
```
Moreover, you will need to write a key provider module + function. This can be as simple as the following:
```elixir
defmodule KeyProvider do
def get_key() do
"safe_key"
end
end
```
Now, whenever a request goes through, the requester will either face a 401 (if they have an invalid paseto) or your `conn` will have a new `:claims` key in the `assigns` map.
```elixir
# You can grab it by using
conn.assigns.claims
```
## Documentation
Documentation can be generated with [ExDoc](https://github.com/elixir-lang/ex_doc)
and published on [HexDocs](https://hexdocs.pm). Once published, the docs can
be found at [https://hexdocs.pm/paseto_plug](https://hexdocs.pm/paseto_plug).