Add context methods for the authority database

This commit is contained in:
Mariano Cano 2022-04-27 12:05:19 -07:00
parent 00f181dec3
commit 0446e82320
2 changed files with 29 additions and 4 deletions

View file

@ -308,11 +308,12 @@ func (ca *CA) Init(cfg *config.Config) (*CA, error) {
// buildContext builds the server base context. // buildContext builds the server base context.
func buildContext(a *authority.Authority) context.Context { func buildContext(a *authority.Authority) context.Context {
ctx := authority.NewContext(context.Background(), a) ctx := authority.NewContext(context.Background(), a)
if authDB := a.GetDatabase(); authDB != nil {
if db := a.GetAdminDatabase(); db != nil { ctx = db.NewContext(ctx, authDB)
ctx = admin.NewContext(ctx, db) }
if adminDB := a.GetAdminDatabase(); adminDB != nil {
ctx = admin.NewContext(ctx, adminDB)
} }
return ctx return ctx
} }

View file

@ -1,6 +1,7 @@
package db package db
import ( import (
"context"
"crypto/x509" "crypto/x509"
"encoding/json" "encoding/json"
"strconv" "strconv"
@ -58,6 +59,29 @@ type AuthDB interface {
Shutdown() error Shutdown() error
} }
type dbKey struct{}
// NewContext adds the given authority database to the context.
func NewContext(ctx context.Context, db AuthDB) context.Context {
return context.WithValue(ctx, dbKey{}, db)
}
// FromContext returns the current authority database from the given context.
func FromContext(ctx context.Context) (db AuthDB, ok bool) {
db, ok = ctx.Value(dbKey{}).(AuthDB)
return
}
// MustFromContext returns the current database from the given context. It
// will panic if it's not in the context.
func MustFromContext(ctx context.Context) AuthDB {
if db, ok := FromContext(ctx); !ok {
panic("authority database is not in the context")
} else {
return db
}
}
// DB is a wrapper over the nosql.DB interface. // DB is a wrapper over the nosql.DB interface.
type DB struct { type DB struct {
nosql.DB nosql.DB