Let's consider a current simplified version of NSM authorization.
Note: This scheme simplified many of the complex things that happen in every client and endpoint for simplicity. To understand it in deep consider looking at the source code of applications.
Each application in the path of NSM request doesn't trust anybody. Each endpoint doesn't trust the client and on each incoming request the endpoint validates tokens in the path and if they invalid then the endpoint returns an error. Each client also doesn't trust the endpoint and checks tokens on the response.
Authorization checks enabled by default in NSM. For example, all use-cases are using valid token chains by default.
The example below will do token from step1 from the scheme as invalid. Expected that Endpoint(in this case NSMgr) will fail the Request from the client on step 4.
Deploy NSC and NSE:
kubectl apply -k https://github.com/networkservicemesh/deployments-k8s/examples/features/opa?ref=c7fb59371de99069e4be8147176a2fb2af8a08a4
Wait for applications ready:
kubectl wait --for=condition=ready --timeout=1m pod -l app=nsc-kernel -n ns-opa
kubectl wait --for=condition=ready --timeout=1m pod -l app=nse-kernel -n ns-opa
Check that NSC is not privileged and it cannot connect to NSE.
kubectl logs deployments/nsc-kernel -n ns-opa | grep "PermissionDenied desc = no sufficient privileges"
Delete ns:
kubectl delete ns ns-opa