Skip to content

Commit

Permalink
opa bundle api post
Browse files Browse the repository at this point in the history
Signed-off-by: Batuhan Apaydın <[email protected]>
  • Loading branch information
developer-guy committed Nov 24, 2020
1 parent b876d74 commit af66fc1
Show file tree
Hide file tree
Showing 6 changed files with 243 additions and 0 deletions.
243 changes: 243 additions & 0 deletions _posts/2020-11-08-distribute-policies-with-the-power-of-openfaas.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,243 @@
---
title: "Share and distribute Open Policy Agent Bundles with functions"
description: "In this post you'll learn how to share and distribute Open Policy Agent Bundles with functions"
date: 2020-11-24
image: /images/2020-11-08-distribute-policies-with-the-power-of-openfaas/opa-bundle-api.png
categories:
- arkade
- kubectl
- faas-cli
- opa
- bundle api
author_staff_member: developer-guy
dark_background: true
---

In this post you'll learn how to share and distribute Open Policy Agent Bundles with functions

<p align="center">
<img height="128" src="/images/2020-11-08-distribute-policies-with-the-power-of-openfaas/opa-power-openfaas.png">
</p>

# Share and distribute Open Policy Agent Bundles with functions

Let's clarify what is the motivation behind this post first.

One of the feature OpenFaaS is [auto-scaling](https://docs.openfaas.com/architecture/autoscaling/) mechanism. The auto-scaling means is that you can scale up/down your function instances as demand increases. Also OpenFaaS provides
a feature called [zero-scale](https://docs.openfaas.com/architecture/autoscaling/#zero-scale). By enabling this feature , you can scaling to zero to recover idle resources is available in OpenFaaS.

Using OpenFaaS as an OPA's Bundle API , you can have all the features by default with less effort.Also, you can't have to manage build/push and deploy phases with your Bundle API's .

### What you will learn in this post ?

In this post we are gonna learn:

* [What is OPA (Open Policy Agent) ?](#whatisopa)
* [How can we deploy OPA co-located with our service ?](#colocate-opa-service)
* [How can OpenFaaS help us about the OPA ?](#openfaasopa)
* [Demo](#demo)

### <a id="whatisopa"></a> What is OPA (Open Policy Agent) ?

OPA describes itself as a general purpose policy engine, for more detail you can look at the official [documentation](https://www.openpolicyagent.org/docs/latest/).

OPA's main goal is decoupling the policy decision-making from the policy enforcement. When your software needs to make policy decisions it queries OPA and supplies structured data (e.g., JSON) as input. OPA accepts arbitrary structured data as input.

![opa-decision-making](/images/2020-11-08-distribute-policies-with-the-power-of-openfaas/opa-policy-decision-make.png)
> Credit: https://www.magalix.com/blog/introducing-policy-as-code-the-open-policy-agent-opa
### <a id="colocate-opa-service"></a> How can we deploy OPA co-located with our service ?

When it comes to deploying OPA, you have more than one option depending on your specific scenario:

* As a Go library
* As a daemon

The recommended way is to run OPA is as a daemon. The reason is that this design increases performance and availability.By default, all of the policy and data that OPA uses to make decisions is kept in-memory for the low-latency and we should colocate OPA and the service to avoid the network latency also.

![opa-deploy-design](/images/2020-11-08-distribute-policies-with-the-power-of-openfaas/opa-deploy-design.png)
> Credit: https://www.magalix.com/blog/introducing-policy-as-code-the-open-policy-agent-opa
## <a id="openfaasopa"></a> How can OpenFaaS help us about the OPA ?

OPA exposes a set of APIs that enable unified, logically centralized policy management which is called ["Management API's"](https://www.openpolicyagent.org/docs/latest/management/). Think of them as a `Control Plane` for the OPA instances working as a `Data Plane`. With the Management API's you can control the OPA instances like enable decision logging, configure the Bundle API etc.

Let's focus on Bundle API which is one of the Management API's for OPA.

Bundle API's purpose is to help OPA to load policies across the stack to the OPA instances.OPA can periodically download bundles of policy and data from remote HTTP servers. The policies and data are loaded on the fly without requiring a restart of OPA.

In this demo, we create a serverless function that mimics an OPA's Bundle API.Simply, this serverless function designed as a plain file server. When OPA's asks for the policies it basically returns bundles that ready on the filesystem as a response.

### <a id="demo"></a> Demo

You can find all the details about this demo in Github [repo](https://github.com/developer-guy/distribute-policies-with-the-power-of-openfaas).

Prerequisites
* A Kubernetes cluster (kind, minikube, etc.)
* OpenFaaS CLI
* Arkade
* Kubectl
* KinD
* Docker

# Setup

## 1. Setup Tools

* Arkade
```sh
$ curl -sLS https://dl.get-arkade.dev | sudo sh
```

* KinD
```sh
$ arkade get kind
```

* Kubectl
```sh
$ arkade get kubectl
```

* OpenFaaS CLI
```sh
$ arkade get faas-cli
```

### 2. Set Up Cluster

You can start a Kubernetes cluster with KinD if you don't have one already

```bash
$ arkade get kind
$ kind create cluster
```

### 3. Deploy OpenFaaS

* Install OpenFaaS using Arkade

```sh
$ arkade install openfaas
```

* Verify Deployment

```sh
$ kubectl rollout status -n openfaas deploy/gateway
```

* Enable local access to Gateway
```sh
$ kubectl port-forward -n openfaas svc/gateway 8080:8080 &
```

### 4. Configure faas-cli

* Access password that available in the basic-auth secret in openfaas namespace

```sh
$ PASSWORD=$(kubectl get secret -n openfaas basic-auth -o jsonpath="{.data.basic-auth-password}" | base64 --decode; echo)
```

* Login with using the password to Gateway

```sh
$ echo -n $PASSWORD | faas-cli login --username admin --password-stdin
```

### 5. Deploy Function

* Go the functions directory , pull the right template and deploy the function

```sh
$ cd functions
$ faas-cli template store pull golang-middleware
$ faas-cli up -f bundle-api.yml
```

### 6. Load Images

* Load images from Docker Hub to KinD

```sh
$ docker image pull openpolicyagent/opa:latest
$ kind load docker-image openpolicyagent/opa:latest
$ docker image pull openpolicyagent/demo-restful-api:0.2
$ kind load docker-image openpolicyagent/demo-restful-api:0.2
```

### 7. Deploy application

* Deploy application with located OPA, detail: [deployment.yaml](https://github.com/developer-guy/distribute-policies-with-the-power-of-openfaas/blob/master/hack/manifests/deployment.yaml)

```sh
$ cd ../hack/manifests <br>
$ kubectl apply -f deployment.yaml
```

* Verify Deployment

```sh
$ kubectl rollout status deployment demo-restful-api
```

* Enable local access to application

```sh
$ kubectl port-forward svc/demo-restful-api 5000:80 &
```

# Test

[Rego](https://www.openpolicyagent.org/docs/latest/#rego) is the DSL for the OPA. We can author our policies using the rego.

For this tutorial, our desired policy is:

* People can see their own salaries (GET /finance/salary/{user} is permitted for {user})
* A manager can see their direct reports’ salaries (GET /finance/salary/{user} is permitted for {user}’s manager)

![authz.rego](/images/2020-11-08-distribute-policies-with-the-power-of-openfaas/authz-policy.png)

### Check that alice can see her own salary

* This command will succeed, because alice wants to see your own salary.

```sh
$ curl --user alice:password localhost:5000/finance/salary/alice
```

### Check that bob CANNOT see charlie’s salary.

* bob is not charlie’s manager, so the following command will fail.

```sh
$ curl --user bob:password localhost:5000/finance/salary/charlie
```

* bob is the alice's manager, so the following command will succeed.

```sh
$ curl --user bob:password localhost:5000/finance/salary/alice
```

### Join the community

Have you got questions, comments, or suggestions? Join the community on [Slack](https://slack.openfaas.io).

Would you like help to set up your OpenFaaS installation, or someone to call when things don't quite go to plan? [Our Premium Subscription plan](https://www.openfaas.com/support/) gives you a say in the project roadmap, a support contact, and access to Enterprise-grade authentication with OIDC.

### Acknowledgements

* Special Thanks to [Alex Ellis](https://twitter.com/alexellisuk) for all guidance and for merging changes into OpenFaaS to better support this workflow.
* Special Thanks to [Furkan Türkal](https://twitter.com/furkanturkaI) for all the support.

### References

* https://www.magalix.com/blog/introducing-policy-as-code-the-open-policy-agent-opa

* https://docs.openfaas.com

* https://www.openpolicyagent.org/docs/latest/http-api-authorization/

* https://github.com/developer-guy/distribute-policies-with-the-power-of-openfaas
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit af66fc1

Please sign in to comment.