This Permissions service ("perm") provides authorization features for the Cloud Foundry Platform. It answers various question forms of what particular identities are allowed to do. It works out the answers to these questions based on the roles assigned to users and the roles assigned to the groups they are a member of.
Even though the service was originally created to add authorization features to Cloud Controller, other components in the system are looking to migrate to storing their authorization rules in Perm.
To fetch all source code, including the Go client library:
go get -u code.cloudfoundry.org/perm
To fetch and install the server's CLI:
go get -u code.cloudfoundry.org/perm/cmd/perm
To fetch and install the monitor's CLI:
go get -u code.cloudfoundry.org/perm/cmd/perm-monitor
Assuming you have the Perm source code in your $GOPATH:
go install code.cloudfoundry.org/perm/vendor/github.com/onsi/ginkgo/ginkgo
ginkgo -r -race -p -randomizeAllSpecs -randomizeSuites
First, make sure that you have the CLI installed:
go get -u code.cloudfoundry.org/perm
go install code.cloudfoundry.org/perm/cmd/perm
To use an in-memory data store, e.g., for testing purposes:
perm serve --tls-cert <path> --tls-key <path> --db-driver in-memory
To use mysql:
perm migrate up --db-driver mysql --db-host <host> --db-port <port> --db-username <username> --db-password <password>
perm serve --tls-cert <path> --tls-key <path> --db-driver mysql --db-host <host> --db-port <port> --db-username <username> --db-password <password>
The monitor is a small app that repeats the same basic workflow every interval, generating traffic and tracking some client-side metrics.
Make sure that you have the monitor's CLI:
go get -u code.cloudfoundry.org/perm
go install code.cloudfoundry.org/perm/cmd/perm-monitor
Make sure that you have a statsd daemon, e.g., with docker:
docker run -d -p 8125:8125 --name statsd hopsoft/graphite-statsd
Then, start the monitor:
perm-monitor --perm-tls-ca <path>
This repository is complemented by 2 other repositories.
-
This is the BOSH release for deploying the
perm
service. -
This is the Ruby library for interacting with
perm
. It is used by Cloud Controller to perform administration and checking of permissions.
For more information, check out our page on Repository Structure.
Not yet, please.