summaryrefslogtreecommitdiffhomepage
path: root/config/bgp_configs.go
diff options
context:
space:
mode:
Diffstat (limited to 'config/bgp_configs.go')
-rw-r--r--config/bgp_configs.go99
1 files changed, 99 insertions, 0 deletions
diff --git a/config/bgp_configs.go b/config/bgp_configs.go
index 42c3e750..6baa8bdd 100644
--- a/config/bgp_configs.go
+++ b/config/bgp_configs.go
@@ -43,6 +43,15 @@ func (v RemovePrivateAsOption) ToInt() int {
return -1
}
+func (v RemovePrivateAsOption) FromInt(i int) RemovePrivateAsOption {
+ for j, vv := range []string{"all", "replace"} {
+ if i == j {
+ return RemovePrivateAsOption(vv)
+ }
+ }
+ return RemovePrivateAsOption("")
+}
+
func (v RemovePrivateAsOption) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid RemovePrivateAsOption: %s", v)
@@ -72,6 +81,15 @@ func (v CommunityType) ToInt() int {
return -1
}
+func (v CommunityType) FromInt(i int) CommunityType {
+ for j, vv := range []string{"standard", "extended", "both", "none"} {
+ if i == j {
+ return CommunityType(vv)
+ }
+ }
+ return CommunityType("")
+}
+
func (v CommunityType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid CommunityType: %s", v)
@@ -102,6 +120,15 @@ func (v PeerTypeDef) ToInt() int {
return -1
}
+func (v PeerTypeDef) FromInt(i int) PeerTypeDef {
+ for j, vv := range []string{"internal", "external"} {
+ if i == j {
+ return PeerTypeDef(vv)
+ }
+ }
+ return PeerTypeDef("")
+}
+
func (v PeerTypeDef) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid PeerTypeDef: %s", v)
@@ -126,6 +153,15 @@ func (v BgpSessionDirection) ToInt() int {
return -1
}
+func (v BgpSessionDirection) FromInt(i int) BgpSessionDirection {
+ for j, vv := range []string{"inbound", "outbound"} {
+ if i == j {
+ return BgpSessionDirection(vv)
+ }
+ }
+ return BgpSessionDirection("")
+}
+
func (v BgpSessionDirection) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid BgpSessionDirection: %s", v)
@@ -150,6 +186,15 @@ func (v MatchSetOptionsRestrictedType) ToInt() int {
return -1
}
+func (v MatchSetOptionsRestrictedType) FromInt(i int) MatchSetOptionsRestrictedType {
+ for j, vv := range []string{"any", "invert"} {
+ if i == j {
+ return MatchSetOptionsRestrictedType(vv)
+ }
+ }
+ return MatchSetOptionsRestrictedType("")
+}
+
func (v MatchSetOptionsRestrictedType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid MatchSetOptionsRestrictedType: %s", v)
@@ -186,6 +231,15 @@ func (v MatchSetOptionsType) ToInt() int {
return -1
}
+func (v MatchSetOptionsType) FromInt(i int) MatchSetOptionsType {
+ for j, vv := range []string{"any", "all", "invert"} {
+ if i == j {
+ return MatchSetOptionsType(vv)
+ }
+ }
+ return MatchSetOptionsType("")
+}
+
func (v MatchSetOptionsType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid MatchSetOptionsType: %s", v)
@@ -224,6 +278,15 @@ func (v DefaultPolicyType) ToInt() int {
return -1
}
+func (v DefaultPolicyType) FromInt(i int) DefaultPolicyType {
+ for j, vv := range []string{"accept-route", "reject-route"} {
+ if i == j {
+ return DefaultPolicyType(vv)
+ }
+ }
+ return DefaultPolicyType("")
+}
+
func (v DefaultPolicyType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid DefaultPolicyType: %s", v)
@@ -258,6 +321,15 @@ func (v BgpSetCommunityOptionType) ToInt() int {
return -1
}
+func (v BgpSetCommunityOptionType) FromInt(i int) BgpSetCommunityOptionType {
+ for j, vv := range []string{"add", "remove", "replace"} {
+ if i == j {
+ return BgpSetCommunityOptionType(vv)
+ }
+ }
+ return BgpSetCommunityOptionType("")
+}
+
func (v BgpSetCommunityOptionType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid BgpSetCommunityOptionType: %s", v)
@@ -283,6 +355,15 @@ func (v BmpRouteMonitoringPolicyType) ToInt() int {
return -1
}
+func (v BmpRouteMonitoringPolicyType) FromInt(i int) BmpRouteMonitoringPolicyType {
+ for j, vv := range []string{"pre-policy", "post-policy", "both"} {
+ if i == j {
+ return BmpRouteMonitoringPolicyType(vv)
+ }
+ }
+ return BmpRouteMonitoringPolicyType("")
+}
+
func (v BmpRouteMonitoringPolicyType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid BmpRouteMonitoringPolicyType: %s", v)
@@ -309,6 +390,15 @@ func (v RpkiValidationResultType) ToInt() int {
return -1
}
+func (v RpkiValidationResultType) FromInt(i int) RpkiValidationResultType {
+ for j, vv := range []string{"none", "not-found", "valid", "invalid"} {
+ if i == j {
+ return RpkiValidationResultType(vv)
+ }
+ }
+ return RpkiValidationResultType("")
+}
+
func (v RpkiValidationResultType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid RpkiValidationResultType: %s", v)
@@ -334,6 +424,15 @@ func (v BgpOriginAttrType) ToInt() int {
return -1
}
+func (v BgpOriginAttrType) FromInt(i int) BgpOriginAttrType {
+ for j, vv := range []string{"igp", "egp", "incomplete"} {
+ if i == j {
+ return BgpOriginAttrType(vv)
+ }
+ }
+ return BgpOriginAttrType("")
+}
+
func (v BgpOriginAttrType) Validate() error {
if v.ToInt() < 0 {
return fmt.Errorf("invalid BgpOriginAttrType: %s", v)