# Joken
[](https://travis-ci.org/joken-elixir/joken)
[](https://hex.pm/packages/joken)
[](https://hexdocs.pm/joken/)
[](https://hex.pm/packages/joken)
[](https://github.com/joken-elixir/joken/blob/main/LICENSE)
[](https://github.com/joken-elixir/joken/commits/main)
A JSON Web Token (JWT) Library.
Please, do read our comprehensive documentation and guides:
- [Changelog](https://hexdocs.pm/joken/changelog.html)
- [Joken Overview](https://hexdocs.pm/joken/introduction.html)
- [Configuration](https://hexdocs.pm/joken/configuration.html)
- [Signers](https://hexdocs.pm/joken/signers.html)
- [Asymmetric cryptography signers](https://hexdocs.pm/joken/asymmetric_cryptography_signers.html)
- [Testing your app with Joken](https://hexdocs.pm/joken/testing.html)
- [JWT Common use cases](https://hexdocs.pm/joken/common_use_cases.html)
- [Migrating from Joken 1.0](https://hexdocs.pm/joken/migration_from_1.html)
- [Custom header arguments](https://hexdocs.pm/joken/custom_header_arguments.html)
## Usage
Add `:joken` to your list of dependencies in `mix.exs`:
``` elixir
def deps do
  # .. other deps
  {:joken, "~> 2.6"},
  # Recommended JSON library
  {:jason, "~> 1.4"}
end
```
All set! (don't forget to take a look at our comprehensive [documentation and guides](https://hexdocs.pm/joken/introduction.html)!)
## Benchmarking
Just run the benchmark script based on the supported algorithm:
``` shell
mix run benchmarks/hs_benchmark.exs
mix run benchmarks/jose_hs_benchmark.exs
mix run benchmarks/pem_rs_benchmark.exs
mix run benchmarks/rs_benchmark.exs
```
## License
Copyright (c) 2014 Bryan Joseph
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at [http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0)
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
## Disclaimer
This library would not be possible without the work of @potatosalad (Andrew Bennet). Specifically his library [erlang-jose](https://github.com/potatosalad/erlang-jose/).