Documentation ¶
Overview ¶
Package guardian . Go-Guardian is a golang library that provides a simple, clean, and idiomatic way to create powerful modern API and web authentication.
Go-Guardian sole purpose is to authenticate requests, which it does through an extensible set of authentication methods known as strategies. Go-Guardian does not mount routes or assume any particular database schema, which maximizes flexibility and allows decisions to be made by the developer. The API is simple: you provide go-guardian a request to authenticate, and go-guardian invoke strategies to authenticate end-user request. Strategies provide callbacks for controlling what occurs when authentication `should` succeeds or fails.
Why Go-Guardian?
When building a modern application, you don't want to implement authentication module from scratch; you want to focus on building awesome software. go-guardian is here to help with that.
Here are a few bullet point reasons you might like to try it out:
- provides simple, clean, and idiomatic API.
- provides top trends and traditional authentication methods.
- provides a package to caches the authentication decisions, based on different mechanisms and algorithms.
- provides two-factor authentication and one-time password as defined in [RFC-4226](https://tools.ietf.org/html/rfc4226) and [RFC-6238](https://tools.ietf.org/html/rfc6238)
- provides a mechanism to customize strategies, even enables writing a custom strategy
Example:
package main import ( "crypto/x509" "encoding/pem" "io/ioutil" "log" "net/http" "github.com/gorilla/mux" "github.com/shaj13/go-guardian/auth" x509Strategy "github.com/shaj13/go-guardian/auth/strategies/x509" ) var authenticator auth.Authenticator func middleware(next http.Handler) http.HandlerFunc { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { log.Println("Executing Auth Middleware") user, err := authenticator.Authenticate(r) if err != nil { code := http.StatusUnauthorized http.Error(w, http.StatusText(code), code) return } log.Printf("User %s Authenticated\n", user.UserName()) next.ServeHTTP(w, r) }) } func Handler(w http.ResponseWriter, r *http.Request) { w.Write([]byte("Handler!!\n")) } func main() { opts := x509.VerifyOptions{} opts.KeyUsages = []x509.ExtKeyUsage{x509.ExtKeyUsageClientAuth} opts.Roots = x509.NewCertPool() // Read Root Ca Certificate opts.Roots.AddCert(readCertificate("/<your-path>/<ca-name>")) // create strategy and bind it to authenticator. strategy := x509Strategy.New(opts) authenticator = auth.New() authenticator.EnableStrategy(x509Strategy.StrategyKey, strategy) r := mux.NewRouter() r.HandleFunc("/", middleware(http.HandlerFunc(Handler))) log.Fatal(http.ListenAndServeTLS(":8080", "<cert>", "<key>", r)) } func readCertificate(file string) *x509.Certificate { data, err := ioutil.ReadFile(file) if err != nil { log.Fatalf("error reading %s: %v", file, err) } p, _ := pem.Decode(data) cert, err := x509.ParseCertificate(p.Bytes) if err != nil { log.Fatalf("error parseing certificate %s: %v", file, err) } return cert }
Directories ¶
Path | Synopsis |
---|---|
_examples
|
|
strategies/basic
Package basic provides authentication strategy, to authenticate HTTP requests using the standard basic scheme.
|
Package basic provides authentication strategy, to authenticate HTTP requests using the standard basic scheme. |
strategies/bearer
Package bearer provides authentication strategy, to authenticate HTTP requests based on the bearer token.
|
Package bearer provides authentication strategy, to authenticate HTTP requests based on the bearer token. |
strategies/digest
Package digest provides authentication strategy, to authenticate HTTP requests using the standard digest scheme as described in RFC 7616.
|
Package digest provides authentication strategy, to authenticate HTTP requests using the standard digest scheme as described in RFC 7616. |
strategies/kubernetes
Package kubernetes provide auth strategy to authenticate, incoming HTTP requests using a Kubernetes Service Account Token.
|
Package kubernetes provide auth strategy to authenticate, incoming HTTP requests using a Kubernetes Service Account Token. |
strategies/ldap
Package ldap provides authentication strategy, to authenticate HTTP requests and builds, extracts user informations from LDAP Server.
|
Package ldap provides authentication strategy, to authenticate HTTP requests and builds, extracts user informations from LDAP Server. |
strategies/x509
Package x509 provides authentication strategy, to authenticate HTTPS requests and builds, extracts user informations from client certificates.
|
Package x509 provides authentication strategy, to authenticate HTTPS requests and builds, extracts user informations from client certificates. |
Package store provides different cache mechanisms and algorithms, To caches the authentication decisions.
|
Package store provides different cache mechanisms and algorithms, To caches the authentication decisions. |
Package tfa (two-factor authentication) provides a simple, clean, and idiomatic way for generating and verifying one-time passwords for both HOTP and TOTP defined in RFC 4226 and 6238.
|
Package tfa (two-factor authentication) provides a simple, clean, and idiomatic way for generating and verifying one-time passwords for both HOTP and TOTP defined in RFC 4226 and 6238. |