Skip to content

Commit

Permalink
Add example for using raw JWT (#967)
Browse files Browse the repository at this point in the history
* Add example for using raw JWT

* typo
  • Loading branch information
lestrrat authored Aug 14, 2023
1 parent bc71a61 commit f592f32
Show file tree
Hide file tree
Showing 2 changed files with 58 additions and 0 deletions.
10 changes: 10 additions & 0 deletions docs/01-jwt.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ In this document we describe how to work with JWT using `github.com/lestrrat-go/
* [Serialize using JWE and JWS](#serialize-using-jwe-and-jws)
* [Serialize the `aud` field as a string](#serialize-aud-field-as-a-string)
* [Working with JWT](#working-with-jwt)
* [Performance](#performance)
* [Access JWS headers](#access-jws-headers)
* [Get/Set fields](#getset-fields)

Expand Down Expand Up @@ -1157,6 +1158,15 @@ source: [examples/jwt_flatten_audience_example_test.go](https://github.com/lestr

# Working with JWT

## Performance

github.com/lestrrat-go/jwx is focused on usability / stable API. If you are worried about performance while processing JWTs, the best path is just to use a plain struct after handling JWS yourself:

<!-- INCLUDE(examples/jwt_raw_struct_example_test.go) -->
<!-- END INCLUDE -->

This makes sure that you do not go through any extra layers of abstraction that causes performance panalties, and you get exactly the type of field that you want.

## Access JWS headers

The RFC defines JWS as an envelope to JWT (JWS can carry any payload, you just happened to assign a JWT to it). A JWT is just a bag of arbitrary key/value pairs, where some of them are predefined for validation. This means that JWS headers are NOT part of a JWT -- and thus you will not be able to access them through the `jwt.Token` itself.
Expand Down
48 changes: 48 additions & 0 deletions examples/jwt_raw_struct_example_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
package examples

import (
"encoding/json"
"fmt"
"os"

"github.com/lestrrat-go/jwx/v2/jwa"
"github.com/lestrrat-go/jwx/v2/jws"
"github.com/lestrrat-go/jwx/v2/jwt"
)

func ExampleJWTPlainStruct() {
t1, err := jwt.NewBuilder().
Issuer("https://github.com/lestrrat-go/jwx/v2/examples").
Subject("raw_struct").
Claim("private", "foobar").
Build()
if err != nil {
fmt.Fprintf(os.Stderr, "failed to build JWT: %s\n", err)
}

key := []byte("secret")
signed, err := jwt.Sign(t1, jwt.WithKey(jwa.HS256, key))
if err != nil {
fmt.Printf("failed to sign JWT: %s\n", err)
}

rawJWT, err := jws.Verify(signed, jws.WithKey(jwa.HS256, key))
if err != nil {
fmt.Printf("failed to verify JWS: %s\n", err)
}

type MyToken struct {
Issuer string `json:"iss"`
Subject string `json:"sub"`
Private string `json:"private"`
}

var t2 MyToken
if err := json.Unmarshal(rawJWT, &t2); err != nil {
fmt.Printf("failed to unmarshal JWT: %s\n", err)
}

fmt.Printf("%s\n", t2.Private)
// OUTPUT:
// foobar
}

0 comments on commit f592f32

Please sign in to comment.