-
Notifications
You must be signed in to change notification settings - Fork 54
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add RBAC, gNOI, API Versioning and Bulk Set operations. (#61)
* Add gnoi infra with only time rpc implemented * Remove unimplemeneted functions from gnoi_client * Remove unimplemented sonic proto, will submit seperate PR for those rpc's * Make gNOI active only on writable mode * Add basic auth changes * Fix Makefile * Fixes * Remove allow_no_client_auth option and instead use ca option to determine if client cert is required * Add autheticate call to gNOI function calls * Add client certificate authentication mode * Add JWT based authentication and authorization mechanism * Add ShowTechSupport gNOI function * Register gNOI System service on gRPC server * Register Sonic gnoi service. Remove other Sonic gNOI RPCs until a later PR * Update proto and add missing deps * Add translib RPC helper function to call from gNOI RPCs * Forgot to add Refresh RPC to proto * Add authenticate and refresh rpcs to gnoi client * Add showTechSupport rpc to gnoi client * Add copyConfig gNOI RPC * Add image mgmt gNOI RPCs * Add image clear neighbors gNOI RPC * Add client patches * Add yang versioning feature * Pass auth info to translib API calls * Add Bulk Set support * Add context when creating transl data client for passing authentication * Add extensions list to NewTranslClient * Check yang bundle version in all actions * Add yang bundle version check to Bulk set * Update error message * Use correct operations and fix error messages * Add yang version check in TranslSubscribe function * Add tlerr library * Add yang version info to Capabilities response extensions * Add support for UpdatesOnly subscribe option * Remove duplicate gnoi service registration * In order to support JWT Auth in read-only mode, separate out JWT RPCs into another proto package * Address review comments, fix build issue * Fix bulk bundle version check * Add unit tests for new features * Add error message to audit log * Change defaults for auth and client cert back * Fix missing jwt mode in client_auth options * Enable default auth modes only in read/write mode * Fix merge build issue
- Loading branch information
1 parent
c9a0cb2
commit 4fcd5b6
Showing
29 changed files
with
8,331 additions
and
260 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
package common_utils | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"sync/atomic" | ||
) | ||
|
||
|
||
// AuthInfo holds data about the authenticated user | ||
type AuthInfo struct { | ||
// Username | ||
User string | ||
AuthEnabled bool | ||
// Roles | ||
Roles []string | ||
} | ||
|
||
// RequestContext holds metadata about REST request. | ||
type RequestContext struct { | ||
|
||
// Unique reqiest id | ||
ID string | ||
|
||
// Auth contains the authorized user information | ||
Auth AuthInfo | ||
|
||
//Bundle Version is the release yang models version. | ||
BundleVersion *string | ||
} | ||
|
||
type contextkey int | ||
|
||
const requestContextKey contextkey = 0 | ||
|
||
// Request Id generator | ||
var requestCounter uint64 | ||
|
||
// GetContext function returns the RequestContext object for a | ||
// gRPC request. RequestContext is maintained as a context value of | ||
// the request. Creates a new RequestContext object is not already | ||
// available. | ||
func GetContext(ctx context.Context) (*RequestContext, context.Context) { | ||
cv := ctx.Value(requestContextKey) | ||
if cv != nil { | ||
return cv.(*RequestContext), ctx | ||
} | ||
|
||
rc := new(RequestContext) | ||
rc.ID = fmt.Sprintf("TELEMETRY-%v", atomic.AddUint64(&requestCounter, 1)) | ||
|
||
ctx = context.WithValue(ctx, requestContextKey, rc) | ||
return rc, ctx | ||
} | ||
|
||
func GetUsername(ctx context.Context, username *string) { | ||
rc, ctx := GetContext(ctx) | ||
if rc != nil { | ||
*username = rc.Auth.User | ||
} | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
package gnmi | ||
|
||
import ( | ||
"github.com/Azure/sonic-telemetry/common_utils" | ||
"github.com/golang/glog" | ||
"golang.org/x/net/context" | ||
"google.golang.org/grpc/codes" | ||
"google.golang.org/grpc/metadata" | ||
"google.golang.org/grpc/status" | ||
) | ||
|
||
func BasicAuthenAndAuthor(ctx context.Context) (context.Context, error) { | ||
rc, ctx := common_utils.GetContext(ctx) | ||
md, ok := metadata.FromIncomingContext(ctx) | ||
if !ok { | ||
return ctx, status.Errorf(codes.Unknown, "Invalid context") | ||
} | ||
|
||
var username string | ||
var passwd string | ||
if username_a, ok := md["username"]; ok { | ||
username = username_a[0] | ||
} else { | ||
return ctx, status.Errorf(codes.Unauthenticated, "No Username Provided") | ||
} | ||
|
||
if passwd_a, ok := md["password"]; ok { | ||
passwd = passwd_a[0] | ||
} else { | ||
return ctx, status.Errorf(codes.Unauthenticated, "No Password Provided") | ||
} | ||
if err := PopulateAuthStruct(username, &rc.Auth, nil); err != nil { | ||
glog.Infof("[%s] Failed to retrieve authentication information; %v", rc.ID, err) | ||
return ctx, status.Errorf(codes.Unauthenticated, "") | ||
} | ||
auth_success, _ := UserPwAuth(username, passwd) | ||
if auth_success == false { | ||
return ctx, status.Errorf(codes.PermissionDenied, "Invalid Password") | ||
} | ||
|
||
return ctx, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
package gnmi | ||
|
||
import ( | ||
"github.com/Azure/sonic-telemetry/common_utils" | ||
"github.com/golang/glog" | ||
"golang.org/x/net/context" | ||
"google.golang.org/grpc/codes" | ||
"google.golang.org/grpc/credentials" | ||
"google.golang.org/grpc/peer" | ||
"google.golang.org/grpc/status" | ||
) | ||
|
||
func ClientCertAuthenAndAuthor(ctx context.Context) (context.Context, error) { | ||
rc, ctx := common_utils.GetContext(ctx) | ||
p, ok := peer.FromContext(ctx) | ||
if !ok { | ||
return ctx, status.Error(codes.Unauthenticated, "no peer found") | ||
} | ||
tlsAuth, ok := p.AuthInfo.(credentials.TLSInfo) | ||
if !ok { | ||
return ctx, status.Error(codes.Unauthenticated, "unexpected peer transport credentials") | ||
} | ||
if len(tlsAuth.State.VerifiedChains) == 0 || len(tlsAuth.State.VerifiedChains[0]) == 0 { | ||
return ctx, status.Error(codes.Unauthenticated, "could not verify peer certificate") | ||
} | ||
|
||
var username string | ||
|
||
username = tlsAuth.State.VerifiedChains[0][0].Subject.CommonName | ||
|
||
if len(username) == 0 { | ||
return ctx, status.Error(codes.Unauthenticated, "invalid username in certificate common name.") | ||
} | ||
|
||
if err := PopulateAuthStruct(username, &rc.Auth, nil); err != nil { | ||
glog.Infof("[%s] Failed to retrieve authentication information; %v", rc.ID, err) | ||
return ctx, status.Errorf(codes.Unauthenticated, "") | ||
} | ||
|
||
return ctx, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.