This repository has been archived by the owner on Jan 14, 2020. It is now read-only.
/
IAM-Role.go
104 lines (89 loc) · 2.7 KB
/
IAM-Role.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
package resources
// Code generated by go generate; DO NOT EDIT.
// It's generated by "github.com/KablamoOSS/kombustion/generate"
import (
"fmt"
"github.com/KablamoOSS/kombustion/types"
yaml "github.com/KablamoOSS/yaml"
)
// IAMRole Documentation: http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html
type IAMRole struct {
Type string `yaml:"Type"`
Properties IAMRoleProperties `yaml:"Properties"`
Condition interface{} `yaml:"Condition,omitempty"`
Metadata interface{} `yaml:"Metadata,omitempty"`
DependsOn interface{} `yaml:"DependsOn,omitempty"`
}
// IAMRole Properties
type IAMRoleProperties struct {
AssumeRolePolicyDocument interface{} `yaml:"AssumeRolePolicyDocument"`
MaxSessionDuration interface{} `yaml:"MaxSessionDuration,omitempty"`
Path interface{} `yaml:"Path,omitempty"`
RoleName interface{} `yaml:"RoleName,omitempty"`
ManagedPolicyArns interface{} `yaml:"ManagedPolicyArns,omitempty"`
Policies interface{} `yaml:"Policies,omitempty"`
}
// NewIAMRole constructor creates a new IAMRole
func NewIAMRole(properties IAMRoleProperties, deps ...interface{}) IAMRole {
return IAMRole{
Type: "AWS::IAM::Role",
Properties: properties,
DependsOn: deps,
}
}
// ParseIAMRole parses IAMRole
func ParseIAMRole(
name string,
data string,
) (
source string,
conditions types.TemplateObject,
metadata types.TemplateObject,
mappings types.TemplateObject,
outputs types.TemplateObject,
parameters types.TemplateObject,
resources types.TemplateObject,
transform types.TemplateObject,
errors []error,
) {
source = "kombustion-core-resources"
// Resources
var resource IAMRole
err := yaml.Unmarshal([]byte(data), &resource)
if err != nil {
errors = append(errors, err)
return
}
if validateErrs := resource.Properties.Validate(); len(errors) > 0 {
errors = append(errors, validateErrs...)
return
}
resources = types.TemplateObject{name: resource}
// Outputs
outputs = types.TemplateObject{
name: types.TemplateObject{
"Description": name + " Object",
"Value": map[string]interface{}{
"Ref": name,
},
"Export": map[string]interface{}{
"Name": map[string]interface{}{
"Fn::Sub": "${AWS::StackName}-IAMRole-" + name,
},
},
},
}
return
}
// ParseIAMRole validator
func (resource IAMRole) Validate() []error {
return resource.Properties.Validate()
}
// ParseIAMRoleProperties validator
func (resource IAMRoleProperties) Validate() []error {
errors := []error{}
if resource.AssumeRolePolicyDocument == nil {
errors = append(errors, fmt.Errorf("Missing required field 'AssumeRolePolicyDocument'"))
}
return errors
}