add storage-auth-bearer

This commit is contained in:
A.Unger
2021-03-04 15:18:35 +01:00
parent 308467b134
commit 7e834c11d6
2 changed files with 43 additions and 1 deletions

View File

@@ -49,7 +49,7 @@ var (
"storage-userprovider", // done
"storage-groupprovider", // done
"storage-auth-basic", // done
"storage-auth-bearer",
"storage-auth-bearer", // done
"storage-home",
"storage-users",
"storage-public-link",
@@ -132,6 +132,7 @@ func (r *Runtime) Start() error {
addServiceToken("users", supervisor.Add(storage.NewUsersProviderService(globalCtx, r.c.Storage)))
addServiceToken("groupsprovider", supervisor.Add(storage.NewGroupsProvider(globalCtx, r.c.Storage))) // TODO(refs) panic? are we sending to a nil / closed channel?
addServiceToken("authbasic", supervisor.Add(storage.NewAuthBasic(globalCtx, r.c.Storage)))
addServiceToken("authbearer", supervisor.Add(storage.NewAuthBearer(globalCtx, r.c.Storage)))
// TODO(refs) debug line with supervised services.
go supervisor.ServeBackground()

View File

@@ -2,6 +2,7 @@ package command
import (
"context"
"flag"
"os"
"os/signal"
"path"
@@ -178,3 +179,43 @@ func AuthBearer(cfg *config.Config) *cli.Command {
},
}
}
// AuthBearerSutureService allows for the storage-gateway command to be embedded and supervised by a suture supervisor tree.
type AuthBearerSutureService struct {
ctx context.Context
cancel context.CancelFunc // used to cancel the context go-micro services used to shutdown a service.
cfg *config.Config
}
// NewAuthBearerSutureService creates a new gateway.AuthBearerSutureService
func NewAuthBearer(ctx context.Context, cfg *config.Config) AuthBearerSutureService {
sctx, cancel := context.WithCancel(ctx)
cfg.Context = sctx
return AuthBearerSutureService{
ctx: sctx,
cancel: cancel,
cfg: cfg,
}
}
func (s AuthBearerSutureService) Serve() {
f := &flag.FlagSet{}
for k := range AuthBearer(s.cfg).Flags {
if err := AuthBearer(s.cfg).Flags[k].Apply(f); err != nil {
return
}
}
ctx := cli.NewContext(nil, f, nil)
if AuthBearer(s.cfg).Before != nil {
if err := AuthBearer(s.cfg).Before(ctx); err != nil {
return
}
}
if err := AuthBearer(s.cfg).Action(ctx); err != nil {
return
}
}
func (s AuthBearerSutureService) Stop() {
s.cancel()
}