This repository has been archived by the owner on Aug 27, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
broker.go
82 lines (73 loc) · 2.75 KB
/
broker.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package broker
import (
"code.cloudfoundry.org/lager"
"context"
"errors"
"github.com/18F/concourse-broker/cf"
"github.com/18F/concourse-broker/concourse"
"github.com/18F/concourse-broker/config"
"github.com/pivotal-cf/brokerapi"
)
// New returns a new concourse service broker instance.
func New(services []brokerapi.Service, logger lager.Logger, env config.Env) brokerapi.ServiceBroker {
return &concourseBroker{services: services, logger: logger, env: env}
}
type concourseBroker struct {
services []brokerapi.Service
logger lager.Logger
env config.Env
}
func (c *concourseBroker) Services(context context.Context) []brokerapi.Service {
return c.services
}
func (c *concourseBroker) Provision(context context.Context, instanceID string,
details brokerapi.ProvisionDetails, asyncAllowed bool) (brokerapi.ProvisionedServiceSpec, error) {
cfClient, err := cf.NewClient(c.env)
if err != nil {
return brokerapi.ProvisionedServiceSpec{}, err
}
cfDetails, err := cfClient.GetProvisionDetails(details.SpaceGUID)
cfDetails.SpaceGUID = details.SpaceGUID
if err != nil {
return brokerapi.ProvisionedServiceSpec{}, err
}
concourseClient := concourse.NewClient(c.env, c.logger)
err = concourseClient.CreateTeam(cfDetails)
if err != nil {
return brokerapi.ProvisionedServiceSpec{}, err
}
return brokerapi.ProvisionedServiceSpec{}, nil
}
func (c *concourseBroker) Deprovision(context context.Context, instanceID string,
details brokerapi.DeprovisionDetails, asyncAllowed bool) (brokerapi.DeprovisionServiceSpec, error) {
cfClient, err := cf.NewClient(c.env)
if err != nil {
return brokerapi.DeprovisionServiceSpec{}, err
}
cfDetails, err := cfClient.GetDeprovisionDetails(instanceID)
if err != nil {
return brokerapi.DeprovisionServiceSpec{}, err
}
concourseClient := concourse.NewClient(c.env, c.logger)
err = concourseClient.DeleteTeam(cfDetails)
if err != nil {
return brokerapi.DeprovisionServiceSpec{}, err
}
return brokerapi.DeprovisionServiceSpec{}, nil
}
func (c *concourseBroker) Bind(context context.Context, instanceID,
bindingID string, details brokerapi.BindDetails) (brokerapi.Binding, error) {
return brokerapi.Binding{}, errors.New("service does not support bind")
}
func (c *concourseBroker) Unbind(context context.Context, instanceID, bindingID string,
details brokerapi.UnbindDetails) error {
return errors.New("service does not support bind")
}
func (c *concourseBroker) Update(context context.Context, instanceID string,
details brokerapi.UpdateDetails, asyncAllowed bool) (brokerapi.UpdateServiceSpec, error) {
return brokerapi.UpdateServiceSpec{}, nil
}
func (c *concourseBroker) LastOperation(context context.Context, instanceID,
operationData string) (brokerapi.LastOperation, error) {
return brokerapi.LastOperation{}, nil
}