Compare commits

..

8 Commits

Author SHA1 Message Date
8035772f71 Merge branch '2-create-firewall-zone-api' 2025-04-13 13:25:26 +02:00
92ec48f4e7 fix 2025-04-13 13:25:14 +02:00
6f78447552 Merge pull request #5 from vegardengen/2-create-firewall-zone-api
fix
2025-04-13 13:20:43 +02:00
898bd842fc fix 2025-04-13 13:19:42 +02:00
4786c4dd6a Merge pull request #4 from vegardengen/2-create-firewall-zone-api
fixes
2025-04-13 12:50:24 +02:00
a37a5c45c3 fixes 2025-04-13 12:49:28 +02:00
27d358911a Merge pull request #3 from vegardengen/2-create-firewall-zone-api
Add minimal firewall zone API
2025-04-13 12:20:59 +02:00
ab3b625a72 Add minimal firewall zone API 2025-04-13 12:14:11 +02:00

51
unifi/firewall_zone.go Normal file
View File

@@ -0,0 +1,51 @@
package unifi
import (
"context"
"fmt"
)
type FirewallZone struct {
ID string `json:"_id,omitempty"`
// Hidden bool `json:"attr_hidden,omitempty"`
// HiddenID string `json:"attr_hidden_id,omitempty"`
// NoDelete bool `json:"attr_no_delete,omitempty"`
// NoEdit bool `json:"attr_no_edit,omitempty"`
Name string `json:"name"`
Description string `json:"desc"`
DefaultZone bool `json:default_zone,omitempty`
NetworkIDs []string `json:network_ids,omitempty`
// Role string `json:"role"`
}
func (c *Client) ListFirewallZones(ctx context.Context, site string) ([]FirewallZone, error) {
var respBody struct {
Meta meta `json:"meta"`
Data []FirewallZone `json:"data"`
}
err := c.do(ctx, "GET", fmt.Sprintf("site/%s/firewall/zone", site), nil, &respBody)
if err != nil {
return nil, err
}
return respBody.Data, nil
}
func (c *Client) GetFirewallZone(ctx context.Context, site, id string) (*FirewallZone, error) {
firewallzones, err := c.ListFirewallZones(ctx, site)
if err != nil {
return nil, err
}
for _, z := range firewallzones {
if z.ID == id {
return &z, nil
}
}
return nil, &NotFoundError{}
}