File: networks_zones_records.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 (72 lines) | stat: -rw-r--r-- 3,216 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
70
71
72
//go:build linux && cgo && !agent

package cluster

import (
	"context"

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

// Code generation directives.
//
//generate-database:mapper target networks_zones_records.mapper.go
//generate-database:mapper reset -i -b "//go:build linux && cgo && !agent"
//
// Statements:
//generate-database:mapper stmt -e NetworkZoneRecord objects table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord objects-by-ID table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord objects-by-Name table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord objects-by-NetworkZoneID table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord objects-by-NetworkZoneID-and-Name table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord objects-by-NetworkZoneID-and-ID table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord id table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord create table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord rename table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord update table=networks_zones_records
//generate-database:mapper stmt -e NetworkZoneRecord delete-by-NetworkZoneID-and-ID table=networks_zones_records
//
// Methods:
//generate-database:mapper method -i -e NetworkZoneRecord GetMany references=Config table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord GetOne table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord Exists table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord Create references=Config table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord ID table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord Rename table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord Update references=Config table=networks_zones_records
//generate-database:mapper method -i -e NetworkZoneRecord DeleteOne-by-NetworkZoneID-and-ID table=networks_zones_records

// NetworkZoneRecord is a value object holding db-related details about a DNS record in a network zone.
type NetworkZoneRecord struct {
	ID            int    `db:"order=yes"`
	NetworkZoneID int    `db:"primary=yes"`
	Name          string `db:"primary=yes"`
	Description   string
	Entries       []api.NetworkZoneRecordEntry `db:"marshal=json"`
}

// NetworkZoneRecordFilter defines the optional WHERE-clause fields.
type NetworkZoneRecordFilter struct {
	ID            *int
	Name          *string
	NetworkZoneID *int
}

// ToAPI converts the DB record into external API type.
func (r *NetworkZoneRecord) ToAPI(ctx context.Context, db tx) (*api.NetworkZoneRecord, error) {
	config, err := GetNetworkZoneRecordConfig(ctx, db, r.ID)
	if err != nil {
		return nil, err
	}

	out := api.NetworkZoneRecord{
		Name: r.Name,
		NetworkZoneRecordPut: api.NetworkZoneRecordPut{
			Description: r.Description,
			Entries:     r.Entries,
			Config:      config,
		},
	}

	return &out, nil
}