File: networks_load_balancers.go

package info (click to toggle)
incus 6.0.5-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 24,428 kB
  • sloc: sh: 16,313; ansic: 3,121; python: 457; makefile: 337; ruby: 51; sql: 50; lisp: 6
file content (69 lines) | stat: -rw-r--r-- 2,832 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
//go:build linux && cgo && !agent

package cluster

import (
	"context"
	"database/sql"

	"github.com/lxc/incus/v6/shared/api"
)

// Code generation directives.
//
//generate-database:mapper target networks_load_balancers.mapper.go
//generate-database:mapper reset -i -b "//go:build linux && cgo && !agent"
//
//generate-database:mapper stmt -e network_load_balancer objects table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer objects-by-NetworkID table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer objects-by-NetworkID-and-ListenAddress table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer id table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer create table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer update table=networks_load_balancers
//generate-database:mapper stmt -e network_load_balancer delete-by-NetworkID-and-ID table=networks_load_balancers
//
//generate-database:mapper method -i -e network_load_balancer GetMany references=Config table=networks_load_balancers
//generate-database:mapper method -i -e network_load_balancer GetOne table=networks_load_balancers
//generate-database:mapper method -i -e network_load_balancer ID table=networks_load_balancers
//generate-database:mapper method -i -e network_load_balancer Create references=Config table=networks_load_balancers
//generate-database:mapper method -i -e network_load_balancer Update references=Config table=networks_load_balancers
//generate-database:mapper method -i -e network_load_balancer DeleteOne-by-NetworkID-and-ID table=networks_load_balancers

// NetworkLoadBalancer is the generated entity backing the networks_load_balancers table.
type NetworkLoadBalancer struct {
	ID            int64
	NetworkID     int64  `db:"primary=yes&column=network_id"`
	ListenAddress string `db:"primary=yes"`
	Description   string
	Backends      []api.NetworkLoadBalancerBackend `db:"marshal=json"`
	Ports         []api.NetworkLoadBalancerPort    `db:"marshal=json"`
}

// NetworkLoadBalancerFilter defines the optional WHERE-clause fields.
type NetworkLoadBalancerFilter struct {
	ID            *int64
	NetworkID     *int64
	ListenAddress *string
}

// ToAPI converts the DB record into the external API type.
func (n *NetworkLoadBalancer) ToAPI(ctx context.Context, tx *sql.Tx) (*api.NetworkLoadBalancer, error) {
	// Get the config.
	cfg, err := GetNetworkLoadBalancerConfig(ctx, tx, int(n.ID))
	if err != nil {
		return nil, err
	}

	out := api.NetworkLoadBalancer{
		NetworkLoadBalancerPut: api.NetworkLoadBalancerPut{
			Description: n.Description,
			Config:      cfg,
			Backends:    n.Backends,
			Ports:       n.Ports,
		},

		ListenAddress: n.ListenAddress,
	}

	return &out, nil
}