Sty -OPA - Rego : What is OPA

 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

 

 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

 OPA is a general purpose policy engine .

All these software that we see on the right at some point of time understands that it needs a policy decision. 


So what it is does it cobles on whatever policy decision that it needs about as a policy query and hands that query over to OPA . And OPA makes the decision and returns into the service , it is the services responsibility to enforce that decision . It is OPA responsibility to make that decision. For example if that service was a kubernetes API server . Kubernetes will decide that some user is trying to create a new resource on it , POD or ingress lets say on the kubernetes cluster . Kubernetes would take that 100 or 500 line of code of JSON or YAMLthat describes the new resource the user trying to deploy on to the cluster and it will hand that entire JSON or YAML code to OPA - OPA will make a decision and return it to the Kubernetes API server and then the Kubernetes will go ahead and enforce that decision

The key thing here is that the Policy query can be any JSON value

OPA does not understand anything about Kubernetes or micro-services . It was designed to general purpose , meaning that OPA just sees JSON coming across and it then evaluates a policy to make a decision and return whatever decision the policy dictates . Now that's why OPA can be so easily used against all these cloud native software. OPA is not build into with a bunch of information of any one of them therefore, it can work with all of them. 

I when as a author write that Policy know what that JSON object represents that is coming in as input . so i can write the appropriate policy . I know what is a Kubernetes pod is or an ingress is so I can write that code. 

The policy language which we call Rego needs to be pretty flexible as well while we write our OPA code. for example if you want all containers in a Kubernetes must come from a trusted registry  

For micro-services most people use Network Proxy . All network traffic to microservice . There is a dedicated sub project within OPA called "Gatekeeper" for Kubernetes

OPA is also used for authorization

OPA for CI / CD pipeline called OPA Conftest

Who is On Call -- This information shall in injected in the Pager duty , OPA help you to extract this information from the pager duty and inject it into OPA. 

The policy decisions that can be returned is not limited to Allow or Deny or True or False , or 1's and 0's.

In fact any Policy decisions that can be returned can be any arbitrary json value for example if you want to write a policy for the computer to rate limit. You would want to return a number . If you want to write a policy to which cluster do you want to deploy an application to then you may be return an array of strings . 

  • One thing that we often do with OPA is return of structure of JSON object that has multiple field within it for example you might return a JSON object that has a bit that says whether or not this request is allowed . 
  • Another field what errors message are to be returned to the user. 
  • And may be another field that contains the HTTP code that gets returned. 


Lets see how this integration work. lets see the Microservices example which is lately called the Network Proxy Integration.











Comments