Cute Gopher Mascot

The Best Go Libraries For Authentication and Authorization (41)

Discover the best Go libraries for Authentication and Authorization! Find the perfect tools to streamline your development and boost productivity. From jwx to go-guardian, we've got you covered. Let the coding begin!

jwx

Go module implementing various JWx (JWA/JWE/JWK/JWS/JWT, otherwise known as JOSE) technologies

See More! 🚀

go-guardian

Go-Guardian is a golang library that provides a simple, clean, and idiomatic way to create powerful modern API and web authentication that supports LDAP, Basic, Bearer token, and Certificate based authentication

See More! 🚀

go-jose

Fairly complete implementation of the JOSE working group's JSON Web Token, JSON Web Signatures, and JSON Web Encryption specs

See More! 🚀

gologin

chainable handlers for login with OAuth1 and OAuth2 authentication providers

See More! 🚀

gorbac

provides a lightweight role-based access control (RBAC) implementation in Golang

See More! 🚀

goth

provides a simple, clean, and idiomatic way to use OAuth and OAuth2. Handles multiple providers out of the box

See More! 🚀

jeff

Simple, flexible, secure, and idiomatic web session management with pluggable backends

See More! 🚀

jwt

Lightweight JSON Web Token (JWT) library

See More! 🚀

jwt-auth

JWT middleware for Golang http servers with many configuration options

See More! 🚀

loginsrv

JWT login microservice with pluggable backends such as OAuth2 (Github), htpasswd, osiam

See More! 🚀

oidc

Easy to use OpenID Connect client and server library written for Go and certified by the OpenID Foundation

See More! 🚀

openfga

Implementation of fine-grained authorization based on the "Zanzibar: Google's Consistent, Global Authorization System" paper. Backed by [CNCF](https://www.cncf.io/)

See More! 🚀

osin

Golang OAuth2 server library

See More! 🚀

otpgo

Time-Based One-Time Password (TOTP) and HMAC-Based One-Time Password (HOTP) library for Go

See More! 🚀

paseto

Golang implementation of Platform-Agnostic Security Tokens (PASETO)

See More! 🚀

scope

Easily Manage OAuth2 Scopes In Go

See More! 🚀

scs

Session Manager for HTTP servers

See More! 🚀

securecookie

Efficient secure cookie encoding/decoding

See More! 🚀

session

Go session management for web servers (including support for Google App Engine - GAE)

See More! 🚀

sessions

Dead simple, highly performant, highly customizable sessions service for go http servers

See More! 🚀

sessionup

Simple, yet effective HTTP session management and identification package

See More! 🚀

sjwt

Simple jwt generator and parser

See More! 🚀

jwt-go

A full featured implementation of JSON Web Tokens (JWT). This library supports the parsing and verification as well as the generation and signing of JWTs

See More! 🚀

authboss

Modular authentication system for the web. It tries to remove as much boilerplate and "hard things" as possible so that each time you start a new web project in Go, you can plug it in, configure it, and start building your app without having to build an authentication system each time

See More! 🚀

casbin

Authorization library that supports access control models like ACL, RBAC, and ABAC

See More! 🚀

cookiestxt

provides a parser of cookies.txt file format

See More! 🚀

jwt

Safe, simple, and fast JSON Web Tokens for Go

See More! 🚀

oauth2

Successor of goauth2. Generic OAuth 2.0 package that comes with JWT, Google APIs, Compute Engine, and App Engine support

See More! 🚀

otpgen

Library to generate TOTP/HOTP codes

See More! 🚀

x509proxy

Library to handle X509 proxy certificates

See More! 🚀

go-iam

Developer-first Identity and Access Management system with a simple UI

See More! 🚀

go-jwt

JWT authentication package providing access tokens and refresh tokens with fingerprinting, Redis storage, and automatic refresh capabilities

See More! 🚀

branca

branca token [specification implementation](https://github.com/tuupola/branca-spec) for Golang 1.15+

See More! 🚀

go-githubauth

Utilities for GitHub authentication: generate and use GitHub application and installation tokens

See More! 🚀

authgate

A lightweight OAuth 2.0 Authorization Server supporting Device Authorization Grant ([RFC 8628](https://datatracker.ietf.org/doc/html/rfc8628)), Authorization Code Flow with PKCE ([RFC 6749](https://datatracker.ietf.org/doc/html/rfc6749) + [RFC 7636](https://datatracker.ietf.org/doc/html/rfc7636)), and Client Credentials Grant for machine-to-machine authentication

See More! 🚀

go-jwt

A JWT (JSON Web Token) library for Go

See More! 🚀

goiabada

An open-source authentication and authorization server supporting OAuth2 and OpenID Connect

See More! 🚀

gosession

This is quick session for net/http in GoLang. This package is perhaps the best implementation of the session mechanism, or at least it tries to become one

See More! 🚀

permissions

Library for keeping track of users, login states, and permissions. Uses secure cookies and bcrypt

See More! 🚀

spicedb

A Zanzibar-inspired database that enables fine-grained authorization

See More! 🚀

keto

Open Source (Go) implementation of "Zanzibar: Google's Consistent, Global Authorization System". Ships gRPC, REST APIs, newSQL, and an easy and granular permission language. Supports ACL, RBAC, and other access models

See More! 🚀