Documentation ¶
Overview ¶
Package models contains generated Reform records and helpers.
Common order of helpers:
- unexported validators (checkXXX);
- FindAllXXX;
- FindXXXByID;
- other finder (e.g. FindNodesForAgent);
- CreateXXX;
- ChangeXXX;
- RemoveXXX.
Index ¶
- Constants
- Variables
- func ChangeActionResult(q *reform.Querier, actionID, pmmAgentID, aError, output string, done bool) error
- func CleanupOldActionResults(q *reform.Querier, olderThan time.Time) error
- func CleanupOldJobResults(q *reform.Querier, olderThan time.Time) error
- func CountChannels(q *reform.Querier) (int, error)
- func CountRules(q *reform.Querier) (int, error)
- func FindBackupLocationsByIDs(q *reform.Querier, ids []string) (map[string]*BackupLocation, error)
- func FindCheckSettings(q *reform.Querier) (map[string]Interval, error)
- func FindPMMAgentsIDsWithPushMetrics(q *reform.Querier) ([]string, error)
- func FindPmmAgentIDToRunActionOrJob(pmmAgentID string, agents []*Agent) (string, error)
- func FindServicesByIDs(q *reform.Querier, ids []string) (map[string]*Service, error)
- func IsPushMetricsSupported(pmmAgentVersion *string) bool
- func MergeLabels(node *Node, service *Service, agent *Agent) (map[string]string, error)
- func OpenDB(address, name, username, password string) (*sql.DB, error)
- func RemoveArtifact(q *reform.Querier, id string) error
- func RemoveBackupLocation(q *reform.Querier, id string, mode RemoveMode) error
- func RemoveChannel(q *reform.Querier, id string) error
- func RemoveKubernetesCluster(q *reform.Querier, name string) error
- func RemoveNode(q *reform.Querier, id string, mode RemoveMode) error
- func RemoveRule(q *reform.Querier, id string) error
- func RemoveService(q *reform.Querier, id string, mode RemoveMode) error
- func RemoveTemplate(q *reform.Querier, name string) error
- func SaveSettings(q reform.DBTX, s *Settings) error
- func SetupDB(sqlDB *sql.DB, params *SetupDBParams) (*reform.DB, error)
- func ValidateSettings(params *ChangeSettingsParams) error
- func VerifyBackupLocationConfig(params *VerifyBackupLocationParams) error
- type ActionResult
- func (s *ActionResult) AfterFind() error
- func (s *ActionResult) BeforeInsert() error
- func (s *ActionResult) BeforeUpdate() error
- func (s *ActionResult) HasPK() bool
- func (s *ActionResult) PKPointer() interface{}
- func (s *ActionResult) PKValue() interface{}
- func (s *ActionResult) Pointers() []interface{}
- func (s *ActionResult) SetPK(pk interface{})deprecated
- func (s ActionResult) String() string
- func (s *ActionResult) Table() reform.Table
- func (s *ActionResult) Values() []interface{}
- func (s *ActionResult) View() reform.View
- type AddDBMSServiceParams
- type Agent
- func ChangeAgent(q *reform.Querier, agentID string, params *ChangeCommonAgentParams) (*Agent, error)
- func CreateAgent(q *reform.Querier, agentType AgentType, params *CreateAgentParams) (*Agent, error)
- func CreateExternalExporter(q *reform.Querier, params *CreateExternalExporterParams) (*Agent, error)
- func CreateNodeExporter(q *reform.Querier, pmmAgentID string, customLabels map[string]string, ...) (*Agent, error)
- func CreatePMMAgent(q *reform.Querier, runsOnNodeID string, customLabels map[string]string) (*Agent, error)
- func FindAgentByID(q *reform.Querier, id string) (*Agent, error)
- func FindAgents(q *reform.Querier, filters AgentFilters) ([]*Agent, error)
- func FindAgentsByIDs(q *reform.Querier, ids []string) ([]*Agent, error)
- func FindAgentsForScrapeConfig(q *reform.Querier, pmmAgentID *string, pushMetrics bool) ([]*Agent, error)
- func FindDSNByServiceIDandPMMAgentID(q *reform.Querier, serviceID, pmmAgentID, db string) (string, *Agent, error)
- func FindPMMAgentsForService(q *reform.Querier, serviceID string) ([]*Agent, error)
- func FindPMMAgentsForServicesOnNode(q *reform.Querier, nodeID string) ([]*Agent, error)
- func FindPMMAgentsForVersion(logger *logrus.Entry, agents []*Agent, minPMMAgentVersion *version.Parsed) []*Agent
- func FindPMMAgentsRunningOnNode(q *reform.Querier, nodeID string) ([]*Agent, error)
- func RemoveAgent(q *reform.Querier, id string, mode RemoveMode) (*Agent, error)
- func (s *Agent) AfterFind() error
- func (s *Agent) BeforeInsert() error
- func (s *Agent) BeforeUpdate() error
- func (s *Agent) DSN(service *Service, dialTimeout time.Duration, database string, ...) string
- func (s *Agent) ExporterURL(q *reform.Querier) (string, error)
- func (s Agent) Files() map[string]string
- func (s *Agent) GetCustomLabels() (map[string]string, error)
- func (s *Agent) HasPK() bool
- func (s *Agent) IsMySQLTablestatsGroupEnabled() bool
- func (s *Agent) PKPointer() interface{}
- func (s *Agent) PKValue() interface{}
- func (s *Agent) Pointers() []interface{}
- func (s *Agent) SetCustomLabels(m map[string]string) error
- func (s *Agent) SetPK(pk interface{})deprecated
- func (s Agent) String() string
- func (s *Agent) Table() reform.Table
- func (s Agent) TemplateDelimiters(svc *Service) *DelimiterPair
- func (s *Agent) UnifiedLabels() (map[string]string, error)
- func (s *Agent) Values() []interface{}
- func (s *Agent) View() reform.View
- type AgentFilters
- type AgentType
- type Artifact
- func (s *Artifact) AfterFind() error
- func (s *Artifact) BeforeInsert() error
- func (s *Artifact) HasPK() bool
- func (s *Artifact) PKPointer() interface{}
- func (s *Artifact) PKValue() interface{}
- func (s *Artifact) Pointers() []interface{}
- func (s *Artifact) SetPK(pk interface{})deprecated
- func (s Artifact) String() string
- func (s *Artifact) Table() reform.Table
- func (s *Artifact) Values() []interface{}
- func (s *Artifact) View() reform.View
- type AzureOptions
- type AzureOptionsParams
- type BackupLocation
- func ChangeBackupLocation(q *reform.Querier, locationID string, params ChangeBackupLocationParams) (*BackupLocation, error)
- func CreateBackupLocation(q *reform.Querier, params CreateBackupLocationParams) (*BackupLocation, error)
- func FindBackupLocationByID(q *reform.Querier, id string) (*BackupLocation, error)
- func FindBackupLocations(q *reform.Querier) ([]*BackupLocation, error)
- func (s *BackupLocation) AfterFind() error
- func (s *BackupLocation) BeforeInsert() error
- func (s *BackupLocation) BeforeUpdate() error
- func (s *BackupLocation) HasPK() bool
- func (s *BackupLocation) PKPointer() interface{}
- func (s *BackupLocation) PKValue() interface{}
- func (s *BackupLocation) Pointers() []interface{}
- func (s *BackupLocation) SetPK(pk interface{})deprecated
- func (s BackupLocation) String() string
- func (s *BackupLocation) Table() reform.Table
- func (s *BackupLocation) Values() []interface{}
- func (s *BackupLocation) View() reform.View
- type BackupLocationConfig
- type BackupLocationType
- type BackupStatus
- type BoolParam
- type ChangeBackupLocationParams
- type ChangeChannelParams
- type ChangeCommonAgentParams
- type ChangeRuleParams
- type ChangeSettingsParams
- type ChangeTemplateParams
- type Channel
- func ChangeChannel(q *reform.Querier, channelID string, params *ChangeChannelParams) (*Channel, error)
- func CreateChannel(q *reform.Querier, params *CreateChannelParams) (*Channel, error)
- func FindChannelByID(q *reform.Querier, id string) (*Channel, error)
- func FindChannels(q *reform.Querier) ([]*Channel, error)
- func FindChannelsByIDs(q *reform.Querier, ids []string) ([]*Channel, error)
- func FindChannelsOnPage(q *reform.Querier, pageIndex, pageSize int) ([]*Channel, error)
- func (c *Channel) AfterFind() error
- func (c *Channel) BeforeInsert() error
- func (c *Channel) BeforeUpdate() error
- func (s *Channel) HasPK() bool
- func (s *Channel) PKPointer() interface{}
- func (s *Channel) PKValue() interface{}
- func (s *Channel) Pointers() []interface{}
- func (s *Channel) SetPK(pk interface{})deprecated
- func (s Channel) String() string
- func (s *Channel) Table() reform.Table
- func (s *Channel) Values() []interface{}
- func (s *Channel) View() reform.View
- type ChannelIDs
- type ChannelType
- type CheckSettings
- func (s *CheckSettings) HasPK() bool
- func (s *CheckSettings) PKPointer() interface{}
- func (s *CheckSettings) PKValue() interface{}
- func (s *CheckSettings) Pointers() []interface{}
- func (s *CheckSettings) SetPK(pk interface{})deprecated
- func (s CheckSettings) String() string
- func (s *CheckSettings) Table() reform.Table
- func (s *CheckSettings) Values() []interface{}
- func (s *CheckSettings) View() reform.View
- type CreateAgentParams
- type CreateArtifactParams
- type CreateBackupLocationParams
- type CreateChannelParams
- type CreateExternalExporterParams
- type CreateKubernetesClusterParams
- type CreateNodeParams
- type CreateRuleParams
- type CreateTemplateParams
- type DataModel
- type DelimiterPair
- type EchoJobResult
- type EmailAlertingSettings
- type EmailConfig
- type Filter
- type FilterType
- type Filters
- type FloatParam
- type HTTPBasicAuth
- type HTTPConfig
- type Interval
- type JobResult
- func (r *JobResult) AfterFind() error
- func (r *JobResult) BeforeInsert() error
- func (r *JobResult) BeforeUpdate() error
- func (s *JobResult) HasPK() bool
- func (s *JobResult) PKPointer() interface{}
- func (s *JobResult) PKValue() interface{}
- func (s *JobResult) Pointers() []interface{}
- func (s *JobResult) SetPK(pk interface{})deprecated
- func (s JobResult) String() string
- func (s *JobResult) Table() reform.Table
- func (s *JobResult) Values() []interface{}
- func (s *JobResult) View() reform.View
- type JobResultData
- type JobType
- type KubernetesCluster
- func (s *KubernetesCluster) AfterFind() error
- func (s *KubernetesCluster) BeforeInsert() error
- func (s *KubernetesCluster) BeforeUpdate() error
- func (s *KubernetesCluster) HasPK() bool
- func (s *KubernetesCluster) PKPointer() interface{}
- func (s *KubernetesCluster) PKValue() interface{}
- func (s *KubernetesCluster) Pointers() []interface{}
- func (s *KubernetesCluster) SetPK(pk interface{})deprecated
- func (s KubernetesCluster) String() string
- func (s *KubernetesCluster) Table() reform.Table
- func (s *KubernetesCluster) Values() []interface{}
- func (s *KubernetesCluster) View() reform.View
- type MetricsResolutions
- type MongoDBOptions
- type MongoDBOptionsParams
- type Node
- func CheckUniqueNodeInstanceRegion(q *reform.Querier, instance string, region *string) (*Node, error)
- func CreateNode(q *reform.Querier, nodeType NodeType, params *CreateNodeParams) (*Node, error)
- func FindNodeByID(q *reform.Querier, id string) (*Node, error)
- func FindNodeByName(q *reform.Querier, name string) (*Node, error)
- func FindNodes(q *reform.Querier, filters NodeFilters) ([]*Node, error)
- func FindNodesByIDs(q *reform.Querier, ids []string) ([]*Node, error)
- func (s *Node) AfterFind() error
- func (s *Node) BeforeInsert() error
- func (s *Node) BeforeUpdate() error
- func (s *Node) GetCustomLabels() (map[string]string, error)
- func (s *Node) HasPK() bool
- func (s *Node) PKPointer() interface{}
- func (s *Node) PKValue() interface{}
- func (s *Node) Pointers() []interface{}
- func (s *Node) SetCustomLabels(m map[string]string) error
- func (s *Node) SetPK(pk interface{})deprecated
- func (s Node) String() string
- func (s *Node) Table() reform.Table
- func (s *Node) UnifiedLabels() (map[string]string, error)
- func (s *Node) Values() []interface{}
- func (s *Node) View() reform.View
- type NodeFilters
- type NodeType
- type PMMClientLocationConfig
- type PMMServerLocationConfig
- type PagerDutyConfig
- type ParamType
- type RemoveMode
- type Rule
- func ChangeRule(q *reform.Querier, ruleID string, params *ChangeRuleParams) (*Rule, error)
- func CreateRule(q *reform.Querier, params *CreateRuleParams) (*Rule, error)
- func FindRuleByID(q *reform.Querier, id string) (*Rule, error)
- func FindRules(q *reform.Querier) ([]*Rule, error)
- func FindRulesOnPage(q *reform.Querier, pageIndex, pageSize int) ([]*Rule, error)
- func ToggleRule(q *reform.Querier, ruleID string, params *ToggleRuleParams) (*Rule, error)
- func (r *Rule) AfterFind() error
- func (r *Rule) BeforeInsert() error
- func (r *Rule) BeforeUpdate() error
- func (r *Rule) GetCustomLabels() (map[string]string, error)
- func (s *Rule) HasPK() bool
- func (s *Rule) PKPointer() interface{}
- func (s *Rule) PKValue() interface{}
- func (s *Rule) Pointers() []interface{}
- func (r *Rule) SetCustomLabels(m map[string]string) error
- func (s *Rule) SetPK(pk interface{})deprecated
- func (s Rule) String() string
- func (s *Rule) Table() reform.Table
- func (s *Rule) Values() []interface{}
- func (s *Rule) View() reform.View
- type RuleParam
- type RuleParams
- type S3LocationConfig
- type STTCheckIntervals
- type SaaS
- type Service
- func AddNewService(q *reform.Querier, serviceType ServiceType, params *AddDBMSServiceParams) (*Service, error)
- func FindServiceByID(q *reform.Querier, id string) (*Service, error)
- func FindServiceByName(q *reform.Querier, name string) (*Service, error)
- func FindServices(q *reform.Querier, filters ServiceFilters) ([]*Service, error)
- func (s *Service) AfterFind() error
- func (s *Service) BeforeInsert() error
- func (s *Service) BeforeUpdate() error
- func (s *Service) GetCustomLabels() (map[string]string, error)
- func (s *Service) HasPK() bool
- func (s *Service) PKPointer() interface{}
- func (s *Service) PKValue() interface{}
- func (s *Service) Pointers() []interface{}
- func (s *Service) SetCustomLabels(m map[string]string) error
- func (s *Service) SetPK(pk interface{})deprecated
- func (s Service) String() string
- func (s *Service) Table() reform.Table
- func (s *Service) UnifiedLabels() (map[string]string, error)
- func (s *Service) Values() []interface{}
- func (s *Service) View() reform.View
- type ServiceFilters
- type ServiceType
- type Settings
- type SetupDBParams
- type SetupFixturesMode
- type Severity
- type SlackAlertingSettings
- type SlackConfig
- type Source
- type StringParam
- type TLSConfig
- type Template
- func ChangeTemplate(q *reform.Querier, params *ChangeTemplateParams) (*Template, error)
- func CreateTemplate(q *reform.Querier, params *CreateTemplateParams) (*Template, error)
- func FindTemplateByName(q *reform.Querier, name string) (*Template, error)
- func FindTemplates(q *reform.Querier) ([]Template, error)
- func (t *Template) AfterFind() error
- func (t *Template) BeforeInsert() error
- func (t *Template) BeforeUpdate() error
- func (t *Template) GetAnnotations() (map[string]string, error)
- func (t *Template) GetLabels() (map[string]string, error)
- func (s *Template) HasPK() bool
- func (s *Template) PKPointer() interface{}
- func (s *Template) PKValue() interface{}
- func (s *Template) Pointers() []interface{}
- func (t *Template) SetAnnotations(m map[string]string) error
- func (t *Template) SetLabels(m map[string]string) error
- func (s *Template) SetPK(pk interface{})deprecated
- func (s Template) String() string
- func (s *Template) Table() reform.Table
- func (s *Template) Values() []interface{}
- func (s *Template) View() reform.View
- type TemplateParam
- type TemplateParams
- type Tiers
- type ToggleRuleParams
- type VerifyBackupLocationParams
- type VictoriaMetricsParams
- type WebHookConfig
Constants ¶
const ( Email = ChannelType("email") PagerDuty = ChannelType("pagerduty") Slack = ChannelType("slack") WebHook = ChannelType("webhook") )
Available notification channel types.
const ( Float = ParamType("float") Bool = ParamType("bool") String = ParamType("string") )
Available parameter types.
const ( Equal = FilterType("=") Regex = FilterType("=~") )
Available filter types.
const ( BuiltInSource = Source("built_in") SAASSource = Source("saas") UserFileSource = Source("user_file") UserAPISource = Source("user_api") )
Available template sources.
const (
Echo = JobType("echo")
)
Supported job types.
const PMMServerAgentID string = "pmm-server" // no /agent_id/ prefix
PMMServerAgentID is a special Agent ID representing pmm-agent on PMM Server.
const PMMServerNodeID string = "pmm-server" // no /node_id/ prefix
PMMServerNodeID is a special Node ID representing PMM Server Node.
const PMMServerPostgreSQLServiceName = "pmm-server-postgresql"
PMMServerPostgreSQLServiceName is a special Service Name representing PMM Server's PostgreSQL Service.
Variables ¶
var ( // ErrNotFound returned when entity is not found. ErrNotFound = errors.New("not found") // ErrInvalidArgument returned when some passed argument is invalid. ErrInvalidArgument = errors.New("invalid argument") )
var ActionResultTable = &actionResultTableType{ s: parse.StructInfo{ Type: "ActionResult", SQLName: "action_results", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "PMMAgentID", Type: "string", Column: "pmm_agent_id"}, {Name: "Done", Type: "bool", Column: "done"}, {Name: "Error", Type: "string", Column: "error"}, {Name: "Output", Type: "string", Column: "output"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(ActionResult).Values(), }
ActionResultTable represents action_results view or table in SQL database.
var AgentTable = &agentTableType{ s: parse.StructInfo{ Type: "Agent", SQLName: "agents", Fields: []parse.FieldInfo{ {Name: "AgentID", Type: "string", Column: "agent_id"}, {Name: "AgentType", Type: "AgentType", Column: "agent_type"}, {Name: "RunsOnNodeID", Type: "*string", Column: "runs_on_node_id"}, {Name: "ServiceID", Type: "*string", Column: "service_id"}, {Name: "NodeID", Type: "*string", Column: "node_id"}, {Name: "PMMAgentID", Type: "*string", Column: "pmm_agent_id"}, {Name: "CustomLabels", Type: "[]uint8", Column: "custom_labels"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, {Name: "Disabled", Type: "bool", Column: "disabled"}, {Name: "Status", Type: "string", Column: "status"}, {Name: "ListenPort", Type: "*uint16", Column: "listen_port"}, {Name: "Version", Type: "*string", Column: "version"}, {Name: "Username", Type: "*string", Column: "username"}, {Name: "Password", Type: "*string", Column: "password"}, {Name: "TLS", Type: "bool", Column: "tls"}, {Name: "TLSSkipVerify", Type: "bool", Column: "tls_skip_verify"}, {Name: "AWSAccessKey", Type: "*string", Column: "aws_access_key"}, {Name: "AWSSecretKey", Type: "*string", Column: "aws_secret_key"}, {Name: "AzureOptions", Type: "*AzureOptions", Column: "azure_options"}, {Name: "TableCount", Type: "*int32", Column: "table_count"}, {Name: "TableCountTablestatsGroupLimit", Type: "int32", Column: "table_count_tablestats_group_limit"}, {Name: "QueryExamplesDisabled", Type: "bool", Column: "query_examples_disabled"}, {Name: "MaxQueryLogSize", Type: "int64", Column: "max_query_log_size"}, {Name: "MetricsPath", Type: "*string", Column: "metrics_path"}, {Name: "MetricsScheme", Type: "*string", Column: "metrics_scheme"}, {Name: "RDSBasicMetricsDisabled", Type: "bool", Column: "rds_basic_metrics_disabled"}, {Name: "RDSEnhancedMetricsDisabled", Type: "bool", Column: "rds_enhanced_metrics_disabled"}, {Name: "PushMetrics", Type: "bool", Column: "push_metrics"}, {Name: "DisabledCollectors", Type: "pq.StringArray", Column: "disabled_collectors"}, {Name: "MongoDBOptions", Type: "*MongoDBOptions", Column: "mongo_db_tls_options"}, }, PKFieldIndex: 0, }, z: new(Agent).Values(), }
AgentTable represents agents view or table in SQL database.
var ArtifactTable = &artifactTableType{ s: parse.StructInfo{ Type: "Artifact", SQLName: "artifacts", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "Name", Type: "string", Column: "name"}, {Name: "Vendor", Type: "string", Column: "vendor"}, {Name: "LocationID", Type: "string", Column: "location_id"}, {Name: "ServiceID", Type: "string", Column: "service_id"}, {Name: "DataModel", Type: "DataModel", Column: "data_model"}, {Name: "Status", Type: "BackupStatus", Column: "status"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, }, PKFieldIndex: 0, }, z: new(Artifact).Values(), }
ArtifactTable represents artifacts view or table in SQL database.
var BackupLocationTable = &backupLocationTableType{ s: parse.StructInfo{ Type: "BackupLocation", SQLName: "backup_locations", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "Name", Type: "string", Column: "name"}, {Name: "Description", Type: "string", Column: "description"}, {Name: "Type", Type: "BackupLocationType", Column: "type"}, {Name: "S3Config", Type: "*S3LocationConfig", Column: "s3_config"}, {Name: "PMMServerConfig", Type: "*PMMServerLocationConfig", Column: "pmm_server_config"}, {Name: "PMMClientConfig", Type: "*PMMClientLocationConfig", Column: "pmm_client_config"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(BackupLocation).Values(), }
BackupLocationTable represents backup_locations view or table in SQL database.
var ChannelTable = &channelTableType{ s: parse.StructInfo{ Type: "Channel", SQLName: "ia_channels", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "Summary", Type: "string", Column: "summary"}, {Name: "Type", Type: "ChannelType", Column: "type"}, {Name: "EmailConfig", Type: "*EmailConfig", Column: "email_config"}, {Name: "PagerDutyConfig", Type: "*PagerDutyConfig", Column: "pagerduty_config"}, {Name: "SlackConfig", Type: "*SlackConfig", Column: "slack_config"}, {Name: "WebHookConfig", Type: "*WebHookConfig", Column: "webhook_config"}, {Name: "Disabled", Type: "bool", Column: "disabled"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(Channel).Values(), }
ChannelTable represents ia_channels view or table in SQL database.
var CheckSettingsTable = &checkSettingsTableType{ s: parse.StructInfo{ Type: "CheckSettings", SQLName: "check_settings", Fields: []parse.FieldInfo{ {Name: "Name", Type: "string", Column: "name"}, {Name: "Interval", Type: "Interval", Column: "interval"}, }, PKFieldIndex: 0, }, z: new(CheckSettings).Values(), }
CheckSettingsTable represents check_settings view or table in SQL database.
var JobResultTable = &jobResultTableType{ s: parse.StructInfo{ Type: "JobResult", SQLName: "job_results", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "PMMAgentID", Type: "string", Column: "pmm_agent_id"}, {Name: "Type", Type: "JobType", Column: "type"}, {Name: "Done", Type: "bool", Column: "done"}, {Name: "Error", Type: "string", Column: "error"}, {Name: "Result", Type: "*JobResultData", Column: "result"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(JobResult).Values(), }
JobResultTable represents job_results view or table in SQL database.
var KubernetesClusterTable = &kubernetesClusterTableType{ s: parse.StructInfo{ Type: "KubernetesCluster", SQLName: "kubernetes_clusters", Fields: []parse.FieldInfo{ {Name: "ID", Type: "string", Column: "id"}, {Name: "KubernetesClusterName", Type: "string", Column: "kubernetes_cluster_name"}, {Name: "KubeConfig", Type: "string", Column: "kube_config"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(KubernetesCluster).Values(), }
KubernetesClusterTable represents kubernetes_clusters view or table in SQL database.
var NodeTable = &nodeTableType{ s: parse.StructInfo{ Type: "Node", SQLName: "nodes", Fields: []parse.FieldInfo{ {Name: "NodeID", Type: "string", Column: "node_id"}, {Name: "NodeType", Type: "NodeType", Column: "node_type"}, {Name: "NodeName", Type: "string", Column: "node_name"}, {Name: "MachineID", Type: "*string", Column: "machine_id"}, {Name: "Distro", Type: "string", Column: "distro"}, {Name: "NodeModel", Type: "string", Column: "node_model"}, {Name: "AZ", Type: "string", Column: "az"}, {Name: "CustomLabels", Type: "[]uint8", Column: "custom_labels"}, {Name: "Address", Type: "string", Column: "address"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, {Name: "ContainerID", Type: "*string", Column: "container_id"}, {Name: "ContainerName", Type: "*string", Column: "container_name"}, {Name: "Region", Type: "*string", Column: "region"}, }, PKFieldIndex: 0, }, z: new(Node).Values(), }
NodeTable represents nodes view or table in SQL database.
var Now = func() time.Time { return time.Now().Truncate(time.Microsecond).UTC() }
Now returns current time with database precision.
var PMMAgentWithPushMetricsSupport = version.MustParse("2.11.99")
PMMAgentWithPushMetricsSupport - version of pmmAgent, that support vmagent and push metrics mode will be released with PMM Agent v2.12.
var RuleTable = &ruleTableType{ s: parse.StructInfo{ Type: "Rule", SQLName: "ia_rules", Fields: []parse.FieldInfo{ {Name: "TemplateName", Type: "string", Column: "template_name"}, {Name: "ID", Type: "string", Column: "id"}, {Name: "Summary", Type: "string", Column: "summary"}, {Name: "Disabled", Type: "bool", Column: "disabled"}, {Name: "Params", Type: "RuleParams", Column: "params"}, {Name: "For", Type: "time.Duration", Column: "for"}, {Name: "Severity", Type: "Severity", Column: "severity"}, {Name: "CustomLabels", Type: "[]uint8", Column: "custom_labels"}, {Name: "Filters", Type: "Filters", Column: "filters"}, {Name: "ChannelIDs", Type: "ChannelIDs", Column: "channel_ids"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 1, }, z: new(Rule).Values(), }
RuleTable represents ia_rules view or table in SQL database.
var ServiceTable = &serviceTableType{ s: parse.StructInfo{ Type: "Service", SQLName: "services", Fields: []parse.FieldInfo{ {Name: "ServiceID", Type: "string", Column: "service_id"}, {Name: "ServiceType", Type: "ServiceType", Column: "service_type"}, {Name: "ServiceName", Type: "string", Column: "service_name"}, {Name: "NodeID", Type: "string", Column: "node_id"}, {Name: "Environment", Type: "string", Column: "environment"}, {Name: "Cluster", Type: "string", Column: "cluster"}, {Name: "ReplicationSet", Type: "string", Column: "replication_set"}, {Name: "CustomLabels", Type: "[]uint8", Column: "custom_labels"}, {Name: "ExternalGroup", Type: "string", Column: "external_group"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, {Name: "Address", Type: "*string", Column: "address"}, {Name: "Port", Type: "*uint16", Column: "port"}, {Name: "Socket", Type: "*string", Column: "socket"}, }, PKFieldIndex: 0, }, z: new(Service).Values(), }
ServiceTable represents services view or table in SQL database.
var TemplateTable = &templateTableType{ s: parse.StructInfo{ Type: "Template", SQLName: "ia_templates", Fields: []parse.FieldInfo{ {Name: "Name", Type: "string", Column: "name"}, {Name: "Version", Type: "uint32", Column: "version"}, {Name: "Summary", Type: "string", Column: "summary"}, {Name: "Tiers", Type: "Tiers", Column: "tiers"}, {Name: "Expr", Type: "string", Column: "expr"}, {Name: "Params", Type: "TemplateParams", Column: "params"}, {Name: "For", Type: "time.Duration", Column: "for"}, {Name: "Severity", Type: "Severity", Column: "severity"}, {Name: "Labels", Type: "[]uint8", Column: "labels"}, {Name: "Annotations", Type: "[]uint8", Column: "annotations"}, {Name: "Source", Type: "Source", Column: "source"}, {Name: "Yaml", Type: "string", Column: "yaml"}, {Name: "CreatedAt", Type: "time.Time", Column: "created_at"}, {Name: "UpdatedAt", Type: "time.Time", Column: "updated_at"}, }, PKFieldIndex: 0, }, z: new(Template).Values(), }
TemplateTable represents ia_templates view or table in SQL database.
Functions ¶
func ChangeActionResult ¶
func ChangeActionResult(q *reform.Querier, actionID, pmmAgentID, aError, output string, done bool) error
ChangeActionResult updates an action result in action results storage.
func CleanupOldActionResults ¶
CleanupOldActionResults deletes action results older than a specified date.
func CleanupOldJobResults ¶
CleanupOldJobResults deletes jobs results older than a specified date.
func CountChannels ¶
CountChannels returns number of notification channels.
func CountRules ¶
CountRules returns number of alert rules.
func FindBackupLocationsByIDs ¶
func FindBackupLocationsByIDs(q *reform.Querier, ids []string) (map[string]*BackupLocation, error)
FindBackupLocationsByIDs finds backup locations by IDs.
func FindCheckSettings ¶
FindCheckSettings returns all CheckSettings stored in the table.
func FindPMMAgentsIDsWithPushMetrics ¶
FindPMMAgentsIDsWithPushMetrics returns pmm-agents-ids with agent, that use push_metrics mode.
func FindPmmAgentIDToRunActionOrJob ¶
FindPmmAgentIDToRunActionOrJob finds pmm-agent-id to run action.
func FindServicesByIDs ¶
FindServicesByIDs finds Services by IDs.
func IsPushMetricsSupported ¶
IsPushMetricsSupported return if PUSH mode is supported for pmm agent version.
func MergeLabels ¶
MergeLabels merges unified labels of Node, Service, and Agent (each can be nil).
func RemoveArtifact ¶
RemoveArtifact removes artifact by ID.
func RemoveBackupLocation ¶
func RemoveBackupLocation(q *reform.Querier, id string, mode RemoveMode) error
RemoveBackupLocation removes BackupLocation by ID.
func RemoveChannel ¶
RemoveChannel removes notification channel with specified id.
func RemoveKubernetesCluster ¶
RemoveKubernetesCluster removes Kubernetes cluster with provided name.
func RemoveNode ¶
func RemoveNode(q *reform.Querier, id string, mode RemoveMode) error
RemoveNode removes single Node.
func RemoveRule ¶
RemoveRule removes alert Rule with specified id.
func RemoveService ¶
func RemoveService(q *reform.Querier, id string, mode RemoveMode) error
RemoveService removes single Service.
func RemoveTemplate ¶
RemoveTemplate removes rule template with specified name.
func SaveSettings ¶
SaveSettings saves PMM Server settings. It may modify passed settings to fill defaults.
func SetupDB ¶
func SetupDB(sqlDB *sql.DB, params *SetupDBParams) (*reform.DB, error)
SetupDB runs PostgreSQL database migrations and optionally adds initial data.
func ValidateSettings ¶
func ValidateSettings(params *ChangeSettingsParams) error
ValidateSettings validates settings changes.
func VerifyBackupLocationConfig ¶
func VerifyBackupLocationConfig(params *VerifyBackupLocationParams) error
VerifyBackupLocationConfig checks and tests backup location config.
Types ¶
type ActionResult ¶
type ActionResult struct { ID string `reform:"id,pk"` PMMAgentID string `reform:"pmm_agent_id"` Done bool `reform:"done"` Error string `reform:"error"` Output string `reform:"output"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
ActionResult describes an action result which is storing in persistent storage.
func CreateActionResult ¶
func CreateActionResult(q *reform.Querier, pmmAgentID string) (*ActionResult, error)
CreateActionResult stores an action result in action results storage.
func FindActionResultByID ¶
func FindActionResultByID(q *reform.Querier, id string) (*ActionResult, error)
FindActionResultByID finds ActionResult by ID.
func (*ActionResult) AfterFind ¶
func (s *ActionResult) AfterFind() error
AfterFind implements reform.AfterFinder interface.
func (*ActionResult) BeforeInsert ¶
func (s *ActionResult) BeforeInsert() error
BeforeInsert implements reform.BeforeInserter interface.
func (*ActionResult) BeforeUpdate ¶
func (s *ActionResult) BeforeUpdate() error
BeforeUpdate implements reform.BeforeUpdater interface.
func (*ActionResult) HasPK ¶
func (s *ActionResult) HasPK() bool
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*ActionResult) PKPointer ¶
func (s *ActionResult) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*ActionResult) PKValue ¶
func (s *ActionResult) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*ActionResult) Pointers ¶
func (s *ActionResult) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*ActionResult) SetPK
deprecated
func (s *ActionResult) SetPK(pk interface{})
SetPK sets record primary key, if possible.
Deprecated: prefer direct field assignment where possible: s.ID = pk.
func (ActionResult) String ¶
func (s ActionResult) String() string
String returns a string representation of this struct or record.
func (*ActionResult) Table ¶
func (s *ActionResult) Table() reform.Table
Table returns Table object for that record.
func (*ActionResult) Values ¶
func (s *ActionResult) Values() []interface{}
Values returns a slice of struct or record field values. Returned interface{} values are never untyped nils.
func (*ActionResult) View ¶
func (s *ActionResult) View() reform.View
View returns View object for that struct.
type AddDBMSServiceParams ¶
type AddDBMSServiceParams struct { ServiceName string NodeID string Environment string Cluster string ReplicationSet string CustomLabels map[string]string ExternalGroup string Address *string Port *uint16 Socket *string }
AddDBMSServiceParams contains parameters for adding DBMS (MySQL, PostgreSQL, MongoDB, External) Services.
type Agent ¶
type Agent struct { AgentID string `reform:"agent_id,pk"` AgentType AgentType `reform:"agent_type"` RunsOnNodeID *string `reform:"runs_on_node_id"` ServiceID *string `reform:"service_id"` NodeID *string `reform:"node_id"` PMMAgentID *string `reform:"pmm_agent_id"` CustomLabels []byte `reform:"custom_labels"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` Disabled bool `reform:"disabled"` Status string `reform:"status"` ListenPort *uint16 `reform:"listen_port"` Version *string `reform:"version"` Username *string `reform:"username"` Password *string `reform:"password"` TLS bool `reform:"tls"` TLSSkipVerify bool `reform:"tls_skip_verify"` AWSAccessKey *string `reform:"aws_access_key"` AWSSecretKey *string `reform:"aws_secret_key"` AzureOptions *AzureOptions `reform:"azure_options"` // TableCount stores last known table count. NULL if unknown. TableCount *int32 `reform:"table_count"` // Tablestats group collectors are disabled if there are more than that number of tables. // 0 means tablestats group collectors are always enabled (no limit). // Negative value means tablestats group collectors are always disabled. // See IsMySQLTablestatsGroupEnabled method. TableCountTablestatsGroupLimit int32 `reform:"table_count_tablestats_group_limit"` QueryExamplesDisabled bool `reform:"query_examples_disabled"` MaxQueryLogSize int64 `reform:"max_query_log_size"` MetricsPath *string `reform:"metrics_path"` MetricsScheme *string `reform:"metrics_scheme"` RDSBasicMetricsDisabled bool `reform:"rds_basic_metrics_disabled"` RDSEnhancedMetricsDisabled bool `reform:"rds_enhanced_metrics_disabled"` PushMetrics bool `reform:"push_metrics"` DisabledCollectors pq.StringArray `reform:"disabled_collectors"` MongoDBOptions *MongoDBOptions `reform:"mongo_db_tls_options"` }
Agent represents Agent as stored in database.
func ChangeAgent ¶
func ChangeAgent(q *reform.Querier, agentID string, params *ChangeCommonAgentParams) (*Agent, error)
ChangeAgent changes common parameters for given Agent.
func CreateAgent ¶
func CreateAgent(q *reform.Querier, agentType AgentType, params *CreateAgentParams) (*Agent, error)
CreateAgent creates Agent with given type.
func CreateExternalExporter ¶
func CreateExternalExporter(q *reform.Querier, params *CreateExternalExporterParams) (*Agent, error)
CreateExternalExporter creates ExternalExporter.
func CreateNodeExporter ¶
func CreateNodeExporter(q *reform.Querier, pmmAgentID string, customLabels map[string]string, pushMetrics bool, disableCollectors []string) (*Agent, error)
CreateNodeExporter creates NodeExporter.
func CreatePMMAgent ¶
func CreatePMMAgent(q *reform.Querier, runsOnNodeID string, customLabels map[string]string) (*Agent, error)
CreatePMMAgent creates PMMAgent.
func FindAgentByID ¶
FindAgentByID finds Agent by ID.
func FindAgents ¶
func FindAgents(q *reform.Querier, filters AgentFilters) ([]*Agent, error)
FindAgents returns Agents by filters.
func FindAgentsByIDs ¶
FindAgentsByIDs finds Agents by IDs.
func FindAgentsForScrapeConfig ¶
func FindAgentsForScrapeConfig(q *reform.Querier, pmmAgentID *string, pushMetrics bool) ([]*Agent, error)
FindAgentsForScrapeConfig returns Agents for scrape config generation by pmm_agent_id and push_metrics value.
func FindDSNByServiceIDandPMMAgentID ¶
func FindDSNByServiceIDandPMMAgentID(q *reform.Querier, serviceID, pmmAgentID, db string) (string, *Agent, error)
FindDSNByServiceIDandPMMAgentID resolves DSN and Files by service id.
func FindPMMAgentsForService ¶
FindPMMAgentsForService gets pmm-agents for service.
func FindPMMAgentsForServicesOnNode ¶
FindPMMAgentsForServicesOnNode gets pmm-agents for Services running on Node.
func FindPMMAgentsForVersion ¶
func FindPMMAgentsForVersion(logger *logrus.Entry, agents []*Agent, minPMMAgentVersion *version.Parsed) []*Agent
FindPMMAgentsForVersion selects pmm-agents with version >= minPMMAgentVersion.
func FindPMMAgentsRunningOnNode ¶
FindPMMAgentsRunningOnNode gets pmm-agents for node where it runs.
func RemoveAgent ¶
func RemoveAgent(q *reform.Querier, id string, mode RemoveMode) (*Agent, error)
RemoveAgent removes Agent by ID.
func (*Agent) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Agent) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Agent) DSN ¶
func (s *Agent) DSN(service *Service, dialTimeout time.Duration, database string, tdp *DelimiterPair) string
DSN returns DSN string for accessing given Service with this Agent (and implicit driver).
func (*Agent) ExporterURL ¶
ExporterURL composes URL to an external exporter.
func (*Agent) GetCustomLabels ¶
GetCustomLabels decodes custom labels.
func (*Agent) IsMySQLTablestatsGroupEnabled ¶
IsMySQLTablestatsGroupEnabled returns true if mysqld_exporter tablestats group collectors should be enabled.
func (*Agent) PKPointer ¶
func (s *Agent) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Agent) PKValue ¶
func (s *Agent) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Agent) Pointers ¶
func (s *Agent) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Agent) SetCustomLabels ¶
SetCustomLabels encodes custom labels.
func (*Agent) Table ¶
func (s *Agent) Table() reform.Table
Table returns Table object for that record.
func (Agent) TemplateDelimiters ¶
func (s Agent) TemplateDelimiters(svc *Service) *DelimiterPair
TemplateDelimiters returns a pair of safe template delimiters that are not present in agent parameters.
func (*Agent) UnifiedLabels ¶
UnifiedLabels returns combined standard and custom labels with empty labels removed.
type AgentFilters ¶
type AgentFilters struct { // Return only Agents started by this pmm-agent. PMMAgentID string // Return only Agents that provide insights for that Node. NodeID string // Return only Agents that provide insights for that Service. ServiceID string // Return Agents with provided type. AgentType *AgentType }
AgentFilters represents filters for agents list.
type AgentType ¶
type AgentType string
AgentType represents Agent type as stored in databases: pmm-managed's PostgreSQL, qan-api's ClickHouse, and VictoriaMetrics.
const ( PMMAgentType AgentType = "pmm-agent" NodeExporterType AgentType = "node_exporter" MySQLdExporterType AgentType = "mysqld_exporter" MongoDBExporterType AgentType = "mongodb_exporter" PostgresExporterType AgentType = "postgres_exporter" ProxySQLExporterType AgentType = "proxysql_exporter" RDSExporterType AgentType = "rds_exporter" AzureDatabaseExporterType AgentType = "azure_database_exporter" QANMySQLPerfSchemaAgentType AgentType = "qan-mysql-perfschema-agent" QANMySQLSlowlogAgentType AgentType = "qan-mysql-slowlog-agent" QANMongoDBProfilerAgentType AgentType = "qan-mongodb-profiler-agent" QANPostgreSQLPgStatementsAgentType AgentType = "qan-postgresql-pgstatements-agent" QANPostgreSQLPgStatMonitorAgentType AgentType = "qan-postgresql-pgstatmonitor-agent" ExternalExporterType AgentType = "external-exporter" VMAgentType AgentType = "vmagent" )
Agent types (in the same order as in agents.proto).
type Artifact ¶
type Artifact struct { ID string `reform:"id,pk"` Name string `reform:"name"` Vendor string `reform:"vendor"` LocationID string `reform:"location_id"` ServiceID string `reform:"service_id"` DataModel DataModel `reform:"data_model"` Status BackupStatus `reform:"status"` CreatedAt time.Time `reform:"created_at"` }
Artifact represents result of a backup.
func CreateArtifact ¶
func CreateArtifact(q *reform.Querier, params CreateArtifactParams) (*Artifact, error)
CreateArtifact creates artifact entry in DB.
func FindArtifacts ¶
FindArtifacts returns artifacts list.
func (*Artifact) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Artifact) HasPK ¶
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*Artifact) PKPointer ¶
func (s *Artifact) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Artifact) PKValue ¶
func (s *Artifact) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Artifact) Pointers ¶
func (s *Artifact) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Artifact) Table ¶
func (s *Artifact) Table() reform.Table
Table returns Table object for that record.
type AzureOptions ¶
type AzureOptions struct { SubscriptionID string `json:"subscription_id"` ClientID string `json:"client_id"` ClientSecret string `json:"client_secret"` TenantID string `json:"tenant_id"` ResourceGroup string `json:"resource_group"` }
AzureOptions represents structure for special Azure options.
func AzureOptionsFromRequest ¶
func AzureOptionsFromRequest(params AzureOptionsParams) *AzureOptions
AzureOptionsFromRequest creates AzureOptions object from request.
func (*AzureOptions) Scan ¶
func (c *AzureOptions) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type AzureOptionsParams ¶
type AzureOptionsParams interface { GetAzureSubscriptionId() string GetAzureClientId() string GetAzureClientSecret() string GetAzureTenantId() string GetAzureResourceGroup() string }
AzureOptionsParams contains methods to create AzureOptions object.
type BackupLocation ¶
type BackupLocation struct { ID string `reform:"id,pk"` Name string `reform:"name"` Description string `reform:"description"` Type BackupLocationType `reform:"type"` S3Config *S3LocationConfig `reform:"s3_config"` PMMServerConfig *PMMServerLocationConfig `reform:"pmm_server_config"` PMMClientConfig *PMMClientLocationConfig `reform:"pmm_client_config"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
BackupLocation represents destination for backup.
func ChangeBackupLocation ¶
func ChangeBackupLocation(q *reform.Querier, locationID string, params ChangeBackupLocationParams) (*BackupLocation, error)
ChangeBackupLocation updates existing location by specified locationID and params.
func CreateBackupLocation ¶
func CreateBackupLocation(q *reform.Querier, params CreateBackupLocationParams) (*BackupLocation, error)
CreateBackupLocation creates backup location.
func FindBackupLocationByID ¶
func FindBackupLocationByID(q *reform.Querier, id string) (*BackupLocation, error)
FindBackupLocationByID finds a Backup Location by its ID.
func FindBackupLocations ¶
func FindBackupLocations(q *reform.Querier) ([]*BackupLocation, error)
FindBackupLocations returns saved backup locations configuration.
func (*BackupLocation) AfterFind ¶
func (s *BackupLocation) AfterFind() error
AfterFind implements reform.AfterFinder interface.
func (*BackupLocation) BeforeInsert ¶
func (s *BackupLocation) BeforeInsert() error
BeforeInsert implements reform.BeforeInserter interface.
func (*BackupLocation) BeforeUpdate ¶
func (s *BackupLocation) BeforeUpdate() error
BeforeUpdate implements reform.BeforeUpdater interface.
func (*BackupLocation) HasPK ¶
func (s *BackupLocation) HasPK() bool
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*BackupLocation) PKPointer ¶
func (s *BackupLocation) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*BackupLocation) PKValue ¶
func (s *BackupLocation) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*BackupLocation) Pointers ¶
func (s *BackupLocation) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*BackupLocation) SetPK
deprecated
func (s *BackupLocation) SetPK(pk interface{})
SetPK sets record primary key, if possible.
Deprecated: prefer direct field assignment where possible: s.ID = pk.
func (BackupLocation) String ¶
func (s BackupLocation) String() string
String returns a string representation of this struct or record.
func (*BackupLocation) Table ¶
func (s *BackupLocation) Table() reform.Table
Table returns Table object for that record.
func (*BackupLocation) Values ¶
func (s *BackupLocation) Values() []interface{}
Values returns a slice of struct or record field values. Returned interface{} values are never untyped nils.
func (*BackupLocation) View ¶
func (s *BackupLocation) View() reform.View
View returns View object for that struct.
type BackupLocationConfig ¶
type BackupLocationConfig struct { PMMClientConfig *PMMClientLocationConfig PMMServerConfig *PMMServerLocationConfig S3Config *S3LocationConfig }
BackupLocationConfig groups all backup locations configs.
func (BackupLocationConfig) FillLocationConfig ¶
func (c BackupLocationConfig) FillLocationConfig(location *BackupLocation)
FillLocationConfig fills provided location according to backup config.
func (BackupLocationConfig) Validate ¶
func (c BackupLocationConfig) Validate() (bool, error)
Validate checks if there is exactly one config with required fields and returns if config is set.
type BackupLocationType ¶
type BackupLocationType string
BackupLocationType represents BackupLocation type as stored in database.
const ( S3BackupLocationType BackupLocationType = "s3" PMMServerBackupLocationType BackupLocationType = "pmm-server" PMMClientBackupLocationType BackupLocationType = "pmm-client" )
BackupLocation types.
type BackupStatus ¶
type BackupStatus string
BackupStatus shows current status of backup.
const ( PendingBackupStatus BackupStatus = "pending" InProgressBackupStatus BackupStatus = "in_progress" PausedBackupStatus BackupStatus = "paused" SuccessBackupStatus BackupStatus = "success" ErrorBackupStatus BackupStatus = "error" )
BackupStatus status (in the same order as in artifacts.proto).
func (BackupStatus) Validate ¶
func (bs BackupStatus) Validate() error
Validate validates backup status.
type BoolParam ¶
type BoolParam struct {
Default *bool `json:"default,omitempty"`
}
BoolParam represents boolean template parameter.
type ChangeBackupLocationParams ¶
type ChangeBackupLocationParams struct { Name string Description string BackupLocationConfig }
ChangeBackupLocationParams are params for updating existing backup location.
type ChangeChannelParams ¶
type ChangeChannelParams struct { Summary string EmailConfig *EmailConfig PagerDutyConfig *PagerDutyConfig SlackConfig *SlackConfig WebHookConfig *WebHookConfig Disabled bool }
ChangeChannelParams is params for changing existing channel.
type ChangeCommonAgentParams ¶
type ChangeCommonAgentParams struct { Disabled *bool // true - disable, false - enable, nil - do not change CustomLabels map[string]string RemoveCustomLabels bool DisablePushMetrics *bool }
ChangeCommonAgentParams contains parameters that can be changed for all Agents.
type ChangeRuleParams ¶
type ChangeRuleParams struct { Summary string Disabled bool RuleParams RuleParams For time.Duration Severity Severity CustomLabels map[string]string Filters Filters ChannelIDs []string }
ChangeRuleParams is params for updating existing Rule.
type ChangeSettingsParams ¶
type ChangeSettingsParams struct { // We don't save it to db DisableUpdates bool DisableTelemetry bool EnableTelemetry bool MetricsResolutions MetricsResolutions DataRetention time.Duration AWSPartitions []string SSHKey string // not url.URL to keep username and password AlertManagerURL string RemoveAlertManagerURL bool // Enable Security Threat Tool EnableSTT bool // Disable Security Threat Tool DisableSTT bool // List of STT checks to disable DisableSTTChecks []string // List of STT checks to enable EnableSTTChecks []string // STT check intevals STTCheckIntervals STTCheckIntervals // Enable DBaaS features. EnableDBaaS bool // Disable DBaaS features. DisableDBaaS bool // Enable Azure Discover features. EnableAzurediscover bool // Disable Azure Discover features. DisableAzurediscover bool // Enable Integrated Alerting features. EnableAlerting bool // Disable Integrated Alerting features. DisableAlerting bool // Email config for Integrated Alerting. EmailAlertingSettings *EmailAlertingSettings // If true removes email alerting settings. RemoveEmailAlertingSettings bool // Slack config for Integrated Alerting. SlackAlertingSettings *SlackAlertingSettings // If true removes Slack alerting settings. RemoveSlackAlertingSettings bool // Percona Platform user email Email string // Percona Platform session Id SessionID string // LogOut user from Percona Platform, i.e. remove user email and session id LogOut bool // EnableVMCache enables caching for vmdb search queries EnableVMCache bool // DisableVMCache disables caching for vmdb search queries DisableVMCache bool // PMM Server public address. PMMPublicAddress string RemovePMMPublicAddress bool // Enable Backup Management features. EnableBackupManagement bool // Disable Backup Management features. DisableBackupManagement bool }
ChangeSettingsParams contains values to change data in settings table.
type ChangeTemplateParams ¶
ChangeTemplateParams is params for changing existing rule template.
type Channel ¶
type Channel struct { ID string `reform:"id,pk"` Summary string `reform:"summary"` Type ChannelType `reform:"type"` EmailConfig *EmailConfig `reform:"email_config"` PagerDutyConfig *PagerDutyConfig `reform:"pagerduty_config"` SlackConfig *SlackConfig `reform:"slack_config"` WebHookConfig *WebHookConfig `reform:"webhook_config"` Disabled bool `reform:"disabled"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
Channel represents Integrated Alerting Notification Channel configuration.
func ChangeChannel ¶
func ChangeChannel(q *reform.Querier, channelID string, params *ChangeChannelParams) (*Channel, error)
ChangeChannel updates existing notifications channel.
func CreateChannel ¶
func CreateChannel(q *reform.Querier, params *CreateChannelParams) (*Channel, error)
CreateChannel persists notification channel.
func FindChannelByID ¶
FindChannelByID finds Channel by ID.
func FindChannels ¶
FindChannels returns saved notification channels configuration.
func FindChannelsByIDs ¶
FindChannelsByIDs finds channels by IDs.
func FindChannelsOnPage ¶
FindChannelsOnPage returns a page with saved notification channels.
func (*Channel) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Channel) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Channel) PKPointer ¶
func (s *Channel) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Channel) PKValue ¶
func (s *Channel) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Channel) Pointers ¶
func (s *Channel) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Channel) Table ¶
func (s *Channel) Table() reform.Table
Table returns Table object for that record.
type ChannelIDs ¶
type ChannelIDs []string
ChannelIDs is a slice of notification channel ids.
func (*ChannelIDs) Scan ¶
func (t *ChannelIDs) Scan(src interface{}) error
Scan implements database/sql Scanner interface.
type CheckSettings ¶
CheckSettings represents any changes to an STT check loaded in pmm-managed.
func ChangeCheckSettings ¶
func ChangeCheckSettings(q *reform.Querier, name string, interval Interval) (*CheckSettings, error)
ChangeCheckSettings updates the interval of a check setting if already present.
func CreateCheckSettings ¶
func CreateCheckSettings(q *reform.Querier, name string, interval Interval) (*CheckSettings, error)
CreateCheckSettings persists CheckSettings.
func FindCheckSettingsByName ¶
func FindCheckSettingsByName(q *reform.Querier, name string) (*CheckSettings, error)
FindCheckSettingsByName finds CheckSettings by check name.
func (*CheckSettings) HasPK ¶
func (s *CheckSettings) HasPK() bool
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*CheckSettings) PKPointer ¶
func (s *CheckSettings) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*CheckSettings) PKValue ¶
func (s *CheckSettings) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*CheckSettings) Pointers ¶
func (s *CheckSettings) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*CheckSettings) SetPK
deprecated
func (s *CheckSettings) SetPK(pk interface{})
SetPK sets record primary key, if possible.
Deprecated: prefer direct field assignment where possible: s.Name = pk.
func (CheckSettings) String ¶
func (s CheckSettings) String() string
String returns a string representation of this struct or record.
func (*CheckSettings) Table ¶
func (s *CheckSettings) Table() reform.Table
Table returns Table object for that record.
func (*CheckSettings) Values ¶
func (s *CheckSettings) Values() []interface{}
Values returns a slice of struct or record field values. Returned interface{} values are never untyped nils.
func (*CheckSettings) View ¶
func (s *CheckSettings) View() reform.View
View returns View object for that struct.
type CreateAgentParams ¶
type CreateAgentParams struct { PMMAgentID string NodeID string ServiceID string Username string Password string CustomLabels map[string]string TLS bool TLSSkipVerify bool MongoDBOptions *MongoDBOptions TableCountTablestatsGroupLimit int32 QueryExamplesDisabled bool MaxQueryLogSize int64 AWSAccessKey string AWSSecretKey string RDSBasicMetricsDisabled bool RDSEnhancedMetricsDisabled bool AzureOptions *AzureOptions PushMetrics bool DisableCollectors []string }
CreateAgentParams params for add common exporter.
type CreateArtifactParams ¶
type CreateArtifactParams struct { Name string Vendor string LocationID string ServiceID string DataModel DataModel Status BackupStatus }
CreateArtifactParams are params for creating a new artifact.
func (*CreateArtifactParams) Validate ¶
func (p *CreateArtifactParams) Validate() error
Validate validates params used for creating an artifact entry.
type CreateBackupLocationParams ¶
type CreateBackupLocationParams struct { Name string Description string BackupLocationConfig }
CreateBackupLocationParams are params for creating new backup location.
type CreateChannelParams ¶
type CreateChannelParams struct { Summary string EmailConfig *EmailConfig PagerDutyConfig *PagerDutyConfig SlackConfig *SlackConfig WebHookConfig *WebHookConfig Disabled bool }
CreateChannelParams are params for creating new channel.
type CreateExternalExporterParams ¶
type CreateExternalExporterParams struct { RunsOnNodeID string ServiceID string Username string Password string Scheme string MetricsPath string ListenPort uint32 CustomLabels map[string]string PushMetrics bool }
CreateExternalExporterParams params for add external exporter.
type CreateKubernetesClusterParams ¶
CreateKubernetesClusterParams contains all params required to create Kubernetes cluster.
type CreateNodeParams ¶
type CreateNodeParams struct { NodeName string MachineID *string Distro string NodeModel string AZ string ContainerID *string ContainerName *string CustomLabels map[string]string Address string Region *string }
CreateNodeParams contains parameters for creating Nodes.
type CreateRuleParams ¶
type CreateRuleParams struct { TemplateName string Summary string Disabled bool RuleParams RuleParams For time.Duration Severity Severity CustomLabels map[string]string Filters Filters ChannelIDs []string }
CreateRuleParams are params for creating new Rule.
type CreateTemplateParams ¶
CreateTemplateParams are params for creating new rule template.
type DataModel ¶
type DataModel string
DataModel represents a data model used for performing a backup.
DataModel types (in the same order as in artifacts.proto).
type DelimiterPair ¶
DelimiterPair contains a pair of safe template delimiters.
func TemplateDelimsPair ¶
func TemplateDelimsPair(str ...string) DelimiterPair
TemplateDelimsPair returns a pair of safe template delimiters that are not present in any given string.
type EchoJobResult ¶
type EchoJobResult struct {
Message string `json:"message"`
}
EchoJobResult stores echo job specific result data.
type EmailAlertingSettings ¶
type EmailAlertingSettings struct { From string `json:"from"` Smarthost string `json:"smarthost"` Hello string `json:"hello"` Username string `json:"username"` Password string `json:"password"` Identity string `json:"identity"` Secret string `json:"secret"` }
EmailAlertingSettings represents email settings for Integrated Alerting.
type EmailConfig ¶
EmailConfig is email notification channel configuration.
func (*EmailConfig) Scan ¶
func (c *EmailConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type Filter ¶
type Filter struct { Type FilterType `json:"type"` Key string `json:"key"` Val string `json:"value"` }
Filter represents rule filter.
type Filters ¶
type Filters []Filter
Filters represents filters slice.
type FloatParam ¶
type FloatParam struct { Default *float64 `json:"default,omitempty"` Min *float64 `json:"min,omitempty"` Max *float64 `json:"max,omitempty"` }
FloatParam represents float template parameter.
type HTTPBasicAuth ¶
type HTTPBasicAuth struct { Username string `json:"username,omitempty"` Password string `json:"password,omitempty"` PasswordFile string `json:"password_file,omitempty"` }
HTTPBasicAuth is HTTP basic authentication configuration.
type HTTPConfig ¶
type HTTPConfig struct { BasicAuth *HTTPBasicAuth `json:"basic_auth,omitempty"` BearerToken string `json:"bearer_token,omitempty"` BearerTokenFile string `json:"bearer_token_file,omitempty"` TLSConfig *TLSConfig `json:"tls_config,omitempty"` ProxyURL string `json:"proxy_url,omitempty"` }
HTTPConfig is HTTP connection configuration.
type JobResult ¶
type JobResult struct { ID string `reform:"id,pk"` PMMAgentID string `reform:"pmm_agent_id"` Type JobType `reform:"type"` Done bool `reform:"done"` Error string `reform:"error"` Result *JobResultData `reform:"result"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
JobResult describes a job result which is storing in persistent storage.
func CreateJobResult ¶
CreateJobResult stores a job result in the storage.
func FindJobResultByID ¶
FindJobResultByID finds JobResult by ID.
func (*JobResult) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*JobResult) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*JobResult) HasPK ¶
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*JobResult) PKPointer ¶
func (s *JobResult) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*JobResult) PKValue ¶
func (s *JobResult) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*JobResult) Pointers ¶
func (s *JobResult) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*JobResult) Table ¶
func (s *JobResult) Table() reform.Table
Table returns Table object for that record.
type JobResultData ¶
type JobResultData struct {
Echo *EchoJobResult `json:"echo,omitempty"`
}
JobResultData holds result data for different job types.
func (*JobResultData) Scan ¶
func (c *JobResultData) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type KubernetesCluster ¶
type KubernetesCluster struct { ID string `reform:"id,pk"` KubernetesClusterName string `reform:"kubernetes_cluster_name"` KubeConfig string `reform:"kube_config"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
KubernetesCluster represents a Kubernetes cluster as stored in database.
func CreateKubernetesCluster ¶
func CreateKubernetesCluster(q *reform.Querier, params *CreateKubernetesClusterParams) (*KubernetesCluster, error)
CreateKubernetesCluster creates Kubernetes cluster with provided params.
func FindAllKubernetesClusters ¶
func FindAllKubernetesClusters(q *reform.Querier) ([]*KubernetesCluster, error)
FindAllKubernetesClusters returns all Kubernetes clusters.
func FindKubernetesClusterByName ¶
func FindKubernetesClusterByName(q *reform.Querier, name string) (*KubernetesCluster, error)
FindKubernetesClusterByName finds a Kubernetes cluster with provided name.
func (*KubernetesCluster) AfterFind ¶
func (s *KubernetesCluster) AfterFind() error
AfterFind implements reform.AfterFinder interface.
func (*KubernetesCluster) BeforeInsert ¶
func (s *KubernetesCluster) BeforeInsert() error
BeforeInsert implements reform.BeforeInserter interface.
func (*KubernetesCluster) BeforeUpdate ¶
func (s *KubernetesCluster) BeforeUpdate() error
BeforeUpdate implements reform.BeforeUpdater interface.
func (*KubernetesCluster) HasPK ¶
func (s *KubernetesCluster) HasPK() bool
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*KubernetesCluster) PKPointer ¶
func (s *KubernetesCluster) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*KubernetesCluster) PKValue ¶
func (s *KubernetesCluster) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*KubernetesCluster) Pointers ¶
func (s *KubernetesCluster) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*KubernetesCluster) SetPK
deprecated
func (s *KubernetesCluster) SetPK(pk interface{})
SetPK sets record primary key, if possible.
Deprecated: prefer direct field assignment where possible: s.ID = pk.
func (KubernetesCluster) String ¶
func (s KubernetesCluster) String() string
String returns a string representation of this struct or record.
func (*KubernetesCluster) Table ¶
func (s *KubernetesCluster) Table() reform.Table
Table returns Table object for that record.
func (*KubernetesCluster) Values ¶
func (s *KubernetesCluster) Values() []interface{}
Values returns a slice of struct or record field values. Returned interface{} values are never untyped nils.
func (*KubernetesCluster) View ¶
func (s *KubernetesCluster) View() reform.View
View returns View object for that struct.
type MetricsResolutions ¶
type MetricsResolutions struct { HR time.Duration `json:"hr"` MR time.Duration `json:"mr"` LR time.Duration `json:"lr"` }
MetricsResolutions contains standard VictoriaMetrics metrics resolutions.
type MongoDBOptions ¶
type MongoDBOptions struct { TLSCertificateKey string `json:"tls_certificate_key"` TLSCertificateKeyFilePassword string `json:"tls_certificate_key_file_password"` TLSCa string `json:"tls_ca"` }
MongoDBOptions represents structure for special MongoDB options.
func MongoDBOptionsFromRequest ¶
func MongoDBOptionsFromRequest(params MongoDBOptionsParams) *MongoDBOptions
MongoDBOptionsFromRequest creates MongoDBOptionsParams object from request.
func (*MongoDBOptions) Scan ¶
func (c *MongoDBOptions) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type MongoDBOptionsParams ¶
type MongoDBOptionsParams interface { GetTlsCertificateKey() string GetTlsCertificateKeyFilePassword() string GetTlsCa() string }
MongoDBOptionsParams contains methods to create MongoDBOptions object.
type Node ¶
type Node struct { NodeID string `reform:"node_id,pk"` NodeType NodeType `reform:"node_type"` NodeName string `reform:"node_name"` MachineID *string `reform:"machine_id"` Distro string `reform:"distro"` NodeModel string `reform:"node_model"` AZ string `reform:"az"` CustomLabels []byte `reform:"custom_labels"` // Node address. Used to construct endpoint for node_exporter. // For RemoteRDS Nodes contains DBInstanceIdentifier (not DbiResourceId; not endpoint - that's Service address). Address string `reform:"address"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` ContainerID *string `reform:"container_id"` // nil means "unknown"; non-nil value must be unique ContainerName *string `reform:"container_name"` Region *string `reform:"region"` // non-nil value must be unique in combination with instance/address }
Node represents Node as stored in database.
func CheckUniqueNodeInstanceRegion ¶
func CheckUniqueNodeInstanceRegion(q *reform.Querier, instance string, region *string) (*Node, error)
CheckUniqueNodeInstanceRegion checks for uniqueness of instance address and region. This function not only return an error in case of finding an existing node with those paramenters but also returns the Node itself if there is any, because if we are recreating the instance (--force in pmm-admin) we need to know the Node.ID to remove it and its dependencies. This check only applies is region is not empty.
func CreateNode ¶
func CreateNode(q *reform.Querier, nodeType NodeType, params *CreateNodeParams) (*Node, error)
CreateNode creates a Node.
func FindNodeByID ¶
FindNodeByID finds a Node by ID.
func FindNodeByName ¶
FindNodeByName finds a Node by name.
func FindNodes ¶
func FindNodes(q *reform.Querier, filters NodeFilters) ([]*Node, error)
FindNodes returns Nodes by filters.
func FindNodesByIDs ¶
FindNodesByIDs finds Nodes by IDs.
func (*Node) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Node) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Node) GetCustomLabels ¶
GetCustomLabels decodes custom labels.
func (*Node) PKPointer ¶
func (s *Node) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Node) PKValue ¶
func (s *Node) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Node) Pointers ¶
func (s *Node) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Node) SetCustomLabels ¶
SetCustomLabels encodes custom labels.
func (*Node) Table ¶
func (s *Node) Table() reform.Table
Table returns Table object for that record.
func (*Node) UnifiedLabels ¶
UnifiedLabels returns combined standard and custom labels with empty labels removed.
type NodeFilters ¶
type NodeFilters struct { // Return Nodes with provided type. NodeType *NodeType }
NodeFilters represents filters for nodes list.
type NodeType ¶
type NodeType string
NodeType represents Node type as stored in databases: pmm-managed's PostgreSQL, qan-api's ClickHouse, and VictoriaMetrics.
type PMMClientLocationConfig ¶
type PMMClientLocationConfig struct {
Path string `json:"path"`
}
PMMClientLocationConfig contains require properties for accessing file system on pmm-client-node.
func (*PMMClientLocationConfig) Scan ¶
func (c *PMMClientLocationConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type PMMServerLocationConfig ¶
type PMMServerLocationConfig struct {
Path string `json:"path"`
}
PMMServerLocationConfig contains require properties for accessing file system on pmm-server-node.
func (*PMMServerLocationConfig) Scan ¶
func (c *PMMServerLocationConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type PagerDutyConfig ¶
type PagerDutyConfig struct { SendResolved bool `json:"send_resolved"` RoutingKey string `json:"routing_key,omitempty"` ServiceKey string `json:"service_key,omitempty"` }
PagerDutyConfig represents PagerDuty channel configuration.
func (*PagerDutyConfig) Scan ¶
func (c *PagerDutyConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type RemoveMode ¶
type RemoveMode int
RemoveMode defines how Remove functions deal with dependend objects.
const ( // RemoveRestrict returns error if there dependend objects. RemoveRestrict RemoveMode = iota // RemoveCascade removes dependend objects recursively. RemoveCascade )
type Rule ¶
type Rule struct { TemplateName string `reform:"template_name"` ID string `reform:"id,pk"` Summary string `reform:"summary"` Disabled bool `reform:"disabled"` Params RuleParams `reform:"params"` For time.Duration `reform:"for"` Severity Severity `reform:"severity"` CustomLabels []byte `reform:"custom_labels"` Filters Filters `reform:"filters"` ChannelIDs ChannelIDs `reform:"channel_ids"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
Rule represents alert rule configuration.
func ChangeRule ¶
func ChangeRule(q *reform.Querier, ruleID string, params *ChangeRuleParams) (*Rule, error)
ChangeRule updates existing alerts Rule.
func CreateRule ¶
func CreateRule(q *reform.Querier, params *CreateRuleParams) (*Rule, error)
CreateRule persists alert Rule.
func FindRuleByID ¶
FindRuleByID finds Rule by ID.
func FindRulesOnPage ¶
FindRulesOnPage returns a page with saved alert rules configuration.
func ToggleRule ¶
func ToggleRule(q *reform.Querier, ruleID string, params *ToggleRuleParams) (*Rule, error)
ToggleRule updates some alert rule fields.
func (*Rule) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Rule) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Rule) GetCustomLabels ¶
GetCustomLabels decodes template labels.
func (*Rule) PKPointer ¶
func (s *Rule) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Rule) PKValue ¶
func (s *Rule) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Rule) Pointers ¶
func (s *Rule) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Rule) SetCustomLabels ¶
SetCustomLabels encodes template labels.
func (*Rule) Table ¶
func (s *Rule) Table() reform.Table
Table returns Table object for that record.
type RuleParam ¶
type RuleParam struct { Name string `json:"name"` Type ParamType `json:"type"` BoolValue bool `json:"bool"` FloatValue float32 `json:"float"` StringValue string `json:"string"` }
RuleParam represents rule parameter.
type RuleParams ¶
type RuleParams []RuleParam
RuleParams represents rule parameters slice.
func (*RuleParams) Scan ¶
func (t *RuleParams) Scan(src interface{}) error
Scan implements database/sql Scanner interface.
type S3LocationConfig ¶
type S3LocationConfig struct { Endpoint string `json:"endpoint"` AccessKey string `json:"access_key"` SecretKey string `json:"secret_key"` BucketName string `json:"bucket_name"` }
S3LocationConfig contains required properties for accessing S3 Bucket.
func (*S3LocationConfig) Scan ¶
func (c *S3LocationConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type STTCheckIntervals ¶
type STTCheckIntervals struct { StandardInterval time.Duration `json:"standard_interval"` RareInterval time.Duration `json:"rare_interval"` FrequentInterval time.Duration `json:"frequent_interval"` }
STTCheckIntervals represents intervals between STT checks.
type SaaS ¶
type SaaS struct { // Percona Platform user email Email string `json:"email"` // Percona Platform session Id SessionID string `json:"session_id"` // Security Threat Tool enabled STTEnabled bool `json:"stt_enabled"` // List of disabled STT checks DisabledSTTChecks []string `json:"disabled_stt_checks"` // STT check intervals STTCheckIntervals STTCheckIntervals `json:"stt_check_intervals"` }
SaaS contains settings related to the SaaS platform.
type Service ¶
type Service struct { ServiceID string `reform:"service_id,pk"` ServiceType ServiceType `reform:"service_type"` ServiceName string `reform:"service_name"` NodeID string `reform:"node_id"` Environment string `reform:"environment"` Cluster string `reform:"cluster"` ReplicationSet string `reform:"replication_set"` CustomLabels []byte `reform:"custom_labels"` ExternalGroup string `reform:"external_group"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` Address *string `reform:"address"` Port *uint16 `reform:"port"` Socket *string `reform:"socket"` }
Service represents Service as stored in database.
func AddNewService ¶
func AddNewService(q *reform.Querier, serviceType ServiceType, params *AddDBMSServiceParams) (*Service, error)
AddNewService adds new service to storage.
func FindServiceByID ¶
FindServiceByID finds Service by ID.
func FindServiceByName ¶
FindServiceByName finds Service by Name.
func FindServices ¶
func FindServices(q *reform.Querier, filters ServiceFilters) ([]*Service, error)
FindServices returns Services by filters.
func (*Service) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Service) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Service) GetCustomLabels ¶
GetCustomLabels decodes custom labels.
func (*Service) PKPointer ¶
func (s *Service) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Service) PKValue ¶
func (s *Service) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Service) Pointers ¶
func (s *Service) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Service) SetCustomLabels ¶
SetCustomLabels encodes custom labels.
func (*Service) Table ¶
func (s *Service) Table() reform.Table
Table returns Table object for that record.
func (*Service) UnifiedLabels ¶
UnifiedLabels returns combined standard and custom labels with empty labels removed.
type ServiceFilters ¶
type ServiceFilters struct { // Return only Services runs on that Node. NodeID string // Return only Services with provided type. ServiceType *ServiceType // Return only Services with given external group. ExternalGroup string }
ServiceFilters represents filters for services list.
type ServiceType ¶
type ServiceType string
ServiceType represents Service type as stored in databases: pmm-managed's PostgreSQL, qan-api's ClickHouse, and VictoriaMetrics.
const ( MySQLServiceType ServiceType = "mysql" MongoDBServiceType ServiceType = "mongodb" PostgreSQLServiceType ServiceType = "postgresql" ProxySQLServiceType ServiceType = "proxysql" HAProxyServiceType ServiceType = "haproxy" ExternalServiceType ServiceType = "external" )
Service types (in the same order as in services.proto).
type Settings ¶
type Settings struct { PMMPublicAddress string `json:"pmm_public_address"` Telemetry struct { Disabled bool `json:"disabled"` UUID string `json:"uuid"` } `json:"telemetry"` MetricsResolutions MetricsResolutions `json:"metrics_resolutions"` DataRetention time.Duration `json:"data_retention"` AWSPartitions []string `json:"aws_partitions"` AWSInstanceChecked bool `json:"aws_instance_checked"` SSHKey string `json:"ssh_key"` // not url.URL to keep username and password AlertManagerURL string `json:"alert_manager_url"` VictoriaMetrics struct { CacheEnabled bool `json:"cache_enabled"` } `json:"victoria_metrics"` SaaS SaaS `json:"sass"` // sic :( // DBaaS config options DBaaS struct { Enabled bool `json:"enabled"` } `json:"dbaas"` IntegratedAlerting struct { Enabled bool `json:"enabled"` EmailAlertingSettings *EmailAlertingSettings `json:"email_settings"` SlackAlertingSettings *SlackAlertingSettings `json:"slack_settings"` } `json:"ia"` Azurediscover struct { Enabled bool `json:"enabled"` } `json:"azure"` BackupManagement struct { Enabled bool `json:"enabled"` } `json:"backup_management"` }
Settings contains PMM Server settings.
func GetSettings ¶
GetSettings returns current PMM Server settings.
func UpdateSettings ¶
func UpdateSettings(q reform.DBTX, params *ChangeSettingsParams) (*Settings, error)
UpdateSettings updates only non-zero, non-empty values.
type SetupDBParams ¶
type SetupDBParams struct { Logf reform.Printf Username string Password string SetupFixtures SetupFixturesMode MigrationVersion *int }
SetupDBParams represents SetupDB parameters.
type SetupFixturesMode ¶
type SetupFixturesMode int
SetupFixturesMode defines if SetupDB adds initial data to the database or not.
const ( // SetupFixtures adds initial data to the database. SetupFixtures SetupFixturesMode = iota // SkipFixtures skips adding initial data to the database. Useful for tests. SkipFixtures )
type Severity ¶
Severity represents alert severity. Integer values is the same as common.Severity. Common constants can be used. Database representation is a string and is handled by Value and Scan methods below.
type SlackAlertingSettings ¶
type SlackAlertingSettings struct {
URL string `json:"url"`
}
SlackAlertingSettings represents Slack settings for Integrated Alerting.
type SlackConfig ¶
type SlackConfig struct { SendResolved bool `json:"send_resolved"` Channel string `json:"channel"` }
SlackConfig is slack notification channel configuration.
func (*SlackConfig) Scan ¶
func (c *SlackConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type StringParam ¶
type StringParam struct {
Default *string `json:"default,omitempty"`
}
StringParam represents string template parameter.
type TLSConfig ¶
type TLSConfig struct { CaFile string `json:"ca_file,omitempty"` CertFile string `json:"cert_file,omitempty"` KeyFile string `json:"key_file,omitempty"` ServerName string `json:"server_name,omitempty"` InsecureSkipVerify bool `json:"insecure_skip_verify,omitempty"` }
TLSConfig is TLS configuration.
type Template ¶
type Template struct { Name string `reform:"name,pk"` Version uint32 `reform:"version"` Summary string `reform:"summary"` Tiers Tiers `reform:"tiers"` Expr string `reform:"expr"` Params TemplateParams `reform:"params"` For time.Duration `reform:"for"` Severity Severity `reform:"severity"` Labels []byte `reform:"labels"` Annotations []byte `reform:"annotations"` Source Source `reform:"source"` Yaml string `reform:"yaml"` CreatedAt time.Time `reform:"created_at"` UpdatedAt time.Time `reform:"updated_at"` }
Template represents Integrated Alerting rule template.
func ChangeTemplate ¶
func ChangeTemplate(q *reform.Querier, params *ChangeTemplateParams) (*Template, error)
ChangeTemplate updates existing rule template.
func CreateTemplate ¶
func CreateTemplate(q *reform.Querier, params *CreateTemplateParams) (*Template, error)
CreateTemplate creates rule template.
func FindTemplateByName ¶
FindTemplateByName finds template by name.
func FindTemplates ¶
FindTemplates returns saved notification rule templates.
func (*Template) BeforeInsert ¶
BeforeInsert implements reform.BeforeInserter interface.
func (*Template) BeforeUpdate ¶
BeforeUpdate implements reform.BeforeUpdater interface.
func (*Template) GetAnnotations ¶
GetAnnotations decodes template annotations.
func (*Template) HasPK ¶
HasPK returns true if record has non-zero primary key set, false otherwise.
func (*Template) PKPointer ¶
func (s *Template) PKPointer() interface{}
PKPointer returns a pointer to primary key field for that record. Returned interface{} value is never untyped nil.
func (*Template) PKValue ¶
func (s *Template) PKValue() interface{}
PKValue returns a value of primary key for that record. Returned interface{} value is never untyped nil.
func (*Template) Pointers ¶
func (s *Template) Pointers() []interface{}
Pointers returns a slice of pointers to struct or record fields. Returned interface{} values are never untyped nils.
func (*Template) SetAnnotations ¶
SetAnnotations encodes template annotations.
func (*Template) Table ¶
func (s *Template) Table() reform.Table
Table returns Table object for that record.
type TemplateParam ¶
type TemplateParam struct { Name string `json:"name"` Summary string `json:"summary"` Unit string `json:"unit"` Type ParamType `json:"type"` FloatParam *FloatParam `json:"float_param"` }
TemplateParam represents template parameter.
type TemplateParams ¶
type TemplateParams []TemplateParam
TemplateParams represent TemplateParam slice.
func (*TemplateParams) Scan ¶
func (p *TemplateParams) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
type Tiers ¶
Tiers represents tiers slice.
type ToggleRuleParams ¶
type ToggleRuleParams struct {
Disabled *bool // nil - do not change
}
ToggleRuleParams represents rule toggle parameters.
type VerifyBackupLocationParams ¶
type VerifyBackupLocationParams struct {
BackupLocationConfig
}
VerifyBackupLocationParams are params for verifying location and credentials.
type VictoriaMetricsParams ¶
type VictoriaMetricsParams struct { // VMAlertFlags additional flags for VMAlert. VMAlertFlags []string // BaseConfigPath defines path for basic prometheus config. BaseConfigPath string }
VictoriaMetricsParams - defines flags and settings for victoriametrics.
func NewVictoriaMetricsParams ¶
func NewVictoriaMetricsParams(basePath string) (*VictoriaMetricsParams, error)
NewVictoriaMetricsParams - returns configuration params for VictoriaMetrics.
func (*VictoriaMetricsParams) UpdateParams ¶
func (vmp *VictoriaMetricsParams) UpdateParams() error
UpdateParams - reads configuration file and updates corresponding flags.
type WebHookConfig ¶
type WebHookConfig struct { SendResolved bool ` json:"send_resolved"` URL string ` json:"url"` HTTPConfig *HTTPConfig ` json:"http_config,omitempty"` MaxAlerts int32 ` json:"max_alerts"` }
WebHookConfig is webhook notification channel configuration.
func (*WebHookConfig) Scan ¶
func (c *WebHookConfig) Scan(src interface{}) error
Scan implements database/sql.Scanner interface. Should be defined on the pointer.
Source Files ¶
- action_helpers.go
- action_models.go
- action_models_reform.go
- agent_helpers.go
- agent_model.go
- agent_model_reform.go
- artifact_helpers.go
- artifact_model.go
- artifact_model_reform.go
- channel.go
- channel_helpers.go
- channel_reform.go
- check_settings_helper.go
- check_settings_model.go
- check_settings_model_reform.go
- database.go
- delimiter.go
- dsn_helpers.go
- job_helpers.go
- job_models.go
- job_models_reform.go
- kubernetes_helpers.go
- kubernetes_models.go
- kubernetes_models_reform.go
- location_helpers.go
- location_model.go
- location_model_reform.go
- models.go
- node_helpers.go
- node_model.go
- node_model_reform.go
- rule_helpers.go
- rule_model.go
- rule_model_reform.go
- service_helpers.go
- service_model.go
- service_model_reform.go
- settings.go
- settings_helpers.go
- template_helpers.go
- template_model.go
- template_model_reform.go
- victoriametrics.go