Skip to content

This repository contains the code for sample application created for explaining the use of OPA for microservices authorisation.

Notifications You must be signed in to change notification settings

eolivares-e/opa-ms-example

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

opa-ms-sample

This repository contains the code for sample application created for explaining the use of OPA for microservices authorization.

Deploying on Minikube

The example can be deployed on minikube by using the pre-compiled images on docker hub and the deployment\cpq.yaml file. You should have minikube and kubectl installed on your machine before running this example.

  1. Start the minikube cluster using minikube start

  2. Clone the repo at a convenient path <REPO_PATH>

  3. Swith the directory to the cloned repo cd <REPO_PATH>/opa-ms-example

  4. Deploy the application using kubectl apply -f deployment/cpq.yaml

  5. Check if all the pods are up and running kubectl get pods

NAME                             READY   STATUS    RESTARTS   AGE
authorization-785794bff5-vxqgj   2/2     Running   0          56m
customer-5fb899fb9d-986m7        1/1     Running   0          56m
offer-654cb448b8-sk8q4           1/1     Running   0          56m
ui-6f87bb9f4-94zpt               1/1     Running   0          56m
  1. Get the URL for accessing application using minikube service ui --url. The sample output can be like http://192.168.64.3:32306

  2. Open a browser and past the URL above to navigate to the application.

  3. Select a role from the dropdown on the page to start experimenting. If you don't select a role, the required Authorization header will not be set causing intended failures.

  4. At first, you will not see any offers listed, and if you try Create Offer, the operation will fail. This is because the authorization is not set yet.

  5. To add the authorization, first set the SERVICE_URL using export SERVICE_URL=`minikube service ui --url` And then, update the policy using

curl -X PUT --data-binary @policies/httpapi.authz.rego \
$SERVICE_URL/authorization/v1/policies/httpapi/authz

Deploying on Docker Desktop

The example can be deployed on Docker Desktop. Enable Kubernetes in Docker Desktop if it is not already enabled.

You should have kubectl installed on your machine before running this example.

  1. Enable Kubernetes with Docker Desktop

  2. Clone the repo at a convenient path <REPO_PATH>

  3. Swith the directory to the cloned repo cd <REPO_PATH>/opa-ms-example

  4. Deploy the application using kubectl apply -f deployment/cpq.yaml

  5. Check if all the pods are up and running kubectl get pods

NAME                            READY   STATUS    RESTARTS   AGE
authorization-c4bb6bc78-229wf   2/2     Running   0          20m
customer-6fdf6b6b9b-59slk       1/1     Running   0          20m
offer-5497b58646-chfff          1/1     Running   0          20m
ui-856d588998-bwjhj             1/1     Running   0          20m
  1. Get the NodePort for accessing the application using kubectl get service ui. The NodePort should be greater than 30000. In the example below, the port is 31974 so you would connect to http://localhost:31974
NAME   TYPE       CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
ui     NodePort   10.109.176.176   <none>        80:31974/TCP   38m
  1. Open a browser and past the URL above to navigate to the application.

  2. Select a role from the dropdown on the page to start experimenting. If you don't select a role, the required Authorization header will not be set causing intended failures.

  3. At first, you will not see any offers listed, and if you try Create Offer, the operation will fail. This is because the authorization is not set yet.

  4. To add the authorization, first set the SERVICE_URL using export SERVICE_URL=http://localhost:31974 And then, update the policy using

curl -X PUT --data-binary @policies/httpapi.authz.rego \
$SERVICE_URL/authorization/v1/policies/httpapi/authz

About

This repository contains the code for sample application created for explaining the use of OPA for microservices authorisation.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 66.3%
  • Go 18.2%
  • HTML 8.3%
  • Dockerfile 3.7%
  • CSS 1.8%
  • Open Policy Agent 1.7%