/guile-jwt

JSON Web Token module for Guile

Primary LanguageM4GNU General Public License v3.0GPL-3.0

guile-jwt

guile-jwt is a JSON Web Token module for Guile. JSON Web Tokens are an open, industry standard (RFC 7519) method for representing claims securely between two parties. guile-jwt allows you to decode, verify and generate JWT.

  • Supported algorithms: HS256, HS384, HS512.

It depends on the following Guile version and modules:

  • Guile >= 2.0.10
  • guile-gcrypt >= 0.4.0
  • guile-json >= 4.5.0

Installation

Download the latest tarball and untar it:

If you are cloning the repository make sure you run this first:

$ autoreconf -vif

Then, run the typical sequence:

$ ./configure --prefix=<guile-prefix>
$ make
$ sudo make install

Where should preferably be the same as your system Guile installation directory (e.g. /usr).

If everything installed successfully you should be up and running:

$ guile
scheme@(guile-user)> (use-modules (jwt))
scheme@(guile-user)> (jwt-encode '((test . "1234567890")) "secret")
"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."

It might be that you installed guile-jwt somewhere differently than your system's Guile. If so, you need to indicate Guile where to find guile-jwt, for example:

$ GUILE_LOAD_PATH=/usr/local/share/guile/site guile

Usage

guile-jwt provides a couple procedures, one to generate a JWT and another to verify it.

To start using guile-jwt you simply need to load the module:

scheme@(guile-user)> (use-modules (jwt))

Procedures

  • (jwt-encode payload secret #:key algorithm header) : Creates a new JWT with the given payload and the specified secret. Throws jwt-invalid-algorithm if a not supported or invalid algorithm is provided.

    • algorithm : symbol specifying signing algorithm. Defaults to HS256.
    • header : association list with additional header fields.

    Returns : a JWT string.

    Throws

    • jwt-invalid-algorithm : if a not supported or invalid algorithm is given.
  • (jwt-decode jwt secret #:key verify) : Decodes the given JWT jwt with the specified secret. The algorithm to verify the signature will be extracted from the JWT header.

    • verify : verify JWT signature and fields. Defaults to true.

    Returns : an alist with the payload.

    Throws

    • jwt-invalid-algorithm : if a not supported or invalid algorithm is found in the header.
    • jwt-invalid : if the JWT is invalid.

Examples

  • Generate a JWT with the default HS256 algorithm and a given payload:
scheme@(guile-user)> (jwt-encode '((test . "1234567890")) "secret")
"...7HFTJOiPGdXmk0G1rqzhpZV_POhjRrTBlR_WOC8-_L0"
  • Generate a JWT with the HS512 algorithm and a given payload:
scheme@(guile-user)> (jwt-encode '((test . "1234567890")) "secret" #:algorithm 'HS512)
"...Yv9ivHlSk-94djH4Qv_k1nkeyAQzN41iN9aEcdQIOgOkmxp0zb725ogOFm52snD_DfQk8u1-tayRXj6cMlagtA"
  • Generate a JWT with a payload and additional headers:
scheme@(guile-user)> (jwt-encode '((test . "1234567890")) "secret" #:header '((foo . bar)))
"...MIgbpMmk9MkzbG0a4NYttv5FoJx72pz6wL0iu_pPSkE"
  • Verify a JWT:
scheme@(guile-user)> (define jwt (jwt-encode '((test . "1234567890")) "secret"))
scheme@(guile-user)> (define payload (jwt-decode jwt "secret"))
scheme@(guile-user)> (assoc-ref payload "test")
"1234567890"

License

Copyright (C) 2018-2022 Aleix Conchillo Flaque aconchillo@gmail.com

guile-jwt is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.

guile-jwt is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with guile-jwt. If not, see https://www.gnu.org/licenses/.