-
Notifications
You must be signed in to change notification settings - Fork 20
/
dbaas_create_kafka.go
125 lines (108 loc) · 3.57 KB
/
dbaas_create_kafka.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package cmd
import (
"fmt"
"net/http"
"github.com/spf13/cobra"
"github.com/exoscale/cli/pkg/account"
"github.com/exoscale/cli/pkg/globalstate"
"github.com/exoscale/cli/utils"
exoapi "github.com/exoscale/egoscale/v2/api"
"github.com/exoscale/egoscale/v2/oapi"
)
func (c *dbaasServiceCreateCmd) createKafka(_ *cobra.Command, _ []string) error {
var err error
ctx := exoapi.WithEndpoint(gContext, exoapi.NewReqEndpoint(account.CurrentAccount.Environment, c.Zone))
databaseService := oapi.CreateDbaasServiceKafkaJSONRequestBody{
KafkaConnectEnabled: &c.KafkaEnableKafkaConnect,
KafkaRestEnabled: &c.KafkaEnableKafkaREST,
Plan: c.Plan,
SchemaRegistryEnabled: &c.KafkaEnableSchemaRegistry,
TerminationProtection: &c.TerminationProtection,
Version: utils.NonEmptyStringPtr(c.KafkaVersion),
}
settingsSchema, err := globalstate.EgoscaleClient.GetDbaasSettingsKafkaWithResponse(ctx)
if err != nil {
return fmt.Errorf("unable to retrieve Database Service settings: %w", err)
}
if settingsSchema.StatusCode() != http.StatusOK {
return fmt.Errorf("API request error: unexpected status %s", settingsSchema.Status())
}
if c.KafkaEnableCertAuth || c.KafkaEnableSASLAuth {
databaseService.AuthenticationMethods = &struct {
Certificate *bool `json:"certificate,omitempty"`
Sasl *bool `json:"sasl,omitempty"`
}{
Certificate: &c.KafkaEnableCertAuth,
Sasl: &c.KafkaEnableSASLAuth,
}
}
if len(c.KafkaIPFilter) > 0 {
databaseService.IpFilter = &c.KafkaIPFilter
}
if c.MaintenanceDOW != "" && c.MaintenanceTime != "" {
databaseService.Maintenance = &struct {
Dow oapi.CreateDbaasServiceKafkaJSONBodyMaintenanceDow `json:"dow"`
Time string `json:"time"`
}{
Dow: oapi.CreateDbaasServiceKafkaJSONBodyMaintenanceDow(c.MaintenanceDOW),
Time: c.MaintenanceTime,
}
}
if c.KafkaConnectSettings != "" {
settings, err := validateDatabaseServiceSettings(
c.KafkaConnectSettings,
settingsSchema.JSON200.Settings.KafkaConnect,
)
if err != nil {
return fmt.Errorf("invalid settings: %w", err)
}
databaseService.KafkaConnectSettings = &settings
}
if c.KafkaRESTSettings != "" {
settings, err := validateDatabaseServiceSettings(
c.KafkaRESTSettings,
settingsSchema.JSON200.Settings.KafkaRest,
)
if err != nil {
return fmt.Errorf("invalid settings: %w", err)
}
databaseService.KafkaRestSettings = &settings
}
if c.KafkaSettings != "" {
settings, err := validateDatabaseServiceSettings(
c.KafkaSettings,
settingsSchema.JSON200.Settings.Kafka,
)
if err != nil {
return fmt.Errorf("invalid settings: %w", err)
}
databaseService.KafkaSettings = &settings
}
if c.KafkaSchemaRegistrySettings != "" {
settings, err := validateDatabaseServiceSettings(
c.KafkaSchemaRegistrySettings,
settingsSchema.JSON200.Settings.SchemaRegistry,
)
if err != nil {
return fmt.Errorf("invalid settings: %w", err)
}
databaseService.SchemaRegistrySettings = &settings
}
var res *oapi.CreateDbaasServiceKafkaResponse
decorateAsyncOperation(fmt.Sprintf("Creating Database Service %q...", c.Name), func() {
res, err = globalstate.EgoscaleClient.CreateDbaasServiceKafkaWithResponse(ctx, oapi.DbaasServiceName(c.Name), databaseService)
})
if err != nil {
return err
}
if res.StatusCode() != http.StatusOK {
return fmt.Errorf("API request error: unexpected status %s", res.Status())
}
if !globalstate.Quiet {
return c.outputFunc((&dbaasServiceShowCmd{
Name: c.Name,
Zone: c.Zone,
}).showDatabaseServiceKafka(ctx))
}
return nil
}