File: networks_forwards.go

package info (click to toggle)
incus 6.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,392 kB
  • sloc: sh: 16,313; ansic: 3,121; python: 457; makefile: 337; ruby: 51; sql: 50; lisp: 6
file content (75 lines) | stat: -rw-r--r-- 2,767 bytes parent folder | download | duplicates (2)
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
70
71
72
73
74
75
//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_forwards.mapper.go
//generate-database:mapper reset -i -b "//go:build linux && cgo && !agent"
//
//generate-database:mapper stmt -e network_forward objects table=networks_forwards
//generate-database:mapper stmt -e network_forward objects-by-NetworkID table=networks_forwards
//generate-database:mapper stmt -e network_forward objects-by-NetworkID-and-ListenAddress table=networks_forwards
//generate-database:mapper stmt -e network_forward id table=networks_forwards
//generate-database:mapper stmt -e network_forward create table=networks_forwards
//generate-database:mapper stmt -e network_forward update table=networks_forwards
//generate-database:mapper stmt -e network_forward delete-by-NetworkID-and-ID table=networks_forwards
//
//generate-database:mapper method -i -e network_forward GetMany references=Config table=networks_forwards
//generate-database:mapper method -i -e network_forward GetOne table=networks_forwards
//generate-database:mapper method -i -e network_forward ID table=networks_forwards
//generate-database:mapper method -i -e network_forward Create references=Config table=networks_forwards
//generate-database:mapper method -i -e network_forward Update references=Config table=networks_forwards
//generate-database:mapper method -i -e network_forward DeleteOne-by-NetworkID-and-ID table=networks_forwards

// NetworkForward is the generated entity backing the networks_forwards table.
type NetworkForward struct {
	ID            int64
	NetworkID     int64         `db:"primary=yes&column=network_id"`
	NodeID        sql.NullInt64 `db:"column=node_id&nullable=true"`
	Location      *string       `db:"leftjoin=nodes.name&omit=create,update"`
	ListenAddress string        `db:"primary=yes"`
	Description   string
	Ports         []api.NetworkForwardPort `db:"marshal=json"`
}

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

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

	// Fill in the struct.
	out := api.NetworkForward{
		NetworkForwardPut: api.NetworkForwardPut{
			Description: n.Description,
			Config:      cfg,
			Ports:       n.Ports,
		},

		ListenAddress: n.ListenAddress,
	}

	if n.Location != nil {
		out.Location = *n.Location
	}

	return &out, nil
}