156 lines
9.3 KiB
Markdown
156 lines
9.3 KiB
Markdown
<img src="https://raw.githubusercontent.com/Thalhammer/jwt-cpp/master/.github/logo.svg" alt="logo" width="100%">
|
||
|
||
[data:image/s3,"s3://crabby-images/2047f/2047f8c895587920e121f9901f78d395e91794e0" alt="License Badge"](https://github.com/Thalhammer/jwt-cpp/blob/master/LICENSE)
|
||
[data:image/s3,"s3://crabby-images/56869/568697427902533cd7b2dfa1bd5230b2aa13346e" alt="Codacy Badge"](https://app.codacy.com/gh/Thalhammer/jwt-cpp/dashboard)
|
||
[![Linux Badge][Linux]][Cross-Platform]
|
||
[![MacOS Badge][MacOS]][Cross-Platform]
|
||
[![Windows Badge][Windows]][Cross-Platform]
|
||
[data:image/s3,"s3://crabby-images/b2b00/b2b003c775960acf7563cc515f8627e9ef7244de" alt="Coverage Status"](https://coveralls.io/github/Thalhammer/jwt-cpp?branch=master)
|
||
|
||
[data:image/s3,"s3://crabby-images/e3549/e35491b09e5cfe94c31e928b8e3973ac27c4bae8" alt="Documentation Badge"](https://thalhammer.github.io/jwt-cpp/)
|
||
|
||
[data:image/s3,"s3://crabby-images/c94fa/c94facad63aee106c3b1084ead16a385b9b2f59e" alt="Stars Badge"](https://github.com/Thalhammer/jwt-cpp/stargazers)
|
||
[data:image/s3,"s3://crabby-images/dbf93/dbf9366f5b03afbcec7301ad4cc59555379affa8" alt="GitHub release (latest SemVer including pre-releases)"](https://github.com/Thalhammer/jwt-cpp/releases)
|
||
[data:image/s3,"s3://crabby-images/fc872/fc872a19ac2c11546a45c1a597b0d7821c0ac578" alt="ConanCenter package"](https://repology.org/project/jwt-cpp/versions)
|
||
[data:image/s3,"s3://crabby-images/33ca2/33ca2c845d0aaf9af3b746a64372d4b5254be3af" alt="Vcpkg package"](https://repology.org/project/jwt-cpp/versions)
|
||
|
||
[Linux]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/cross-platform/ubuntu-latest/shields.json
|
||
[MacOS]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/cross-platform/macos-latest/shields.json
|
||
[Windows]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/cross-platform/windows-latest/shields.json
|
||
[Cross-Platform]: https://github.com/Thalhammer/jwt-cpp/actions?query=workflow%3A%22Cross-Platform+CI%22
|
||
|
||
A header only library for creating and validating [JSON Web Tokens](https://tools.ietf.org/html/rfc7519) in C++11. For a great introduction, [read this](https://jwt.io/introduction/).
|
||
|
||
## Signature algorithms
|
||
|
||
jwt-cpp supports all the algorithms defined by the specifications. The modular design allows to easily add additional algorithms without any problems. If you need any feel free to create a pull request or [open an issue](https://github.com/Thalhammer/jwt-cpp/issues/new).
|
||
|
||
For completeness, here is a list of all supported algorithms:
|
||
|
||
| HMSC | RSA | ECDSA | PSS | EdDSA |
|
||
|-------|-------|--------|-------|---------|
|
||
| HS256 | RS256 | ES256 | PS256 | Ed25519 |
|
||
| HS384 | RS384 | ES384 | PS384 | Ed448 |
|
||
| HS512 | RS512 | ES512 | PS512 | |
|
||
| | | ES256K | | |
|
||
|
||
## SSL Compatibility
|
||
|
||
In the name of flexibility and extensibility, jwt-cpp supports [OpenSSL](https://github.com/openssl/openssl), [LibreSSL](https://github.com/libressl-portable/portable), and [wolfSSL](https://github.com/wolfSSL/wolfssl). Read [this page](docs/ssl.md) for more details. These are the version which are currently being tested:
|
||
|
||
| OpenSSL | LibreSSL | wolfSSL |
|
||
|-------------------|----------------|----------------|
|
||
| ![1.0.2u][o1.0.2] | ![3.3.6][l3.3] | ![5.1.1][w5.1] |
|
||
| ![1.1.0i][o1.1.0] | ![3.4.3][l3.4] | ![5.2.0][w5.2] |
|
||
| ![1.1.1q][o1.1.1] | ![3.5.3][l3.5] | ![5.3.0][w5.3] |
|
||
| ![3.0.5][o3.0] | | |
|
||
|
||
> ℹ️ Note: A complete list of versions tested in the past can be found [here](https://github.com/Thalhammer/jwt-cpp/tree/badges).
|
||
|
||
[o1.0.2]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/openssl/1.0.2u/shields.json
|
||
[o1.1.0]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/openssl/1.1.0i/shields.json
|
||
[o1.1.1]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/openssl/1.1.1q/shields.json
|
||
[o3.0]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/openssl/3.0.5/shields.json
|
||
[l3.3]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/libressl/3.3.6/shields.json
|
||
[l3.4]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/libressl/3.4.3/shields.json
|
||
[l3.5]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/libressl/3.5.3/shields.json
|
||
[w5.1]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/wolfssl/5.1.1/shields.json
|
||
[w5.2]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/wolfssl/5.2.0/shields.json
|
||
[w5.3]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/wolfssl/5.3.0/shields.json
|
||
|
||
## Overview
|
||
|
||
There is no hard dependency on a JSON library. Instead, there's a generic `jwt::basic_claim` which is templated around type traits, which described the semantic [JSON types](https://json-schema.org/understanding-json-schema/reference/type.html) for a value, object, array, string, number, integer and boolean, as well as methods to translate between them.
|
||
|
||
```cpp
|
||
jwt::basic_claim<my_favorite_json_library_traits> claim(json::object({{"json", true},{"example", 0}}));
|
||
```
|
||
|
||
This allows for complete freedom when picking which libraries you want to use. For more information, [read this page](docs/traits.md)).
|
||
|
||
For your convenience there are serval traits implementation which provide some popular JSON libraries. They are:
|
||
|
||
[![picojson][picojson]](https://github.com/kazuho/picojson)
|
||
[![nlohmann][nlohmann]](https://github.com/nlohmann/json)
|
||
[![jsoncons][jsoncons]](https://github.com/danielaparker/jsoncons)
|
||
[![boostjson][boostjson]](https://github.com/boostorg/json)
|
||
|
||
[picojson]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/traits/kazuho-picojson/shields.json
|
||
[nlohmann]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/traits/nlohmann-json/shields.json
|
||
[jsoncons]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/traits/danielaparker-jsoncons/shields.json
|
||
[boostjson]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/Thalhammer/jwt-cpp/badges/traits/boost-json/shields.json
|
||
|
||
In order to maintain compatibility, [picojson](https://github.com/kazuho/picojson) is still used to provide a specialized `jwt::claim` along with all helpers. Defining `JWT_DISABLE_PICOJSON` will remove this optional dependency. It's possible to directly include the traits defaults for the other JSON libraries. See the [traits examples](https://github.com/Thalhammer/jwt-cpp/tree/master/example/traits) for details.
|
||
|
||
As for the base64 requirements of JWTs, this library provides `base.h` with all the required implementation; However base64 implementations are very common, with varying degrees of performance. When providing your own base64 implementation, you can define `JWT_DISABLE_BASE64` to remove the jwt-cpp implementation.
|
||
|
||
### Getting Started
|
||
|
||
Simple example of decoding a token and printing all [claims](https://tools.ietf.org/html/rfc7519#section-4) ([try it out](https://github.com/Thalhammer/jwt-cpp/tree/master/example/print-claims.cpp)):
|
||
|
||
```cpp
|
||
#include <jwt-cpp/jwt.h>
|
||
#include <iostream>
|
||
|
||
int main() {
|
||
std::string token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXUyJ9.eyJpc3MiOiJhdXRoMCJ9.AbIJTDMFc7yUa5MhvcP03nJPyCPzZtQcGEp-zWfOkEE";
|
||
auto decoded = jwt::decode(token);
|
||
|
||
for(auto& e : decoded.get_payload_json())
|
||
std::cout << e.first << " = " << e.second << std::endl;
|
||
}
|
||
```
|
||
|
||
In order to verify a token you first build a verifier and use it to verify a decoded token.
|
||
|
||
```cpp
|
||
auto verifier = jwt::verify()
|
||
.allow_algorithm(jwt::algorithm::hs256{ "secret" })
|
||
.with_issuer("auth0");
|
||
|
||
verifier.verify(decoded_token);
|
||
```
|
||
|
||
The created verifier is stateless so you can reuse it for different tokens.
|
||
|
||
Creating a token (and signing) is equally as easy.
|
||
|
||
```cpp
|
||
auto token = jwt::create()
|
||
.set_issuer("auth0")
|
||
.set_type("JWS")
|
||
.set_payload_claim("sample", jwt::claim(std::string("test")))
|
||
.sign(jwt::algorithm::hs256{"secret"});
|
||
```
|
||
|
||
> To see more examples working with RSA public and private keys, visit our [examples](https://github.com/Thalhammer/jwt-cpp/tree/master/example)!
|
||
|
||
### Providing your own JSON Traits
|
||
|
||
To learn how to writes a trait's implementation, checkout the [these instructions](docs/traits.md)
|
||
|
||
## Contributing
|
||
|
||
If you have an improvement or found a bug feel free to [open an issue](https://github.com/Thalhammer/jwt-cpp/issues/new) or add the change and create a pull request. If you file a bug please make sure to include as much information about your environment (compiler version, etc.) as possible to help reproduce the issue. If you add a new feature please make sure to also include test cases for it.
|
||
|
||
## Dependencies
|
||
|
||
In order to use jwt-cpp you need the following tools.
|
||
|
||
* libcrypto (openssl or compatible)
|
||
* libssl-dev (for the header files)
|
||
* a compiler supporting at least c++11
|
||
* basic stl support
|
||
|
||
In order to build the test cases you also need
|
||
|
||
* gtest
|
||
* pthread
|
||
|
||
## Troubleshooting
|
||
|
||
See the [FAQs](docs/faqs.md) for tips.
|
||
|
||
## Conference Coverage
|
||
[data:image/s3,"s3://crabby-images/ab2d3/ab2d396b2be9c6d558b4be133345cbbd34f799b1" alt="CppCon"](https://www.youtube.com/watch?v=Oq4NW5idmiI)
|