mirror of
https://github.com/grafana/grafana.git
synced 2024-12-01 21:19:28 -06:00
a94acb7f61
* GRPC Server: Add signedInUser to context after auth * add permissions to signedInUser * add access control permissions test * add additional signedInUser checks * get user from context * move `UserFromContext` to object/auth.go Co-authored-by: Todd Treece <todd.treece@grafana.com>
27 lines
658 B
Go
27 lines
658 B
Go
package object
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/grafana/grafana/pkg/models"
|
|
"github.com/grafana/grafana/pkg/services/contexthandler/ctxkey"
|
|
grpccontext "github.com/grafana/grafana/pkg/services/grpcserver/context"
|
|
"github.com/grafana/grafana/pkg/services/user"
|
|
)
|
|
|
|
// UserFromContext ** Experimental **
|
|
// TODO: move to global infra package / new auth service
|
|
func UserFromContext(ctx context.Context) *user.SignedInUser {
|
|
grpcCtx := grpccontext.FromContext(ctx)
|
|
if grpcCtx != nil {
|
|
return grpcCtx.SignedInUser
|
|
}
|
|
|
|
c, ok := ctxkey.Get(ctx).(*models.ReqContext)
|
|
if !ok || c == nil || c.SignedInUser == nil {
|
|
return nil
|
|
}
|
|
|
|
return c.SignedInUser
|
|
}
|