Compare commits

...

22 Commits

Author SHA1 Message Date
db4af29aa6 Merge branch '2-create-firewall-zone-api' 2025-04-14 08:35:41 +02:00
db8d86a2c5 fix 2025-04-14 08:35:30 +02:00
5626d6341e Merge branch '2-create-firewall-zone-api' 2025-04-14 08:19:13 +02:00
825508ed03 debugging 2025-04-14 08:19:06 +02:00
b3b119c402 Merge branch '2-create-firewall-zone-api' 2025-04-13 19:39:29 +02:00
b4e2400bcf Another test 2025-04-13 19:39:16 +02:00
8974e82e78 Merge 2025-04-13 15:42:41 +02:00
01e89ca98d debug firewall zone api 2025-04-13 15:42:28 +02:00
f85fe28c53 Merge branch '2-create-firewall-zone-api' 2025-04-13 15:36:23 +02:00
82702848f9 fix 2025-04-13 15:35:58 +02:00
c52743effa Merge branch '2-create-firewall-zone-api' 2025-04-13 15:26:49 +02:00
b079790183 reverse test 2025-04-13 15:26:35 +02:00
bae6a964eb Merge branch '2-create-firewall-zone-api' 2025-04-13 15:20:31 +02:00
bab50ebfc4 Unifi API v2 2025-04-13 15:20:13 +02:00
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
2 changed files with 58 additions and 2 deletions

49
unifi/firewall_zone.go Normal file
View File

@@ -0,0 +1,49 @@
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"`
DefaultZone bool `json:"default_zone,omitempty"`
NetworkIDs []string `json:"network_ids,omitempty"`
ZoneKey string `json:"zone_key,omitempty"`
// Role string `json:"role"`
}
func (c *Client) ListFirewallZones(ctx context.Context, site string) ([]FirewallZone, error) {
var respBody []FirewallZone
err := c.do(ctx, "GET", fmt.Sprintf("site/%s/firewall/zone", site), nil, &respBody)
if err != nil {
return nil, err
}
return respBody, 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{}
}

View File

@@ -13,6 +13,7 @@ import (
"path" "path"
"strings" "strings"
"sync" "sync"
"log"
) )
const ( const (
@@ -213,8 +214,12 @@ func (c *Client) do(ctx context.Context, method, relativeURL string, reqBody int
return fmt.Errorf("unable to parse URL: %s %s %w", method, relativeURL, err) return fmt.Errorf("unable to parse URL: %s %s %w", method, relativeURL, err)
} }
if !strings.HasPrefix(relativeURL, "/") && !reqURL.IsAbs() { if !strings.HasPrefix(relativeURL, "/") && !reqURL.IsAbs() {
if strings.Contains(relativeURL, "firewall/zone") {
reqURL.Path = path.Join(c.apiV2Path, reqURL.Path)
} else {
reqURL.Path = path.Join(c.apiPath, reqURL.Path) reqURL.Path = path.Join(c.apiPath, reqURL.Path)
} }
}
url := c.baseURL.ResolveReference(reqURL) url := c.baseURL.ResolveReference(reqURL)
req, err := http.NewRequestWithContext(ctx, method, url.String(), reqReader) req, err := http.NewRequestWithContext(ctx, method, url.String(), reqReader)
@@ -270,6 +275,8 @@ func (c *Client) do(ctx context.Context, method, relativeURL string, reqBody int
// TODO: check rc in addition to status code? // TODO: check rc in addition to status code?
log.Printf("%+v", respBody)
log.Printf("%+v", resp.Body)
err = json.NewDecoder(resp.Body).Decode(respBody) err = json.NewDecoder(resp.Body).Decode(respBody)
if err != nil { if err != nil {
return fmt.Errorf("unable to decode body: %s %s %w", method, relativeURL, err) return fmt.Errorf("unable to decode body: %s %s %w", method, relativeURL, err)