mirror of
https://github.com/netbirdio/netbird.git
synced 2026-04-16 07:16:38 +00:00
279 lines
8.2 KiB
Go
279 lines
8.2 KiB
Go
package rest
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"encoding/json"
|
|
|
|
"github.com/netbirdio/netbird/shared/management/http/api"
|
|
)
|
|
|
|
// PeersAPI APIs for peers, do not use directly
|
|
type PeersAPI struct {
|
|
c *Client
|
|
}
|
|
|
|
// PeersListOption options for Peers List API
|
|
type PeersListOption func() (string, string)
|
|
|
|
func PeerNameFilter(name string) PeersListOption {
|
|
return func() (string, string) {
|
|
return "name", name
|
|
}
|
|
}
|
|
|
|
func PeerIPFilter(ip string) PeersListOption {
|
|
return func() (string, string) {
|
|
return "ip", ip
|
|
}
|
|
}
|
|
|
|
// List list all peers
|
|
// See more: https://docs.netbird.io/api/resources/peers#list-all-peers
|
|
func (a *PeersAPI) List(ctx context.Context, opts ...PeersListOption) ([]api.Peer, error) {
|
|
query := make(map[string]string)
|
|
for _, o := range opts {
|
|
k, v := o()
|
|
query[k] = v
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers", nil, query)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[[]api.Peer](resp)
|
|
return ret, err
|
|
}
|
|
|
|
// Get retrieve a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#retrieve-a-peer
|
|
func (a *PeersAPI) Get(ctx context.Context, peerID string) (*api.Peer, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+peerID, nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.Peer](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Update update information for a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#update-a-peer
|
|
func (a *PeersAPI) Update(ctx context.Context, peerID string, request api.PutApiPeersPeerIdJSONRequestBody) (*api.Peer, error) {
|
|
requestBytes, err := json.Marshal(request)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "PUT", "/api/peers/"+peerID, bytes.NewReader(requestBytes), nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.Peer](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Delete delete a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#delete-a-peer
|
|
func (a *PeersAPI) Delete(ctx context.Context, peerID string) error {
|
|
resp, err := a.c.NewRequest(ctx, "DELETE", "/api/peers/"+peerID, nil, nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// ListAccessiblePeers list all peers that the specified peer can connect to within the network
|
|
// See more: https://docs.netbird.io/api/resources/peers#list-accessible-peers
|
|
func (a *PeersAPI) ListAccessiblePeers(ctx context.Context, peerID string) ([]api.Peer, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+peerID+"/accessible-peers", nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[[]api.Peer](resp)
|
|
return ret, err
|
|
}
|
|
|
|
// CreateTemporaryAccess create temporary access for a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#create-temporary-access
|
|
func (a *PeersAPI) CreateTemporaryAccess(ctx context.Context, peerID string, request api.PostApiPeersPeerIdTemporaryAccessJSONRequestBody) (*api.PeerTemporaryAccessResponse, error) {
|
|
requestBytes, err := json.Marshal(request)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "POST", "/api/peers/"+peerID+"/temporary-access", bytes.NewReader(requestBytes), nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.PeerTemporaryAccessResponse](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// PeerIngressPortsAPI APIs for Peer Ingress Ports, do not use directly
|
|
type PeerIngressPortsAPI struct {
|
|
c *Client
|
|
peerID string
|
|
}
|
|
|
|
// IngressPorts APIs for peer ingress ports
|
|
func (a *PeersAPI) IngressPorts(peerID string) *PeerIngressPortsAPI {
|
|
return &PeerIngressPortsAPI{
|
|
c: a.c,
|
|
peerID: peerID,
|
|
}
|
|
}
|
|
|
|
// List list all ingress port allocations for a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#list-all-ingress-port-allocations
|
|
func (a *PeerIngressPortsAPI) List(ctx context.Context) ([]api.IngressPortAllocation, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+a.peerID+"/ingress/ports", nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[[]api.IngressPortAllocation](resp)
|
|
return ret, err
|
|
}
|
|
|
|
// Get get ingress port allocation info
|
|
// See more: https://docs.netbird.io/api/resources/peers#retrieve-an-ingress-port-allocation
|
|
func (a *PeerIngressPortsAPI) Get(ctx context.Context, allocationID string) (*api.IngressPortAllocation, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+a.peerID+"/ingress/ports/"+allocationID, nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.IngressPortAllocation](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Create create new ingress port allocation
|
|
// See more: https://docs.netbird.io/api/resources/peers#create-an-ingress-port-allocation
|
|
func (a *PeerIngressPortsAPI) Create(ctx context.Context, request api.PostApiPeersPeerIdIngressPortsJSONRequestBody) (*api.IngressPortAllocation, error) {
|
|
requestBytes, err := json.Marshal(request)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "POST", "/api/peers/"+a.peerID+"/ingress/ports", bytes.NewReader(requestBytes), nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.IngressPortAllocation](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Update update ingress port allocation
|
|
// See more: https://docs.netbird.io/api/resources/peers#update-an-ingress-port-allocation
|
|
func (a *PeerIngressPortsAPI) Update(ctx context.Context, allocationID string, request api.PutApiPeersPeerIdIngressPortsAllocationIdJSONRequestBody) (*api.IngressPortAllocation, error) {
|
|
requestBytes, err := json.Marshal(request)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "PUT", "/api/peers/"+a.peerID+"/ingress/ports/"+allocationID, bytes.NewReader(requestBytes), nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.IngressPortAllocation](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Delete delete ingress port allocation
|
|
// See more: https://docs.netbird.io/api/resources/peers#delete-an-ingress-port-allocation
|
|
func (a *PeerIngressPortsAPI) Delete(ctx context.Context, allocationID string) error {
|
|
resp, err := a.c.NewRequest(ctx, "DELETE", "/api/peers/"+a.peerID+"/ingress/ports/"+allocationID, nil, nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// PeerJobsAPI APIs for Peer Jobs, do not use directly
|
|
type PeerJobsAPI struct {
|
|
c *Client
|
|
peerID string
|
|
}
|
|
|
|
// Jobs APIs for peer jobs
|
|
func (a *PeersAPI) Jobs(peerID string) *PeerJobsAPI {
|
|
return &PeerJobsAPI{
|
|
c: a.c,
|
|
peerID: peerID,
|
|
}
|
|
}
|
|
|
|
// List list all jobs for a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#list-all-peer-jobs
|
|
func (a *PeerJobsAPI) List(ctx context.Context) ([]api.JobResponse, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+a.peerID+"/jobs", nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[[]api.JobResponse](resp)
|
|
return ret, err
|
|
}
|
|
|
|
// Get get job info
|
|
// See more: https://docs.netbird.io/api/resources/peers#retrieve-a-peer-job
|
|
func (a *PeerJobsAPI) Get(ctx context.Context, jobID string) (*api.JobResponse, error) {
|
|
resp, err := a.c.NewRequest(ctx, "GET", "/api/peers/"+a.peerID+"/jobs/"+jobID, nil, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.JobResponse](resp)
|
|
return &ret, err
|
|
}
|
|
|
|
// Create create new job for a peer
|
|
// See more: https://docs.netbird.io/api/resources/peers#create-a-peer-job
|
|
func (a *PeerJobsAPI) Create(ctx context.Context, request api.PostApiPeersPeerIdJobsJSONRequestBody) (*api.JobResponse, error) {
|
|
requestBytes, err := json.Marshal(request)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
resp, err := a.c.NewRequest(ctx, "POST", "/api/peers/"+a.peerID+"/jobs", bytes.NewReader(requestBytes), nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Body != nil {
|
|
defer resp.Body.Close()
|
|
}
|
|
ret, err := parseResponse[api.JobResponse](resp)
|
|
return &ret, err
|
|
}
|