Compare commits

..

11 Commits

Author SHA1 Message Date
9a6bf18774 more omit 2025-04-18 19:31:40 +02:00
c4acd30bfb More omitempty 2025-04-18 11:38:50 +02:00
3a991266a1 More omitempty 2025-04-18 11:35:19 +02:00
ad412ef42b More omitempty 2025-04-18 11:29:17 +02:00
e72621290e More omitempty 2025-04-18 11:19:41 +02:00
42434bf718 omitempty for NetworkIDs in destination 2025-04-18 11:17:01 +02:00
abe6ce09b2 omitempty for NetworkIDs in destination 2025-04-18 11:12:52 +02:00
d008cac359 typo 2025-04-17 11:57:05 +02:00
96cf5ac987 follow casing conventions 2025-04-17 10:35:49 +02:00
d83c354874 Missing field 2025-04-17 10:20:27 +02:00
861a985dd0 Remove some anonymous structs 2025-04-17 10:08:03 +02:00

View File

@@ -5,6 +5,46 @@ import (
"fmt" "fmt"
) )
type FirewallDestination struct {
IPGroupID string `json:"ip_group_id"`
IPs []string `json:"ips,omitempty"`
MatchOppositeIPs bool `json:"match_opposite_ips"`
MatchOppositePorts bool `json:"match_opposite_ports"`
MatchingTarget string `json:"matching_target"`
MatchingTargetType string `json:"matching_target_type"`
NetworkIDs [] string `json:"network_ids,omitempty"`
Port string `json:"port"`
PortGroupID string `json:"port_group_id"`
PortMatchingType string `json:"port_matching_type"`
Regions []string `json:"regions,omitempty"`
ZoneID string `json:"zone_id"`
}
type FirewallSource struct {
ClientMacs []string `json:"client_macs,omitempty"`
IPs []string `json:"ips,omitempty"`
MatchMac bool `json:"match_mac"`
MatchOppositeIPs bool `json:"match_opposite_ips"`
MatchOppositeNetworks bool `json:"match_opposite_networks"`
MatchOppositePorts bool `json:"match_opposite_ports"`
MatchingTarget string `json:"matching_target,omitempty"`
MatchingTargetType string `json:"matching_target_type,omitempty"`
NetworkIDs []string `json:"network_ids,omitempty"`
Port string `json:"port,omitempty"`
PortMatchingType string `json:"port_matching_type,omitempty"`
ZoneID string `json:"zone_id,omitempty"`
}
type FirewallSchedule struct {
Mode string `json:"mode"`
DateStart string `json:"date_start,omitempty"`
DateEnd string `json:"date_end,omitempty"`
RepeatOnDays []string `json:"repeat_on_days"`
TimeAllDay bool `json:"time_all_day"`
TimeRangeStart string `json:"time_range_start,omitempty"`
TimeRangeEnd string `json:"time_range_end,omitempty"`
}
type FirewallPolicy struct { type FirewallPolicy struct {
ID string `json:"_id,omitempty"` ID string `json:"_id,omitempty"`
@@ -18,56 +58,23 @@ type FirewallPolicy struct {
ConnectionStates []string `json:"connection_states"` ConnectionStates []string `json:"connection_states"`
CreateAllowRespond bool `json:"create_allow_respond"` CreateAllowRespond bool `json:"create_allow_respond"`
Description string `json:"description"` Description string `json:"description"`
Destination struct { Destination FirewallDestination `json:"destination"`
IPGroupID string `json:"ip_group_id"`
Ips []string `json:"ips"`
MatchOppositeIps bool `json:"match_opposite_ips"`
MatchOppositePorts bool `json:"match_opposite_ports"`
MatchingTarget string `json:"matching_target"`
NetworkIDs [] string `json:"network_ids"`
Port string `json:"port"`
PortGroupID string `json:"port_group_id"`
PortMatchingType string `json:"port_matching_type"`
Regions []string `json:"regions"`
ZoneID string `json:"zone_id"`
} `json:"destination"`
Enabled bool `json:"enabled"` Enabled bool `json:"enabled"`
IcmpTypename string `json:"icmp_typename"` ICMPTypename string `json:"icmp_typename"`
IcmpV6Typename string `json:"icmp_v6_typename"` ICMPV6Typename string `json:"icmp_v6_typename"`
Index int64 `json:"index"` Index int64 `json:"index"`
IPVersion string `json:"ip_version"` IPVersion string `json:"ip_version"`
Logging bool `json:"logging"` Logging bool `json:"logging"`
MatchIPSec bool `json:"match_ip_sec"` MatchIPSec bool `json:"match_ip_sec"`
MatchIPSecType string `json:"match_ip_sec_type"` MatchIPSecType string `json:"match_ip_sec_type,omitempty"`
MatchOppositeProtocol bool `json:"match_opposite_protocol"` MatchOppositeProtocol bool `json:"match_opposite_protocol"`
Name string `json:"name"` Name string `json:"name"`
OriginID string `json:"origin_id"` OriginID string `json:"origin_id,omitempty"`
OriginType string `json:"origin_type"` OriginType string `json:"origin_type,omitempty"`
Predefined bool `json:"predefined"` Predefined bool `json:"predefined"`
Protocol string `json:"protocol"` Protocol string `json:"protocol"`
Schedule struct { Schedule FirewallSchedule `json:"schedule"`
Mode string `json:"mode"` Source FirewallSource `json:"source"`
DateStart string `json:"date_start"`
DateEnd string `json:"date_end"`
RepeatOnDays []string `json:"repeat_on_days"`
TimeAllDay bool `json:"time_all_day"`
TimeRangeStart string `json:"time_range_start"`
TimeRangeEnd string `json:"time_range_end"`
} `json:"schedule"`
Source struct {
ClientMacs []string `json:"client_macs"`
Ips []string `json:"ips"`
MatchMac bool `json:"match_mac"`
MatchOppositeIps bool `json:"match_opposite_ips"`
MatchOppositeNetworks bool `json:"match_opposite_networks"`
MatchOppositePorts bool `json:"match_opposite_ports"`
MatchingTarget string `json:"matching_target"`
MatchingTargetType string `json:"matching_target_type"`
NetworkIDs []string `json:"network_ids"`
Port string `json:"port"`
PortMatchingType string `json:"port_matching_type"`
ZoneID string `json:"zone_id"`
} `json:"source"`
// Role string `json:"role"` // Role string `json:"role"`
} }
@@ -105,7 +112,7 @@ func (c *Client) DeleteFirewallPolicy(ctx context.Context, site, id string) erro
return nil return nil
} }
func (c *Client) CreaateFirewallPolicy(ctx context.Context, site string, d *FirewallPolicy) (*FirewallPolicy, error) { func (c *Client) CreateFirewallPolicy(ctx context.Context, site string, d *FirewallPolicy) (*FirewallPolicy, error) {
var respBody FirewallPolicy var respBody FirewallPolicy
err := c.do_versioned(ctx, "V2", "POST", fmt.Sprintf("site/%s/firewall-policies", site), d, &respBody) err := c.do_versioned(ctx, "V2", "POST", fmt.Sprintf("site/%s/firewall-policies", site), d, &respBody)