Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cloudfoundry/cloud-service-broker
OSBAPI service broker that uses Terraform to provision and bind services. Derived from https://github.com/GoogleCloudPlatform/gcp-service-broker
https://github.com/cloudfoundry/cloud-service-broker
aws azure cff-wg-service-management cloud-foundry gcp opentofu osbapi service-broker terraform
Last synced: 2 days ago
JSON representation
OSBAPI service broker that uses Terraform to provision and bind services. Derived from https://github.com/GoogleCloudPlatform/gcp-service-broker
- Host: GitHub
- URL: https://github.com/cloudfoundry/cloud-service-broker
- Owner: cloudfoundry
- License: apache-2.0
- Created: 2020-01-09T21:20:25.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-05-29T22:44:11.000Z (7 months ago)
- Last Synced: 2024-05-30T17:52:10.470Z (7 months ago)
- Topics: aws, azure, cff-wg-service-management, cloud-foundry, gcp, opentofu, osbapi, service-broker, terraform
- Language: Go
- Homepage:
- Size: 931 MB
- Stars: 78
- Watchers: 10
- Forks: 37
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE-OF-CONDUCT.md
- Codeowners: CODEOWNERS
- Authors: AUTHORS
Awesome Lists containing this project
README
[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](https://opensource.org/license/apache-2-0/)
[![test](https://github.com/cloudfoundry/cloud-service-broker/workflows/run-tests/badge.svg?branch=main)](https://github.com/cloudfoundry/cloud-service-broker/actions?query=workflow%3Arun-tests+branch%3Amain)
[![Go Report Card](https://goreportcard.com/badge/github.com/cloudfoundry/cloud-service-broker)](https://goreportcard.com/report/github.com/cloudfoundry/cloud-service-broker)**Warning**: From Version 1.0.0 onwards the Cloud Service Broker only supports OpenTofu. Custom brokerpaks need to specify an OpenTofu version and the [upgrade process](https://github.com/cloudfoundry/cloud-service-broker/blob/main/docs/terraform-upgrades.md) must be followed for existing instances. Only upgrades from terraform versions 1.5.x are supported. For more information, see the [OpenTofu migration guide](./docs/opentofu_migration_guide.md)
# Cloud Service Broker
An OSBAPI-compliant service broker that uses OpenTofu to create service instances.This is a service broker built to be used with [Cloud Foundry](https://docs.cloudfoundry.org/services/overview.html) and Kubernetes. It adheres to the [Open Service Broker API v2.13](https://github.com/openservicebrokerapi/servicebroker/blob/v2.13/spec.md).
Cloud Service Broker is a fork of the [GCP Service Broker](https://github.com/GoogleCloudPlatform/gcp-service-broker)
and uses [Brokerpaks](https://github.com/cloudfoundry/cloud-service-broker/blob/main/docs/brokerpak-intro.md) to
expose services. As long as your target cloud has a [OpenTofu provider](https://opentofu.org/docs/language/providers/),
services can be provisioned via a common interface using standard `cf` CLI commands.Some of the benefits over traditional, IaaS-provided, service brokers include:
- **Easily extensible and maintainable** Less talking to far-flung teams, more getting work done.
- **One common broker for all brokered services.** Cloud Service Broker decouples the service broker functionality from the catalog of services that it exposes.
- **Credhub integration out-of-the-box** CredHub encrypts and manages all the secrets associated with your usage of cloud services.
- **Community** When you expose a service via a [Brokerpak](https://github.com/cloudfoundry/cloud-service-broker/blob/main/docs/brokerpak-intro.md), you can make it available to everyone who uses CSB.
- **Possible to migrate existing services using [OpenTofu Import](https://opentofu.org/docs/language/import/)**## Architecture
![Architecture Diagram](https://lh6.googleusercontent.com/GoNJx-4dQ51pEY6mCLkus1peKhZJbDMj4JHpdu83stfQrbcsjd45ypBPzpspfWAPPYrc63BREaawwRHS4Ht4U7m2yWAHItwaIgfuwUtn_KxfF96s6Jby7BRIliZ6BZz1HL-KhaI)## Slack
Please reach out on the #cloudservicebroker channel in the [Cloud Foundry Slack](https://slack.cloudfoundry.org/)!## Installation
This service broker can be installed as a CF application. See the instructions for:
* [General configuration](./docs/configuration.md)
* [AWS](https://github.com/cloudfoundry/csb-brokerpak-aws/blob/main/docs/installation.md)
* [Azure](https://github.com/cloudfoundry/csb-brokerpak-azure/blob/main/docs/azure-installation.md)
* [Azure configuration examples](https://github.com/cloudfoundry/csb-brokerpak-azure/blob/main/docs/azure-example-configs.md)
* [GCP](https://github.com/cloudfoundry/csb-brokerpak-gcp/blob/main/docs/installation.md)## CSB-Provided Brokerpaks
To examine, submit issues or pull requests to the Brokerpaks which have been created for the major public clouds (AWS, Azure, GCP) see the repos below:
* [AWS Brokerpak](https://github.com/cloudfoundry/csb-brokerpak-aws)
* [Azure Brokerpak](https://github.com/cloudfoundry/csb-brokerpak-azure)
* [GCP Brokerpak](https://github.com/cloudfoundry/csb-brokerpak-gcp)## Usage
**For operators**: see [docs/configuration.md](./docs/configuration.md) for details about configuring the service broker.
**For developers**: see [docs/](./docs) ReadMe for service options and details.
You can get documentation specific to your install from the `/docs` endpoint of your deployment.
## Commands
The service broker can be run as both a server (the service broker) and as a general purpose command line utility.
It supports the following sub-commands:* `client` - A CLI client for the service broker.
* `config` - Show and merge configuration options together.
* `help` - Help about any command.
* `serve` - Start the service broker.## Development
`make` is used to orchestrate most development tasks.
`go` is required to build the broker.
If you don't have `go` installed, it is possible to use `docker` to launch an interactive shell into some supported image containing all necessary tools. For example:
```
# From the root of this repo run:
docker run -it --rm -v "${PWD}:/repo" --workdir "/repo" --entrypoint "/bin/bash" golang:latest
make
```There are make targets for most common dev tasks. Running make without a target will list the possible targets.
| command | action |
|-------------------|----------------------------------------|
| `make build` | builds broker into `./build` |
| `make test-units` | runs unit tests |
| `make clean` | removes binaries and built broker paks |## Local mimic commands
The mimic commands look and feel like CloudFoundry CLI commands, but actually run CSB actions locally. They are useful when developing brokerpaks.
By using the make target `make install` you can install the CSB as a local command called `csb`.
The mimic commands are:
- `csb create-service` - creates a service instance
- `csb services` - lists created service instances
- `csb service` - displays information on an existing service instance
- `csb update-service` - updates a service instance
- `csb upgrade-service` - upgrades a service instance
- `csb delete-service` - deletes a service instance
- `csb create-service-key` - creates a "binding" and prints credentials
- `csb service-keys` - lists service keys
- `csb service-key` - prints a service key
- `csb delete-service-key` - deletes a "binding"The mimic commands build a brokerpak, start an ephemeral CSB server and send OSBAPI
requests to it in a similar style to what CloudFoundry would do. The CSB database
is stored as a file called `.csb.db`.Additionally, there are commands which use the same framework to run the example tests. These are:
- `csb examples` - list the example tests
- `csb run-examples` - runs the specified example tests## Bug Reports, Feature Requests, Documentation Requests & Support
[File a GitHub issue](https://github.com/cloudfoundry/cloud-service-broker/issues) for bug reports and documentation or feature requests. Please use the provided templates.
## Contributing
We are always looking for folks to contribute Brokerpaks!See [Brokerpak Dissection](https://github.com/cloudfoundry/cloud-service-broker/blob/main/docs/brokerpak-dissection.md) and the [user guides](https://github.com/cloudfoundry/cloud-service-broker/blob/main/docs/user-guides) for more information on how to contribute to existing brokerpaks and how build one from scratch.