Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cloudworkz/kubernetes-rbac-synchroniser
Google Group User --> Kubernetes RBAC
https://github.com/cloudworkz/kubernetes-rbac-synchroniser
docker google-cloud kubernetes rbac synchronization
Last synced: 3 months ago
JSON representation
Google Group User --> Kubernetes RBAC
- Host: GitHub
- URL: https://github.com/cloudworkz/kubernetes-rbac-synchroniser
- Owner: cloudworkz
- License: apache-2.0
- Created: 2017-11-19T11:43:24.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-01-20T19:50:19.000Z (about 6 years ago)
- Last Synced: 2024-11-09T19:41:37.702Z (3 months ago)
- Topics: docker, google-cloud, kubernetes, rbac, synchronization
- Language: Go
- Homepage:
- Size: 169 KB
- Stars: 45
- Watchers: 4
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - cloudworkz/kubernetes-rbac-synchroniser - Google Group User --> Kubernetes RBAC (Go)
README
## kubernetes-rbac-synchroniser
[data:image/s3,"s3://crabby-images/826e6/826e62bef694eb641953c6e6150e6fb1e4741474" alt="license"](https://github.com/google-cloud-tools/kubernetes-rbac-synchroniser)
[data:image/s3,"s3://crabby-images/aaea4/aaea45a38c8565517fb5c9a1e17798fdc5debd26" alt="Docker Repository on Quay"](https://quay.io/repository/google-cloud-tools/kubernetes-rbac-synchroniser)
[data:image/s3,"s3://crabby-images/ce56d/ce56d1f807535c0ea5e484002a7ae15dc3ec22f1" alt="Docker Pulls"](https://hub.docker.com/r/google-cloud-tools/kubernetes-rbac-synchroniser)
[data:image/s3,"s3://crabby-images/80302/8030203972cd64c7da29aff5f9e138cae3fa9965" alt="Go Report Card"](https://goreportcard.com/report/github.com/google-cloud-tools/kubernetes-rbac-synchroniser)### What It Does
RBAC Synchroniser pulls a Google Group, extracts Google Group Member Emails and updates the Kubernetes RoleBinding in the given namespace.
[data:image/s3,"s3://crabby-images/2e620/2e6209ffcc4c5b1121c6e1e1bd7584252934da7f" alt="graph"](https://raw.githubusercontent.com/google-cloud-tools/kubernetes-rbac-synchroniser/master/graph.png)
### Requirements
- The service account's private key file: **-config-file-path** flag
- The email of the user with permissions to access the Admin APIs: **-google-admin-email** flag> see guide: https://developers.google.com/admin-sdk/directory/v1/guides/delegation
- The Google Group list per Kubernetes namespace: **-namespace-group** flag
- Configure Minimal GKE IAM permissions for each Google Group: `gcloud beta iam roles create minimal_gke_role --project my_project --title "Container Engine Minimal" --description "Minimal GKE Role which allows 'gcloud container clusters get-credentials' command" --permissions "container.apiServices.get,container.apiServices.list,container.clusters.get,container.clusters.getCredentials"`> see: https://stackoverflow.com/questions/45945074/iam-and-rbac-conflicts-on-google-cloud-container-engine-gke/45945239#45945239
### Flags
| Flag | Description | Defalut |
| :------------------- | :------------------------------------------------------- |:----------- |
| -cluster-role-name | The cluster role name with permissions. | "view" |
| -config-file-path | The Path to the Service Account's Private Key file. | |
| -google-admin-email | The Google Admin Email. | |
| -fake-group-response | Fake Google Admin API Response. | |
| -namespace-group | The group and namespace. May be used multiple times. | |
| -in-cluster-config | Use in cluster kubeconfig. | true |
| -kubeconfig | Absolute path to the kubeconfig file. | |
| -listen-address | The address to listen on for HTTP requests. | ":8080" |
| -rolebinding-name | The role binding name per namespace. | "developer" |
| -update-interval | Update interval in seconds. | 15m0s |
| -log-json | Log as JSON instead of the default ASCII formatter. | false |### Prometheus metrics
- **rbac_synchroniser_success**: Cumulative number of role update operations.
- **rbac_synchroniser_errors**: Cumulative number of errors during role update operations.### Examples
[https://github.com/google-cloud-tools/kubernetes-rbac-synchroniser/tree/master/examples](https://github.com/google-cloud-tools/kubernetes-rbac-synchroniser/tree/master/examples)
### Links
- https://developers.google.com/admin-sdk/directory/v1/guides/delegation
- https://developers.google.com/admin-sdk/directory/v1/guides/manage-group-members
- https://github.com/kubernetes/client-go
- https://github.com/prometheus/client_golang