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
|
//go:build linux && cgo && !agent
package cluster
import (
"database/sql"
"time"
)
// Code generation directives.
//
//generate-database:mapper target images.mapper.go
//generate-database:mapper reset -i -b "//go:build linux && cgo && !agent"
//
//generate-database:mapper stmt -e image objects
//generate-database:mapper stmt -e image objects-by-ID
//generate-database:mapper stmt -e image objects-by-Project
//generate-database:mapper stmt -e image objects-by-Project-and-Cached
//generate-database:mapper stmt -e image objects-by-Project-and-Public
//generate-database:mapper stmt -e image objects-by-Fingerprint
//generate-database:mapper stmt -e image objects-by-Cached
//generate-database:mapper stmt -e image objects-by-AutoUpdate
//
//generate-database:mapper method -i -e image GetMany
//generate-database:mapper method -i -e image GetOne
// Image is a value object holding db-related details about an image.
type Image struct {
ID int
Project string `db:"primary=yes&join=projects.name"`
Fingerprint string `db:"primary=yes"`
Type int
Filename string
Size int64
Public bool
Architecture int
CreationDate sql.NullTime
ExpiryDate sql.NullTime
UploadDate time.Time
Cached bool
LastUseDate sql.NullTime
AutoUpdate bool
}
// ImageFilter can be used to filter results yielded by GetImages.
type ImageFilter struct {
ID *int
Project *string
Fingerprint *string
Public *bool
Cached *bool
AutoUpdate *bool
}
|