This repository has been archived by the owner on Jul 14, 2023. It is now read-only.
/
data_source_iosxe_bgp_l2vpn_evpn_neighbor.go
116 lines (96 loc) · 3.7 KB
/
data_source_iosxe_bgp_l2vpn_evpn_neighbor.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
// Code generated by "gen/generator.go"; DO NOT EDIT.
package provider
import (
"context"
"fmt"
"github.com/hashicorp/terraform-plugin-framework/datasource"
"github.com/hashicorp/terraform-plugin-framework/datasource/schema"
"github.com/hashicorp/terraform-plugin-framework/path"
"github.com/hashicorp/terraform-plugin-framework/types"
"github.com/hashicorp/terraform-plugin-log/tflog"
"github.com/netascode/go-restconf"
)
// Ensure the implementation satisfies the expected interfaces.
var (
_ datasource.DataSource = &BGPL2VPNEVPNNeighborDataSource{}
_ datasource.DataSourceWithConfigure = &BGPL2VPNEVPNNeighborDataSource{}
)
func NewBGPL2VPNEVPNNeighborDataSource() datasource.DataSource {
return &BGPL2VPNEVPNNeighborDataSource{}
}
type BGPL2VPNEVPNNeighborDataSource struct {
clients map[string]*restconf.Client
}
func (d *BGPL2VPNEVPNNeighborDataSource) Metadata(_ context.Context, req datasource.MetadataRequest, resp *datasource.MetadataResponse) {
resp.TypeName = req.ProviderTypeName + "_bgp_l2vpn_evpn_neighbor"
}
func (d *BGPL2VPNEVPNNeighborDataSource) Schema(ctx context.Context, req datasource.SchemaRequest, resp *datasource.SchemaResponse) {
resp.Schema = schema.Schema{
// This description is used by the documentation generator and the language server.
MarkdownDescription: "This data source can read the BGP L2VPN EVPN Neighbor configuration.",
Attributes: map[string]schema.Attribute{
"device": schema.StringAttribute{
MarkdownDescription: "A device name from the provider configuration.",
Optional: true,
},
"id": schema.StringAttribute{
MarkdownDescription: "The path of the retrieved object.",
Computed: true,
},
"asn": schema.StringAttribute{
MarkdownDescription: "",
Required: true,
},
"ip": schema.StringAttribute{
MarkdownDescription: "",
Required: true,
},
"activate": schema.BoolAttribute{
MarkdownDescription: "Enable the address family for this neighbor",
Computed: true,
},
"send_community": schema.StringAttribute{
MarkdownDescription: "",
Computed: true,
},
"route_reflector_client": schema.BoolAttribute{
MarkdownDescription: "Configure a neighbor as Route Reflector client",
Computed: true,
},
},
}
}
func (d *BGPL2VPNEVPNNeighborDataSource) Configure(_ context.Context, req datasource.ConfigureRequest, _ *datasource.ConfigureResponse) {
if req.ProviderData == nil {
return
}
d.clients = req.ProviderData.(map[string]*restconf.Client)
}
func (d *BGPL2VPNEVPNNeighborDataSource) Read(ctx context.Context, req datasource.ReadRequest, resp *datasource.ReadResponse) {
var config BGPL2VPNEVPNNeighborData
// Read config
diags := req.Config.Get(ctx, &config)
resp.Diagnostics.Append(diags...)
if resp.Diagnostics.HasError() {
return
}
if _, ok := d.clients[config.Device.ValueString()]; !ok {
resp.Diagnostics.AddAttributeError(path.Root("device"), "Invalid device", fmt.Sprintf("Device '%s' does not exist in provider configuration.", config.Device.ValueString()))
return
}
tflog.Debug(ctx, fmt.Sprintf("%s: Beginning Read", config.getPath()))
res, err := d.clients[config.Device.ValueString()].GetData(config.getPath())
if res.StatusCode == 404 {
config = BGPL2VPNEVPNNeighborData{Device: config.Device}
} else {
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to retrieve object, got error: %s", err))
return
}
config.fromBody(ctx, res.Res)
}
config.Id = types.StringValue(config.getPath())
tflog.Debug(ctx, fmt.Sprintf("%s: Read finished successfully", config.getPath()))
diags = resp.State.Set(ctx, &config)
resp.Diagnostics.Append(diags...)
}