-
Notifications
You must be signed in to change notification settings - Fork 90
/
structure_repository.go
72 lines (66 loc) · 2.12 KB
/
structure_repository.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
package argocd
import (
application "github.com/argoproj/argo-cd/pkg/apis/application/v1alpha1"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
)
// Expand
func expandRepository(d *schema.ResourceData) *application.Repository {
repository := &application.Repository{}
if v, ok := d.GetOk("repo"); ok {
repository.Repo = v.(string)
}
if v, ok := d.GetOk("enable_lfs"); ok {
repository.EnableLFS = v.(bool)
}
if v, ok := d.GetOk("inherited_creds"); ok {
repository.InheritedCreds = v.(bool)
}
if v, ok := d.GetOk("insecure"); ok {
repository.Insecure = v.(bool)
}
if v, ok := d.GetOk("name"); ok {
repository.Name = v.(string)
}
if v, ok := d.GetOk("username"); ok {
repository.Username = v.(string)
}
if v, ok := d.GetOk("password"); ok {
repository.Password = v.(string)
}
repository.SSHPrivateKey = d.Get("ssh_private_key").(string)
if v, ok := d.GetOk("tls_client_cert_data"); ok {
repository.TLSClientCertData = v.(string)
}
if v, ok := d.GetOk("tls_client_cert_key"); ok {
repository.TLSClientCertKey = v.(string)
}
if v, ok := d.GetOk("type"); ok {
repository.Type = v.(string)
}
return repository
}
// Flatten
func flattenRepository(repository *application.Repository, d *schema.ResourceData) error {
r := map[string]interface{}{
"repo": repository.Repo,
"connection_state_status": repository.ConnectionState.Status,
"enable_lfs": repository.EnableLFS,
"inherited_creds": repository.InheritedCreds,
"insecure": repository.Insecure,
"name": repository.Name,
// TODO: in case of repositoryCredentials existence, will perma-diff
//"username": repository.Username,
// TODO: ArgoCD API does not return sensitive data!
//"password": repository.Password,
//"ssh_private_key": repository.SSHPrivateKey,
//"tls_client_cert_key": repository.TLSClientCertKey,
"tls_client_cert_data": repository.TLSClientCertData,
"type": repository.Type,
}
for k, v := range r {
if err := persistToState(k, v, d); err != nil {
return err
}
}
return nil
}