/
data_source_fargate_container_definitions.go
106 lines (95 loc) · 3.51 KB
/
data_source_fargate_container_definitions.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
package tf
import (
"context"
"encoding/json"
"github.com/hashicorp/terraform-plugin-framework/schema"
"github.com/hashicorp/terraform-plugin-framework/tfsdk"
"github.com/hashicorp/terraform-plugin-framework/types"
"github.com/hashicorp/terraform-plugin-go/tfprotov6"
"github.com/sysdiglabs/agent-kilt/runtimes/cloudformation/cfnpatcher"
)
type dataSourceFargateContainerDefinitions struct {
provider *provider
}
type DataSourceConfig struct {
ContainerDefinitions types.String `tfsdk:"container_definitions"`
KiltDefinition types.String `tfsdk:"kilt_definition"`
RecipeConfig map[string]string `tfsdk:"recipe_config"`
OutputContainerDefinitions types.String `tfsdk:"output_container_definitions"`
}
func (d dataSourceFargateContainerDefinitions) Read(ctx context.Context, request tfsdk.ReadDataSourceRequest, response *tfsdk.ReadDataSourceResponse) {
var config DataSourceConfig
err := request.Config.Get(ctx, &config)
if err != nil {
response.Diagnostics = append(response.Diagnostics, &tfprotov6.Diagnostic{
Severity: tfprotov6.DiagnosticSeverityError,
Summary: "Error reading configuration",
Detail: "An unexpected error was encountered while reading configuration: " + err.Error(),
})
return
}
jsonConf, err := json.Marshal(&config.RecipeConfig)
if err != nil {
response.Diagnostics = append(response.Diagnostics, &tfprotov6.Diagnostic{
Severity: tfprotov6.DiagnosticSeverityError,
Summary: "Failed to serialize recipe config",
Detail: "Failed to serialize recipe config: " + err.Error(),
})
return
}
kiltConfig := &cfnpatcher.Configuration{
Kilt: config.KiltDefinition.Value,
ImageAuthSecret: d.provider.ImageAuthSecret.Value,
OptIn: false,
UseRepositoryHints: true,
RecipeConfig: string(jsonConf),
}
config.OutputContainerDefinitions, err = patchFargateTaskDefinition(ctx, &config.ContainerDefinitions, kiltConfig)
if err != nil {
response.Diagnostics = append(response.Diagnostics, &tfprotov6.Diagnostic{
Severity: tfprotov6.DiagnosticSeverityError,
Summary: "Error applying kilt patch",
Detail: "Error applying kilt patch: " + err.Error(),
})
return
}
err = response.State.Set(ctx, &config)
if err != nil {
response.Diagnostics = append(response.Diagnostics, &tfprotov6.Diagnostic{
Severity: tfprotov6.DiagnosticSeverityError,
Summary: "Error setting response",
Detail: "An unexpected error was encountered while setting the data source response: " + err.Error(),
})
return
}
}
func (d dataSourceFargateContainerDefinitions) GetSchema(_ context.Context) (schema.Schema, []*tfprotov6.Diagnostic) {
return schema.Schema{
Attributes: map[string]schema.Attribute{
"container_definitions": {
Type: types.StringType,
Description: "the input Fargate container definitions to process with kilt",
Required: true,
},
"kilt_definition": {
Type: types.StringType,
Description: "the kilt definition to apply to the input",
Required: true,
},
"recipe_config": {
Type: types.MapType{
ElemType: types.StringType,
},
Description: "kilt recipe configuration",
Required: false,
},
"output_container_definitions": {
Type: types.StringType,
Computed: true,
},
},
}, nil
}
func (d dataSourceFargateContainerDefinitions) NewDataSource(_ context.Context, p tfsdk.Provider) (tfsdk.DataSource, []*tfprotov6.Diagnostic) {
return dataSourceFargateContainerDefinitions{provider: p.(*provider)}, nil
}