Documentation ¶
Overview ¶
Package graylog provides Golang's structs which represents Graylog resource such as roles and users. Client and mock server and terraform provider are provided as subpackages.
https://godoc.org/github.com/suzuki-shunsuke/go-graylog/#pkg-subdirectories
Index ¶
- Constants
- Variables
- func SetFuncGetInputAttrsByType(f GetInputAttrsByTypeIntf)
- func SetFuncGetUnknownTypeInputAttrs(f GetUnknownTypeInputAttrsIntf)
- func SetInputAttrs(args ...NewInputAttrs) error
- type AlarmCallback
- type AlarmCallbackConfiguration
- type AlarmCallbacksBody
- type Alert
- type AlertCondition
- type AlertConditionParameters
- type AlertConditionsBody
- type AlertReceivers
- type AlertsBody
- type CollectorConfiguration
- type CollectorConfigurationInput
- type CollectorConfigurationInputFileProperty
- type CollectorConfigurationInputProperty
- type CollectorConfigurationInputWindowsEventLogProperty
- type CollectorConfigurationOutput
- type CollectorConfigurationOutputProperty
- type CollectorConfigurationSnippet
- type CollectorConfigurationsBody
- type Dashboard
- type DashboardWidgetPosition
- type DashboardsBody
- type EmailAlarmCallbackConfiguration
- type EventDefinition
- type EventDefinitionConfigConditions
- type EventDefinitionConfigConditionsExpression
- type EventDefinitionConfigConditionsExpressionLeft
- type EventDefinitionConfigConditionsExpressionRight
- type EventDefinitionConfigSeries
- type EventDefinitionFieldSpec
- type EventDefinitionNotification
- type EventDefinitionNotificationSettings
- type EventDefinitionsBody
- type EventNotification
- type EventNotificationsBody
- type Extractor
- type ExtractorConverter
- type ExtractorConverterConfig
- type ExtractorMetric
- type ExtractorMetricRate
- type ExtractorMetricTime
- type ExtractorMetrics
- type ExtractorTypeGrokConfig
- type ExtractorTypeJSONConfig
- type ExtractorTypeRegexConfig
- type ExtractorsBody
- type FieldAggregationAlertConditionParameters
- type FieldContentAlertConditionParameters
- type GeneralAlarmCallbackConfiguration
- type GeneralAlertConditionParameters
- type GetInputAttrsByTypeIntf
- type GetUnknownTypeInputAttrsIntf
- type GrokPattern
- type GrokPatternsBody
- type HTTPAlarmCallbackConfiguration
- type IndexSet
- type IndexSetStats
- type IndexSetUpdateParams
- type IndexSetsBody
- type Input
- type InputAWSCloudTrailAttrs
- type InputAWSCloudWatchLogsAttrs
- type InputAWSFlowLogsAttrs
- type InputAttrs
- func NewInputAWSCloudTrailAttrs() InputAttrs
- func NewInputAWSCloudWatchLogsAttrs() InputAttrs
- func NewInputAWSFlowLogsAttrs() InputAttrs
- func NewInputAttrsByType(t string) InputAttrs
- func NewInputBeatsAttrs() InputAttrs
- func NewInputCEFAMQPAttrs() InputAttrs
- func NewInputCEFKafkaAttrs() InputAttrs
- func NewInputCEFTCPAttrs() InputAttrs
- func NewInputCEFUDPAttrs() InputAttrs
- func NewInputFakeHTTPMessageAttrs() InputAttrs
- func NewInputGELFAMQPAttrs() InputAttrs
- func NewInputGELFHTTPAttrs() InputAttrs
- func NewInputGELFKafkaAttrs() InputAttrs
- func NewInputGELFTCPAttrs() InputAttrs
- func NewInputGELFUDPAttrs() InputAttrs
- func NewInputJSONPathAttrs() InputAttrs
- func NewInputNetFlowUDPAttrs() InputAttrs
- func NewInputRawAMQPAttrs() InputAttrs
- func NewInputRawKafkaAttrs() InputAttrs
- func NewInputSyslogAMQPAttrs() InputAttrs
- func NewInputSyslogKafkaAttrs() InputAttrs
- func NewInputSyslogTCPAttrs() InputAttrs
- func NewInputSyslogUDPAttrs() InputAttrs
- type InputBeatsAttrs
- type InputCEFAMQPAttrs
- type InputCEFKafkaAttrs
- type InputCEFTCPAttrs
- type InputCEFUDPAttrs
- type InputData
- type InputFakeHTTPMessageAttrs
- type InputGELFAMQPAttrs
- type InputGELFHTTPAttrs
- type InputGELFKafkaAttrs
- type InputGELFTCPAttrs
- type InputGELFUDPAttrs
- type InputJSONPathAttrs
- type InputNetFlowUDPAttrs
- type InputRawAMQPAttrs
- type InputRawKafkaAttrs
- type InputSyslogAMQPAttrs
- type InputSyslogKafkaAttrs
- type InputSyslogTCPAttrs
- type InputSyslogUDPAttrs
- type InputUnknownAttrs
- type InputUpdateParams
- type InputUpdateParamsData
- type InputsBody
- type LDAPSetting
- type MessageCountAlertConditionParameters
- type NewInputAttrs
- type Output
- type OutputsBody
- type Pipeline
- type PipelineConnection
- type PipelineRule
- type PipelineStage
- type Preferences
- type RetentionStrategy
- type Role
- type RoleUpdateParams
- type RolesBody
- type RotationStrategy
- type SlackAlarmCallbackConfiguration
- type Startpage
- type Stream
- type StreamRule
- type StreamRuleType
- type StreamRuleUpdateParams
- type StreamRulesBody
- type StreamUpdateParams
- type StreamsBody
- type Timerange
- type User
- type UserUpdateParams
- type UsersBody
- type Widget
- type WidgetConfig
- type WidgetConfigFieldChart
- type WidgetConfigQuickValues
- type WidgetConfigQuickValuesHistogram
- type WidgetConfigSearchResultChart
- type WidgetConfigStatsCount
- type WidgetConfigStreamSearchResultCount
- type WidgetConfigUnknownType
Constants ¶
const ( // EmailAlarmCallbackType is a type of EmailAlarmCallback. EmailAlarmCallbackType = "org.graylog2.alarmcallbacks.EmailAlarmCallback" // HTTPAlarmCallbackType is a type of HTTPAlarmCallback. HTTPAlarmCallbackType = "org.graylog2.alarmcallbacks.HTTPAlarmCallback" // SlackAlarmCallbackType is a type of SlackAlarmCallback. SlackAlarmCallbackType = "org.graylog2.plugins.slack.callback.SlackAlarmCallback" )
const ( // MessageCountRotationStrategy is one of index set's rotation strategies. MessageCountRotationStrategy string = "org.graylog2.indexer.rotation.strategies.MessageCountRotationStrategy" // SizeBasedRotationStrategy is one of index set's rotation strategies. SizeBasedRotationStrategy string = "org.graylog2.indexer.rotation.strategies.SizeBasedRotationStrategy" // TimeBasedRotationStrategy is one of index set's rotation strategies. TimeBasedRotationStrategy string = "org.graylog2.indexer.rotation.strategies.TimeBasedRotationStrategy" // MessageCountRotationStrategyConfig is one of index set's rotation strategy configs. MessageCountRotationStrategyConfig string = "org.graylog2.indexer.rotation.strategies.MessageCountRotationStrategyConfig" // SizeBasedRotationStrategyConfig is one of index set's rotation strategy configs. SizeBasedRotationStrategyConfig string = "org.graylog2.indexer.rotation.strategies.SizeBasedRotationStrategyConfig" // TimeBasedRotationStrategyConfig is one of index set's rotation strategy configs. TimeBasedRotationStrategyConfig string = "org.graylog2.indexer.rotation.strategies.TimeBasedRotationStrategyConfig" // DeletionRetentionStrategy is one of index set's retention strategies. DeletionRetentionStrategy string = "org.graylog2.indexer.retention.strategies.DeletionRetentionStrategy" // ClosingRetentionStrategy is one of index set's retention strategies. ClosingRetentionStrategy string = "org.graylog2.indexer.retention.strategies.ClosingRetentionStrategy" // NoopRetentionStrategy is one of index set's retention strategies. NoopRetentionStrategy string = "org.graylog2.indexer.retention.strategies.NoopRetentionStrategy" // DeletionRetentionStrategyConfig is one of index set's retention strategy configs. DeletionRetentionStrategyConfig string = "org.graylog2.indexer.retention.strategies.DeletionRetentionStrategyConfig" // ClosingRetentionStrategyConfig is one of index set's retention strategy configs. ClosingRetentionStrategyConfig string = "org.graylog2.indexer.retention.strategies.ClosingRetentionStrategyConfig" // NoopRetentionStrategyConfig is one of index set's retention strategy configs. NoopRetentionStrategyConfig string = "org.graylog2.indexer.retention.strategies.NoopRetentionStrategyConfig" // CreationDateFormat is the date format used at graylog API's request and response body. CreationDateFormat string = "2006-01-02T15:04:05.000Z" )
const ( // InputTypeAWSCloudTrail is one of input types. InputTypeAWSCloudTrail string = "org.graylog.aws.inputs.cloudtrail.CloudTrailInput" )
const ( // InputTypeAWSCloudWatchLogs is one of input types. InputTypeAWSCloudWatchLogs string = "org.graylog.aws.inputs.cloudwatch.CloudWatchLogsInput" )
const ( // InputTypeAWSFlowLogs is one of input types. InputTypeAWSFlowLogs string = "org.graylog.aws.inputs.flowlogs.FlowLogsInput" )
const ( // InputTypeBeats is one of input types. InputTypeBeats string = "org.graylog.plugins.beats.BeatsInput" )
const ( // InputTypeCEFAMQP is one of input types. InputTypeCEFAMQP string = "org.graylog.plugins.cef.input.CEFAmqpInput" )
const ( // InputTypeCEFKafka is one of input types. InputTypeCEFKafka string = "org.graylog.plugins.cef.input.CEFKafkaInput" )
const ( // InputTypeCEFTCP is one of input types. InputTypeCEFTCP string = "org.graylog.plugins.cef.input.CEFTCPInput" )
const ( // InputTypeCEFUDP is one of input types. InputTypeCEFUDP string = "org.graylog.plugins.cef.input.CEFUDPInput" )
const ( // InputTypeFakeHTTPMessage is one of input types. InputTypeFakeHTTPMessage string = "org.graylog2.inputs.random.FakeHttpMessageInput" )
const ( // InputTypeGELFAMQP is one of input types. InputTypeGELFAMQP string = "org.graylog2.inputs.gelf.amqp.GELFAMQPInput" )
const ( // InputTypeGELFHTTP is one of input types. InputTypeGELFHTTP string = "org.graylog2.inputs.gelf.http.GELFHttpInput" )
const ( // InputTypeGELFKafka is one of input types. InputTypeGELFKafka string = "org.graylog2.inputs.gelf.kafka.GELFKafkaInput" )
const ( // InputTypeGELFTCP is one of input types. InputTypeGELFTCP string = "org.graylog2.inputs.gelf.tcp.GELFTCPInput" )
const ( // InputTypeGELFUDP is one of input types. InputTypeGELFUDP string = "org.graylog2.inputs.gelf.udp.GELFUDPInput" )
const ( // InputTypeJSONPath is one of input types. InputTypeJSONPath string = "org.graylog2.inputs.misc.jsonpath.JsonPathInput" )
const ( // InputTypeNetFlowUDP is one of input types. InputTypeNetFlowUDP string = "org.graylog.plugins.netflow.inputs.NetFlowUdpInput" )
const ( // InputTypeRawAMQP is one of input types. InputTypeRawAMQP string = "org.graylog2.inputs.raw.amqp.RawAMQPInput" )
const ( // InputTypeRawKafka is one of input types. InputTypeRawKafka string = "org.graylog2.inputs.raw.kafka.RawKafkaInput" )
const ( // InputTypeSyslogAMQP is one of input types. InputTypeSyslogAMQP string = "org.graylog2.inputs.syslog.amqp.SyslogAMQPInput" )
const ( // InputTypeSyslogKafka is one of input types. InputTypeSyslogKafka string = "org.graylog2.inputs.syslog.kafka.SyslogKafkaInput" )
const ( // InputTypeSyslogTCP is one of input types. InputTypeSyslogTCP string = "org.graylog2.inputs.syslog.tcp.SyslogTCPInput" )
const ( // InputTypeSyslogUDP is one of input types. InputTypeSyslogUDP string = "org.graylog2.inputs.syslog.udp.SyslogUDPInput" )
const Version = "8.5.4"
Version is the go-graylog's version.
Variables ¶
var ( // InputAttrsIntFieldSet is the set of int fields of all type of input attributes. InputAttrsIntFieldSet = set.NewStrSet() // InputAttrsBoolFieldSet is the set of bool fields of all type of input attributes. InputAttrsBoolFieldSet = set.NewStrSet() // InputAttrsStrFieldSet is the set of string fields of all type of input attributes. InputAttrsStrFieldSet = set.NewStrSet() )
Functions ¶
func SetFuncGetInputAttrsByType ¶
func SetFuncGetInputAttrsByType(f GetInputAttrsByTypeIntf)
SetFuncGetInputAttrsByType customizes NewInputAttrsByType's behavior.
func SetFuncGetUnknownTypeInputAttrs ¶
func SetFuncGetUnknownTypeInputAttrs(f GetUnknownTypeInputAttrsIntf)
SetFuncGetUnknownTypeInputAttrs customizes NewInputAttrsByType's behavior.
func SetInputAttrs ¶
func SetInputAttrs(args ...NewInputAttrs) error
SetInputAttrs sets InputAttrs. You can add the custom InputAttrs and override existing InputAttrs.
Types ¶
type AlarmCallback ¶
type AlarmCallback struct { // ex. "org.graylog2.alarmcallbacks.HTTPAlarmCallback" ID string `json:"id,omitempty" v-create:"isdefault"` StreamID string `json:"stream_id,omitempty" v-create:"required"` Title string `json:"title" v-create:"required"` CreatorUserID string `json:"creator_user_id,omitempty" v-create:"isdefault"` CreatedAt string `json:"created_at,omitempty" v-create:"isdefault"` Configuration AlarmCallbackConfiguration `json:"configuration" v-create:"required"` }
AlarmCallback represents an Alarm Callback. https://docs.graylog.org/en/latest/pages/streams/alerts.html#alert-notifications-types-explained
func (*AlarmCallback) MarshalJSON ¶
func (ac *AlarmCallback) MarshalJSON() ([]byte, error)
MarshalJSON returns JSON encoding of an AlarmCallback.
func (AlarmCallback) Type ¶
func (ac AlarmCallback) Type() string
Type returns an alarm callback type.
func (*AlarmCallback) UnmarshalJSON ¶
func (ac *AlarmCallback) UnmarshalJSON(b []byte) error
UnmarshalJSON unmarshals JSON into an AlarmCallback.
type AlarmCallbackConfiguration ¶
type AlarmCallbackConfiguration interface {
AlarmCallbackType() string
}
AlarmCallbackConfiguration is an alarm callback configuration.
type AlarmCallbacksBody ¶
type AlarmCallbacksBody struct { AlarmCallbacks []AlarmCallback `json:"alarmcallbacks"` Total int `json:"total"` }
AlarmCallbacksBody represents Get Alarm Callbacks API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Alert ¶
type Alert struct { ID string `json:"id"` Description string `json:"description"` ConditionID string `json:"condition_id"` StreamID string `json:"stream_id"` TriggeredAt string `json:"triggered_at"` ResolvedAt string `json:"resolved_at"` IsInterval bool `json:"is_interval"` ConditionParameters *AlertConditionParameters `json:"condition_parameters"` }
Alert represents an Alert. https://docs.graylog.org/en/latest/pages/streams/alerts.html
type AlertCondition ¶
type AlertCondition struct { ID string `json:"id,omitempty"` CreatorUserID string `json:"creator_user_id,omitempty"` CreatedAt string `json:"created_at,omitempty"` Title string `json:"title" v-create:"required" v-update:"required"` // in_grace must be "omitempty". Without "omitempty", it is failed to create an Alert Condition. // Unable to map property in_grace. Known properties include: title, type, parameters InGrace bool `json:"in_grace,omitempty"` Parameters AlertConditionParameters `json:"parameters" v-create:"reqired" v-update:"required"` }
AlertCondition represents an Alert Condition. https://docs.graylog.org/en/latest/pages/streams/alerts.html#conditions
func (*AlertCondition) MarshalJSON ¶
func (cond *AlertCondition) MarshalJSON() ([]byte, error)
MarshalJSON returns JSON encoding of an alert condition.
func (AlertCondition) Type ¶
func (cond AlertCondition) Type() string
Type returns an alert condition type.
func (*AlertCondition) UnmarshalJSON ¶
func (cond *AlertCondition) UnmarshalJSON(b []byte) error
UnmarshalJSON unmarshals JSON into an alert condition.
type AlertConditionParameters ¶
type AlertConditionParameters interface {
AlertConditionType() string
}
AlertConditionParameters represents Alert Condition's parameters.
type AlertConditionsBody ¶
type AlertConditionsBody struct { AlertConditions []AlertCondition `json:"conditions"` Total int `json:"total"` }
AlertConditionsBody represents Get Alert Conditions API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type AlertReceivers ¶
type AlertReceivers struct { Emails []string `json:"emails,omitempty"` Users []string `json:"users,omitempty"` }
AlertReceivers represents alert receivers.
type AlertsBody ¶
AlertsBody represents Get Alerts API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type CollectorConfiguration ¶
type CollectorConfiguration struct { ID string `json:"id,omitempty" v-create:"isdefault"` Name string `json:"name,omitempty" v-create:"required"` Tags set.StrSet `json:"tags"` Inputs []CollectorConfigurationInput `json:"inputs"` Outputs []CollectorConfigurationOutput `json:"outputs"` Snippets []CollectorConfigurationSnippet `json:"snippets"` }
CollectorConfiguration represents a Graylog's Collector Configuration.
type CollectorConfigurationInput ¶
type CollectorConfigurationInput struct { Backend string `json:"backend"` Type string `json:"type"` Name string `json:"name"` InputID string `json:"input_id"` ForwardTo string `json:"forward_to"` Properties CollectorConfigurationInputProperty `json:"properties"` }
CollectorConfigurationInput represents a Graylog's Collector Configuration Input.
type CollectorConfigurationInputFileProperty ¶
type CollectorConfigurationInputFileProperty struct { Paths string `json:"paths"` ExcludeFiles string `json:"exclude_files"` ScanFrequency string `json:"scan_frequency"` Encoding string `json:"encoding"` IgnoreOlder string `json:"ignore_older"` DocumentType string `json:"document_type"` ExcludeLines string `json:"exclude_lines"` IncludeLines string `json:"include_lines"` TailFiles bool `json:"tail_files"` }
CollectorConfigurationInputFileProperty represents a Graylog's Collector Configuration file type Input properties.
type CollectorConfigurationInputProperty ¶
type CollectorConfigurationInputProperty interface{}
CollectorConfigurationInputProperty represents a Graylog's Collector Configuration Input properties.
type CollectorConfigurationInputWindowsEventLogProperty ¶
type CollectorConfigurationInputWindowsEventLogProperty struct {
Event string `json:"event"`
}
CollectorConfigurationInputWindowsEventLogProperty represents a Graylog's Collector Configuration windows event log type Input properties.
type CollectorConfigurationOutput ¶
type CollectorConfigurationOutput struct { Backend string `json:"backend"` Type string `json:"type"` Name string `json:"name"` OutputID string `json:"output_id"` Properties CollectorConfigurationOutputProperty `json:"properties"` }
CollectorConfigurationOutput represents a Graylog's Collector Configuration Output.
type CollectorConfigurationOutputProperty ¶
type CollectorConfigurationOutputProperty interface{}
CollectorConfigurationOutputProperty represents a Graylog's Collector Configuration Output properties.
type CollectorConfigurationSnippet ¶
type CollectorConfigurationSnippet struct { Backend string `json:"backend"` Name string `json:"name"` Snippet string `json:"snippet"` SnippetID string `json:"snippet_id"` }
CollectorConfigurationSnippet represents a Graylog's Collector Configuration Snippet.
type CollectorConfigurationsBody ¶
type CollectorConfigurationsBody struct { Configurations []CollectorConfiguration `json:"configurations"` Total int `json:"total"` }
CollectorConfigurationsBody represents Get Collector Configurations API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Dashboard ¶
type Dashboard struct { // required Title string `json:"title,omitempty" v-create:"required"` Description string `json:"description,omitempty"` // ex. "2018-02-20T11:37:19.305Z" CreatedAt string `json:"created_at,omitempty"` ID string `json:"id,omitempty" v-create:"isdefault"` Widgets []Widget `json:"widgets,omitempty"` Positions []DashboardWidgetPosition `json:"positions"` CreatorUserID string `json:"creator_user_id,omitempty"` }
Dashboard represents a Graylog's Dashboard. https://docs.graylog.org/en/latest/pages/dashboards.html
func (*Dashboard) UnmarshalJSON ¶
type DashboardWidgetPosition ¶
type DashboardsBody ¶
DashboardsBody represents Get Dashboards API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type EmailAlarmCallbackConfiguration ¶
type EmailAlarmCallbackConfiguration struct { Sender string `json:"sender" v-create:"required"` Subject string `json:"subject" v-create:"required"` Body string `json:"body,omitempty"` UserReceivers set.StrSet `json:"user_receivers,omitempty"` EmailReceivers set.StrSet `json:"email_receivers,omitempty"` }
EmailAlarmCallbackConfiguration represents a configuration of EmailAlarmCallback.
func (*EmailAlarmCallbackConfiguration) AlarmCallbackType ¶
func (ac *EmailAlarmCallbackConfiguration) AlarmCallbackType() string
AlarmCallbackType returns an alarm callback type.
type EventDefinition ¶ added in v8.5.0
type EventDefinition struct { ID string `json:"id"` Title string `json:"title"` Description string `json:"description"` Priority int `json:"priority"` Alert bool `json:"alert"` FieldSpec map[string]EventDefinitionFieldSpec `json:"field_spec"` // KeySpec []interface{} `json:"key_spec"` NotificationSettings EventDefinitionNotificationSettings `json:"notification_settings"` Notifications []EventDefinitionNotification `json:"notifications"` Storage []interface{} `json:"storage"` Config interface{} `json:"config"` }
EventDefinition represents an event definition.
type EventDefinitionConfigConditions ¶ added in v8.5.0
type EventDefinitionConfigConditions struct {
Expression EventDefinitionConfigConditionsExpression `json:"expression"`
}
type EventDefinitionConfigConditionsExpression ¶ added in v8.5.0
type EventDefinitionConfigConditionsExpression struct { Expr string `json:"expr"` Left *EventDefinitionConfigConditionsExpressionLeft `json:"left"` Right *EventDefinitionConfigConditionsExpressionRight `json:"right"` }
type EventDefinitionConfigConditionsExpressionLeft ¶ added in v8.5.0
type EventDefinitionConfigConditionsExpressionRight ¶ added in v8.5.0
type EventDefinitionConfigSeries ¶ added in v8.5.0
type EventDefinitionFieldSpec ¶ added in v8.5.0
type EventDefinitionFieldSpec struct { DataType string `json:"data_type"` Providers []interface{} `json:"providers"` }
type EventDefinitionNotification ¶ added in v8.5.0
type EventDefinitionNotification struct {
NotificationID string `json:"notification_id"`
}
type EventDefinitionNotificationSettings ¶ added in v8.5.0
type EventDefinitionsBody ¶ added in v8.5.0
type EventDefinitionsBody struct { EventDefinitions []EventDefinition `json:"event_definitions"` Total int `json:"total"` Page int `json:"page"` PerPage int `json:"per_page"` Count int `json:"count"` GrandTotal int `json:"grand_total"` Query string `json:"query"` }
EventDefinitionsBody represents Get EventDefinitions API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type EventNotification ¶ added in v8.4.0
type EventNotification struct { ID string `json:"id,omitempty"` Title string `json:"title"` Description string `json:"description"` Config interface{} `json:"config"` }
EventNotification represents an output.
type EventNotificationsBody ¶ added in v8.4.0
type EventNotificationsBody struct { EventNotifications []EventNotification `json:"notifications"` Total int `json:"total"` Page int `json:"page"` PerPage int `json:"per_page"` Count int `json:"count"` GrandTotal int `json:"grand_total"` Query string `json:"query"` }
EventNotificationsBody represents Get EventNotifications API's response body.
type Extractor ¶
type Extractor struct { ID string `json:"id,omitempty"` Title string `json:"title,omitempty"` Type string `json:"type,omitempty"` Converters []ExtractorConverter `json:"converters,omitempty"` Order int `json:"order"` Exceptions int `json:"exceptions,omitempty"` ConverterExceptions int `json:"converter_exceptions,omitempty"` Metrics *ExtractorMetrics `json:"metrics,omitempty"` CursorStrategy string `json:"cursor_strategy,omitempty"` SourceField string `json:"source_field,omitempty"` TargetField string `json:"target_field"` ExtractorConfig interface{} `json:"extractor_config,omitempty"` CreatorUserID string `json:"creator_user_id,omitempty"` ConditionType string `json:"condition_type,omitempty"` ConditionValue string `json:"condition_value"` }
func (*Extractor) UnmarshalJSON ¶
type ExtractorConverter ¶
type ExtractorConverter struct { Type string `json:"type"` Config *ExtractorConverterConfig `json:"config"` }
type ExtractorMetric ¶
type ExtractorMetric struct { Time *ExtractorMetricTime `json:"time,omitempty"` Rate *ExtractorMetricRate `json:"rate,omitempty"` DurationUnit string `json:"duration_unit,omitempty"` RateUnit string `json:"rate_unit,omitempty"` }
type ExtractorMetricRate ¶
type ExtractorMetricRate struct { // in Graylog, the type of these fields are double. // https://github.com/Graylog2/graylog2-server/blob/484fdf0940718cb6bf23f812d000fd07f165eb92/graylog2-server/src/main/java/org/graylog2/rest/models/metrics/responses/RateMetricsResponse.java#L25-L35 Total float64 `json:"total,omitempty"` Mean float64 `json:"mean,omitempty"` OneMinute float64 `json:"one_minute,omitempty"` FiveMinute float64 `json:"five_minute,omitempty"` FifteenMinute float64 `json:"fifteen_minute,omitempty"` }
type ExtractorMetricTime ¶
type ExtractorMetricTime struct { // in Graylog, the type of these fields are double. // https://github.com/Graylog2/graylog2-server/blob/484fdf0940718cb6bf23f812d000fd07f165eb92/graylog2-server/src/main/java/org/graylog2/rest/models/metrics/responses/TimerMetricsResponse.java#L25-L39 Min float64 `json:"min,omitempty"` Max float64 `json:"max,omitempty"` Mean float64 `json:"mean,omitempty"` StdDev float64 `json:"std_dev,omitempty"` Percentile95th float64 `json:"95th_percentile,omitempty"` Percentile98th float64 `json:"98th_percentile,omitempty"` Percentile99th float64 `json:"99th_percentile,omitempty"` }
type ExtractorMetrics ¶
type ExtractorMetrics struct { Total *ExtractorMetric `json:"total,omitempty"` Condition *ExtractorMetric `json:"condition,omitempty"` Execution *ExtractorMetric `json:"execution,omitempty"` Converters *ExtractorMetric `json:"converters,omitempty"` ConditionHits int `json:"condition_hits,omitempty"` ConditionMisses int `json:"condition_misses,omitempty"` }
type ExtractorTypeGrokConfig ¶
type ExtractorTypeGrokConfig struct {
GrokPattern string `json:"grok_pattern"`
}
type ExtractorTypeJSONConfig ¶
type ExtractorTypeJSONConfig struct { ListSeparator string `json:"list_separator,omitempty"` KVSeparator string `json:"kv_separator,omitempty"` KeyPrefix string `json:"key_prefix,omitempty"` KeySeparator string `json:"key_separator,omitempty"` ReplaceKeyWhitespace bool `json:"replace_key_whitespace"` KeyWhitespaceReplacement string `json:"key_whitespace_replacement,omitempty"` }
type ExtractorTypeRegexConfig ¶
type ExtractorTypeRegexConfig struct {
RegexValue string `json:"regex_value"`
}
type ExtractorsBody ¶
ExtractorsBody represents Get Extractors API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type FieldAggregationAlertConditionParameters ¶
type FieldAggregationAlertConditionParameters struct { Grace int `json:"grace"` Backlog int `json:"backlog"` Threshold int `json:"threshold"` Time int `json:"time" v-create:"required"` RepeatNotifications bool `json:"repeat_notifications"` Field string `json:"field,omitempty" v-create:"required"` Query string `json:"query,omitempty"` ThresholdType string `json:"threshold_type,omitempty" v-create:"required"` Type string `json:"type,omitempty" v-create:"required"` }
FieldAggregationAlertConditionParameters represents Field Aggregation Alert Condition's parameters.
func (FieldAggregationAlertConditionParameters) AlertConditionType ¶
func (p FieldAggregationAlertConditionParameters) AlertConditionType() string
AlertConditionType returns an alert condition type.
type FieldContentAlertConditionParameters ¶
type FieldContentAlertConditionParameters struct { Grace int `json:"grace"` Backlog int `json:"backlog"` RepeatNotifications bool `json:"repeat_notifications"` Field string `json:"field,omitempty" v-create:"required"` Value string `json:"value,omitempty" v-create:"required"` Query string `json:"query,omitempty"` }
FieldContentAlertConditionParameters represents Field Content Alert Condition's parameters.
func (FieldContentAlertConditionParameters) AlertConditionType ¶
func (p FieldContentAlertConditionParameters) AlertConditionType() string
AlertConditionType returns an alert condition type.
type GeneralAlarmCallbackConfiguration ¶
type GeneralAlarmCallbackConfiguration struct { Type string `json:"type"` Configuration map[string]interface{} `json:"configuration"` }
GeneralAlarmCallbackConfiguration is a general third party's AlarmCallbackConfiguration.
func (*GeneralAlarmCallbackConfiguration) AlarmCallbackType ¶
func (p *GeneralAlarmCallbackConfiguration) AlarmCallbackType() string
AlarmCallbackType returns an alarm callback type.
func (*GeneralAlarmCallbackConfiguration) MarshalJSON ¶
func (p *GeneralAlarmCallbackConfiguration) MarshalJSON() ([]byte, error)
MarshalJSON returns JSON encoding of GeneralAlarmCallbackConfiguration.
type GeneralAlertConditionParameters ¶
GeneralAlertConditionParameters is a general third party's alert condition parameters.
func (GeneralAlertConditionParameters) AlertConditionType ¶
func (p GeneralAlertConditionParameters) AlertConditionType() string
AlertConditionType returns an alert condition type.
func (*GeneralAlertConditionParameters) MarshalJSON ¶
func (p *GeneralAlertConditionParameters) MarshalJSON() ([]byte, error)
MarshalJSON returns JSON encoding of GeneralAlertConditionParameters.
type GetInputAttrsByTypeIntf ¶
type GetInputAttrsByTypeIntf func(map[string]NewInputAttrs, string) InputAttrs
GetInputAttrsByTypeIntf returns a given type InputAttrs.
func GetFuncGetInputAttrsByType ¶
func GetFuncGetInputAttrsByType() GetInputAttrsByTypeIntf
GetFuncGetInputAttrsByType returns the global GetInputAttrsByType function. Mainly this is used to prevent global pollution at test.
f := graylog.GetFuncGetInputAttrsByType() // change the global function temporary defer graylog.SetFuncGetInputAttrsByType(f) graylog.SetFuncGetInputAttrsByType(customFunc)
type GetUnknownTypeInputAttrsIntf ¶
type GetUnknownTypeInputAttrsIntf func(map[string]NewInputAttrs, string) InputAttrs
GetUnknownTypeInputAttrsIntf returns an unknown type InputAttrs.
func GetFuncGetUnknownTypeInputAttrs ¶
func GetFuncGetUnknownTypeInputAttrs() GetUnknownTypeInputAttrsIntf
GetFuncGetUnknownTypeInputAttrs returns the global GetUnknownTypeInputAttrs function. Mainly this is used to prevent global pollution at test.
f := graylog.GetFuncGetUnknownTypeInputAttrs() // change the global function temporary defer graylog.SetFuncGetUnknownTypeInputAttrs(f) graylog.SetFuncGetUnknownTypeInputAttrs(customFunc)
type GrokPattern ¶
type GrokPattern struct { ID string `json:"id,omitempty"` Name string `json:"name"` Pattern string `json:"pattern"` }
GrokPattern represents a grok pattern.
type GrokPatternsBody ¶
type GrokPatternsBody struct {
Patterns []GrokPattern `json:"patterns"`
}
GrokPatternsBody represents Get Grok Pattern API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type HTTPAlarmCallbackConfiguration ¶
type HTTPAlarmCallbackConfiguration struct {
URL string `json:"url" v-create:"required"`
}
HTTPAlarmCallbackConfiguration represents a configuration of HTTPAlarmCallback.
func (*HTTPAlarmCallbackConfiguration) AlarmCallbackType ¶
func (ac *HTTPAlarmCallbackConfiguration) AlarmCallbackType() string
AlarmCallbackType returns an alarm callback type.
type IndexSet ¶
type IndexSet struct { // required Title string `json:"title,omitempty" v-create:"required"` // ^[a-z0-9][a-z0-9_+-]*$ IndexPrefix string `json:"index_prefix,omitempty" v-create:"required,indexprefixregexp"` // ex. "org.graylog2.indexer.rotation.strategies.MessageCountRotationStrategy" RotationStrategyClass string `json:"rotation_strategy_class,omitempty" v-create:"required"` RotationStrategy *RotationStrategy `json:"rotation_strategy,omitempty" v-create:"required"` // ex. "org.graylog2.indexer.retention.strategies.DeletionRetentionStrategy" RetentionStrategyClass string `json:"retention_strategy_class,omitempty" v-create:"required"` RetentionStrategy *RetentionStrategy `json:"retention_strategy,omitempty" v-create:"required"` // ex. "2018-02-20T11:37:19.305Z" CreationDate string `json:"creation_date,omitempty"` IndexAnalyzer string `json:"index_analyzer,omitempty" v-create:"required"` Shards int `json:"shards,omitempty" v-create:"required"` IndexOptimizationMaxNumSegments int `json:"index_optimization_max_num_segments,omitempty" v-create:"required"` // field_type_refresh_interval is added from Graylog API v3 FieldTypeRefreshInterval int `json:"field_type_refresh_interval,omitempty"` ID string `json:"id,omitempty" v-create:"isdefault"` Description string `json:"description,omitempty"` Replicas int `json:"replicas,omitempty"` IndexOptimizationDisabled bool `json:"index_optimization_disabled"` Writable bool `json:"writable"` Default bool `json:"default"` Stats *IndexSetStats `json:"-"` }
IndexSet represents a Graylog's Index Set. https://docs.graylog.org/en/latest/pages/configuration/index_model.html#index-set-configuration
func (*IndexSet) CreationTime ¶
CreationTime returns a creation date converted to time.Time.
func (*IndexSet) NewUpdateParams ¶
func (is *IndexSet) NewUpdateParams() *IndexSetUpdateParams
NewUpdateParams converts an IndexSet to IndexSetUpdateParams.
func (*IndexSet) SetCreateDefaultValues ¶
func (is *IndexSet) SetCreateDefaultValues()
SetCreateDefaultValues sets the default values of Create Index Set API.
func (*IndexSet) SetCreationTime ¶
SetCreationTime sets a creation date with time.Time.
type IndexSetStats ¶
type IndexSetStats struct { Indices int `json:"indices"` Documents int `json:"documents"` Size int `json:"size"` }
IndexSetStats represents a Graylog's Index Set Stats.
type IndexSetUpdateParams ¶
type IndexSetUpdateParams struct { Title string `json:"title" v-update:"required"` IndexPrefix string `json:"index_prefix" v-update:"required,indexprefixregexp"` RotationStrategyClass string `json:"rotation_strategy_class" v-update:"required"` RotationStrategy *RotationStrategy `json:"rotation_strategy" v-update:"required"` RetentionStrategyClass string `json:"retention_strategy_class" v-update:"required"` RetentionStrategy *RetentionStrategy `json:"retention_strategy" v-update:"required"` IndexAnalyzer string `json:"index_analyzer" v-update:"required"` Shards int `json:"shards" v-update:"required"` IndexOptimizationMaxNumSegments int `json:"index_optimization_max_num_segments" v-update:"required"` // field_type_refresh_interval is added from Graylog API v3 FieldTypeRefreshInterval int `json:"field_type_refresh_interval"` ID string `json:"id" v-update:"required,objectid"` Description *string `json:"description,omitempty"` Replicas *int `json:"replicas,omitempty"` IndexOptimizationDisabled *bool `json:"index_optimization_disabled,omitempty"` Writable *bool `json:"writable,omitempty"` }
IndexSetUpdateParams represents a Graylog's Index Set Update API's parameter. https://docs.graylog.org/en/latest/pages/configuration/index_model.html#index-set-configuration
type IndexSetsBody ¶
type IndexSetsBody struct { IndexSets []IndexSet `json:"index_sets"` Stats map[string]IndexSetStats `json:"stats"` Total int `json:"total"` }
IndexSetsBody represents Get Index Sets API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Input ¶
type Input struct { // Select a name of your new input that describes it. Title string `json:"title,omitempty" v-create:"required"` // https://github.com/Graylog2/graylog2-server/issues/3480 // update input overwrite attributes Attrs InputAttrs `json:"attributes,omitempty" v-create:"required"` ID string `json:"id,omitempty" v-create:"isdefault"` // Should this input start on all nodes Global bool `json:"global"` // On which node should this input start // ex. "2ad6b340-3e5f-4a96-ae81-040cfb8b6024" Node string `json:"node,omitempty"` // ex. 2018-02-24T03:02:26.001Z CreatedAt string `json:"created_at,omitempty" v-create:"isdefault"` // ex. "admin" CreatorUserID string `json:"creator_user_id,omitempty" v-create:"isdefault"` StaticFields map[string]string `json:"static_fields,omitempty"` }
Input represents Graylog Input.
func (*Input) MarshalJSON ¶
MarshalJSON is the implementation of the json.Marshaler interface.
func (*Input) NewUpdateParams ¶
func (input *Input) NewUpdateParams() *InputUpdateParams
NewUpdateParams converts Input to InputUpdateParams.
func (*Input) UnmarshalJSON ¶
UnmarshalJSON is the implementation of the json.Unmarshaler interface.
type InputAWSCloudTrailAttrs ¶
type InputAWSCloudTrailAttrs struct { CreatorUserID string `json:"creator_user_id,omitempty" v-create:"isdefault"` AWSAssumeRoleArn string `json:"aws_assume_role_arn,omitempty"` AWSAccessKey string `json:"aws_access_key,omitempty"` AWSSecretKey string `json:"aws_secret_key,omitempty"` AWSSQSRegion string `json:"aws_sqs_region,omitempty"` AWSSQSQueueName string `json:"aws_sqs_queue_name,omitempty"` AWSS3Region string `json:"aws_s3_region,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` OverrideSource string `json:"override_source,omitempty"` }
InputAWSCloudTrailAttrs represents aws cloud trail Input's attributes.
func (InputAWSCloudTrailAttrs) InputType ¶
func (attrs InputAWSCloudTrailAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputAWSCloudWatchLogsAttrs ¶
type InputAWSCloudWatchLogsAttrs struct { AWSRegion string `json:"aws_region,omitempty"` AWSAssumeRoleArn string `json:"aws_assume_role_arn,omitempty"` AWSAccessKey string `json:"aws_access_key,omitempty"` AWSSecretKey string `json:"aws_secret_key,omitempty"` KinesisStreamName string `json:"kinesis_stream_name,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` OverrideSource string `json:"override_source,omitempty"` }
InputAWSCloudWatchLogsAttrs represents AWS logs Input's attributes.
func (InputAWSCloudWatchLogsAttrs) InputType ¶
func (attrs InputAWSCloudWatchLogsAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputAWSFlowLogsAttrs ¶
type InputAWSFlowLogsAttrs struct { AWSRegion string `json:"aws_region,omitempty"` AWSAssumeRoleArn string `json:"aws_assume_role_arn,omitempty"` AWSAccessKey string `json:"aws_access_key,omitempty"` AWSSecretKey string `json:"aws_secret_key,omitempty"` KinesisStreamName string `json:"kinesis_stream_name,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` }
InputAWSFlowLogsAttrs represents AWS flow logs Input's attributes.
func (InputAWSFlowLogsAttrs) InputType ¶
func (attrs InputAWSFlowLogsAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputAttrs ¶
type InputAttrs interface {
InputType() string
}
InputAttrs represents Input Attributes. A receiver must be a pointer.
func NewInputAWSCloudTrailAttrs ¶
func NewInputAWSCloudTrailAttrs() InputAttrs
NewInputAWSCloudTrailAttrs is the constructor of InputAWSCloudTrailAttrs.
func NewInputAWSCloudWatchLogsAttrs ¶
func NewInputAWSCloudWatchLogsAttrs() InputAttrs
NewInputAWSCloudWatchLogsAttrs is the constructor of InputAWSCloudWatchLogsAttrs.
func NewInputAWSFlowLogsAttrs ¶
func NewInputAWSFlowLogsAttrs() InputAttrs
NewInputAWSFlowLogsAttrs is the constructor of InputAWSFlowLogsAttrs.
func NewInputAttrsByType ¶
func NewInputAttrsByType(t string) InputAttrs
NewInputAttrsByType returns a new InputAttrs.
func NewInputBeatsAttrs ¶
func NewInputBeatsAttrs() InputAttrs
NewInputBeatsAttrs is the constructor of InputBeatsAttrs.
func NewInputCEFAMQPAttrs ¶
func NewInputCEFAMQPAttrs() InputAttrs
NewInputCEFAMQPAttrs is the constructor of InputCEFAMQPAttrs.
func NewInputCEFKafkaAttrs ¶
func NewInputCEFKafkaAttrs() InputAttrs
NewInputCEFKafkaAttrs is the constructor of InputCEFKafkaAttrs.
func NewInputCEFTCPAttrs ¶
func NewInputCEFTCPAttrs() InputAttrs
NewInputCEFTCPAttrs is the constructor of InputCEFTCPAttrs.
func NewInputCEFUDPAttrs ¶
func NewInputCEFUDPAttrs() InputAttrs
NewInputCEFUDPAttrs is the constructor of InputCEFUDPAttrs.
func NewInputFakeHTTPMessageAttrs ¶
func NewInputFakeHTTPMessageAttrs() InputAttrs
NewInputFakeHTTPMessageAttrs is the constructor of InputFakeHTTPMessageAttrs.
func NewInputGELFAMQPAttrs ¶
func NewInputGELFAMQPAttrs() InputAttrs
NewInputGELFAMQPAttrs is the constructor of InputGELFAMQPAttrs.
func NewInputGELFHTTPAttrs ¶
func NewInputGELFHTTPAttrs() InputAttrs
NewInputGELFHTTPAttrs is the constructor of InputGELFHTTPAttrs.
func NewInputGELFKafkaAttrs ¶
func NewInputGELFKafkaAttrs() InputAttrs
NewInputGELFKafkaAttrs is the constructor of InputGELFKafkaAttrs.
func NewInputGELFTCPAttrs ¶
func NewInputGELFTCPAttrs() InputAttrs
NewInputGELFTCPAttrs is the constructor of InputGELFTCPAttrs.
func NewInputGELFUDPAttrs ¶
func NewInputGELFUDPAttrs() InputAttrs
NewInputGELFUDPAttrs is the constructor of InputGELFUDPAttrs.
func NewInputJSONPathAttrs ¶
func NewInputJSONPathAttrs() InputAttrs
NewInputJSONPathAttrs is the constructor of InputJSONPathAttrs.
func NewInputNetFlowUDPAttrs ¶
func NewInputNetFlowUDPAttrs() InputAttrs
NewInputNetFlowUDPAttrs is the constructor of InputNetFlowUDPAttrs.
func NewInputRawAMQPAttrs ¶
func NewInputRawAMQPAttrs() InputAttrs
NewInputRawAMQPAttrs is the constructor of InputRawAMQPAttrs.
func NewInputRawKafkaAttrs ¶
func NewInputRawKafkaAttrs() InputAttrs
NewInputRawKafkaAttrs is the constructor of InputRawKafkaAttrs.
func NewInputSyslogAMQPAttrs ¶
func NewInputSyslogAMQPAttrs() InputAttrs
NewInputSyslogAMQPAttrs is the constructor of InputSyslogAMQPAttrs.
func NewInputSyslogKafkaAttrs ¶
func NewInputSyslogKafkaAttrs() InputAttrs
NewInputSyslogKafkaAttrs is the constructor of InputSyslogKafkaAttrs.
func NewInputSyslogTCPAttrs ¶
func NewInputSyslogTCPAttrs() InputAttrs
NewInputSyslogTCPAttrs is the constructor of InputSyslogTCPAttrs.
func NewInputSyslogUDPAttrs ¶
func NewInputSyslogUDPAttrs() InputAttrs
NewInputSyslogUDPAttrs is the constructor of InputSyslogUDPAttrs.
type InputBeatsAttrs ¶
type InputBeatsAttrs struct { BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` OverrideSource string `json:"override_source,omitempty"` TLSKeyFile string `json:"tls_key_file,omitempty"` TLSKeyPassword string `json:"tls_key_password,omitempty"` TLSClientAuthCertFile string `json:"tls_client_auth_cert_file,omitempty"` TLSClientAuth string `json:"tls_client_auth,omitempty"` TLSCertFile string `json:"tls_cert_file,omitempty"` TLSEnable bool `json:"tls_enable"` TCPKeepAlive bool `json:"tcp_keepalive"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` }
InputBeatsAttrs represents Beats Input's attributes.
func (InputBeatsAttrs) InputType ¶
func (attrs InputBeatsAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputCEFAMQPAttrs ¶
type InputCEFAMQPAttrs struct { Exchange string `json:"exchange,omitempty"` Timezone string `json:"timezone,omitempty"` BrokerPassword string `json:"broker_password,omitempty"` Locale string `json:"locale,omitempty"` BrokerHostname string `json:"broker_hostname,omitempty"` Queue string `json:"queue,omitempty"` BrokerVHost string `json:"broker_vhost,omitempty"` BrokerUsername string `json:"broker_username,omitempty"` RoutingKey string `json:"routing_key,omitempty"` Heartbeat int `json:"heartbeat,omitempty"` ParallelQueues int `json:"parallel_queues,omitempty"` Prefetch int `json:"prefetch,omitempty"` BrokerPort int `json:"broker_port,omitempty"` ExchangeBind bool `json:"exchange_bind"` RequeueInvalidMessages bool `json:"requeue_invalid_messages"` UseFullNames bool `json:"use_full_names"` TLS bool `json:"tls"` ThrottlingAllowed bool `json:"throttling_allowed"` }
InputCEFAMQPAttrs represents CEF AMQP Input's attributes.
func (InputCEFAMQPAttrs) InputType ¶
func (attrs InputCEFAMQPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputCEFKafkaAttrs ¶
type InputCEFKafkaAttrs struct { ThrottlingAllowed bool `json:"throttling_allowed"` UseFullNames bool `json:"use_full_names"` Locale string `json:"locale,omitempty"` Zookeeper string `json:"zookeeper,omitempty"` Timezone string `json:"timezone,omitempty"` TopicFilter string `json:"topic_filter,omitempty"` OffsetReset string `json:"offset_reset,omitempty"` Threads int `json:"threads,omitempty"` FetchWaitMax int `json:"fetch_wait_max,omitempty"` FetchMinBytes int `json:"fetch_min_bytes,omitempty"` }
InputCEFKafkaAttrs represents CEF Kafka Input's attributes.
func (InputCEFKafkaAttrs) InputType ¶
func (attrs InputCEFKafkaAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputCEFTCPAttrs ¶
type InputCEFTCPAttrs struct { UseNullDelimiter bool `json:"use_null_delimiter"` UseFullNames bool `json:"use_full_names"` TLSEnable bool `json:"tls_enable"` TCPKeepAlive bool `json:"tcp_keepalive"` MaxMessageSize int `json:"max_message_size,omitempty"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` Timezone string `json:"timezone,omitempty"` Locale string `json:"locale,omitempty"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` TLSKeyFile string `json:"tls_key_file,omitempty"` TLSClientAuth string `json:"tls_client_auth,omitempty"` TLSKeyPassword string `json:"tls_key_password,omitempty"` TLSClientAuthCertFile string `json:"tls_client_auth_cert_file,omitempty"` TLSCertFile string `json:"tls_cert_file,omitempty"` }
InputCEFTCPAttrs represents CEF TCP Input's attributes.
func (InputCEFTCPAttrs) InputType ¶
func (attrs InputCEFTCPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputCEFUDPAttrs ¶
type InputCEFUDPAttrs struct { Locale string `json:"locale,omitempty"` UseFullNames bool `json:"use_full_names"` Timezone string `json:"timezone,omitempty"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` }
InputCEFUDPAttrs represents CEF UDP Input's attributes.
func (InputCEFUDPAttrs) InputType ¶
func (attrs InputCEFUDPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputData ¶
type InputData struct { Title string `json:"title,omitempty"` Type string `json:"type,omitempty"` ID string `json:"id,omitempty"` Node string `json:"node,omitempty"` CreatedAt string `json:"created_at,omitempty"` CreatorUserID string `json:"creator_user_id,omitempty"` Global bool `json:"global"` Attrs map[string]interface{} `json:"attributes,omitempty"` StaticFields map[string]string `json:"static_fields,omitempty"` }
InputData represents data of Input. This is used for data conversion of Input. ex. json.Unmarshal
type InputFakeHTTPMessageAttrs ¶
type InputFakeHTTPMessageAttrs struct { Sleep int `json:"sleep,omitempty"` SleepDeviation int `json:"sleep_deviation,omitempty"` Source string `json:"source,omitempty"` OverrideSource string `json:"override_source,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` }
InputFakeHTTPMessageAttrs represents fake HTTP message Input's attributes.
func (InputFakeHTTPMessageAttrs) InputType ¶
func (attrs InputFakeHTTPMessageAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputGELFAMQPAttrs ¶
type InputGELFAMQPAttrs struct { ExchangeBind bool `json:"exchange_bind"` ThrottlingAllowed bool `json:"throttling_allowed"` TLS bool `json:"tls"` RequeueInvalidMessages bool `json:"requeue_invalid_messages"` BrokerVHost string `json:"broker_vhost,omitempty"` BrokerUsername string `json:"broker_username,omitempty"` Queue string `json:"queue,omitempty"` RoutingKey string `json:"routing_key,omitempty"` OverrideSource string `json:"override_source,omitempty"` BrokerHostname string `json:"broker_hostname,omitempty"` Exchange string `json:"exchange,omitempty"` BrokerPassword string `json:"broker_password,omitempty"` Prefetch int `json:"prefetch,omitempty"` Heartbeat int `json:"heartbeat,omitempty"` DecompressSizeLimit int `json:"decompress_size_limit,omitempty"` BrokerPort int `json:"broker_port,omitempty"` ParallelQueues int `json:"parallel_queues,omitempty"` }
InputGELFAMQPAttrs represents GELF AMQP Input's attributes.
func (InputGELFAMQPAttrs) InputType ¶
func (attrs InputGELFAMQPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputGELFHTTPAttrs ¶
type InputGELFHTTPAttrs struct { IdleWriterTimeOut int `json:"idle_writer_timeout,omitempty"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` MaxChunkSize int `json:"max_chunk_size,omitempty"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` DecompressSizeLimit int `json:"decompress_size_limit,omitempty"` TLSClientAuthCertFile string `json:"tls_client_auth_cert_file,omitempty"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` TLSCertFile string `json:"tls_cert_file,omitempty"` TLSKeyFile string `json:"tls_key_file,omitempty"` TLSKeyPassword string `json:"tls_key_password,omitempty"` TLSClientAuth string `json:"tls_client_auth,omitempty"` OverrideSource string `json:"override_source,omitempty"` TCPKeepAlive bool `json:"tcp_keepalive"` EnableCORS bool `json:"enable_cors"` TLSEnable bool `json:"tls_enable"` }
InputGELFHTTPAttrs represents GELF HTTP Input's attributes.
func (InputGELFHTTPAttrs) InputType ¶
func (attrs InputGELFHTTPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputGELFKafkaAttrs ¶
type InputGELFKafkaAttrs struct { OverrideSource string `json:"override_source,omitempty"` DecompressSizeLimit int `json:"decompress_size_limit,omitempty"` TopicFilter string `json:"topic_filter,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` FetchWaitMax int `json:"fetch_wait_max,omitempty"` FetchMinBytes int `json:"fetch_min_bytes,omitempty"` OffsetReset string `json:"offset_reset,omitempty"` Threads int `json:"threads,omitempty"` Zookeeper string `json:"zookeeper,omitempty"` }
InputGELFKafkaAttrs represents GELF Kafka Input's attributes.
func (InputGELFKafkaAttrs) InputType ¶
func (attrs InputGELFKafkaAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputGELFTCPAttrs ¶
type InputGELFTCPAttrs struct { MaxMessageSize int `json:"max_message_size,omitempty"` DecompressSizeLimit int `json:"decompress_size_limit,omitempty"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` OverrideSource string `json:"override_source,omitempty"` TLSKeyFile string `json:"tls_key_file,omitempty"` TLSKeyPassword string `json:"tls_key_password,omitempty"` TLSClientAuthCertFile string `json:"tls_client_auth_cert_file,omitempty"` TLSClientAuth string `json:"tls_client_auth,omitempty"` TLSCertFile string `json:"tls_cert_file,omitempty"` UseNullDelimiter bool `json:"use_null_delimiter"` TLSEnable bool `json:"tls_enable"` TCPKeepAlive bool `json:"tcp_keepalive"` }
InputGELFTCPAttrs represents GELF TCP Input's attributes.
func (InputGELFTCPAttrs) InputType ¶
func (attrs InputGELFTCPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputGELFUDPAttrs ¶
type InputGELFUDPAttrs struct { DecompressSizeLimit int `json:"decompress_size_limit,omitempty"` OverrideSource string `json:"override_source,omitempty"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` }
InputGELFUDPAttrs represents GELF UDP Input's attributes.
func (InputGELFUDPAttrs) InputType ¶
func (attrs InputGELFUDPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputJSONPathAttrs ¶
type InputJSONPathAttrs struct { ThrottlingAllowed bool `json:"throttling_allowed"` OverrideSource string `json:"override_source,omitempty"` Headers string `json:"headers,omitempty"` Path string `json:"path,omitempty"` TargetURL string `json:"target_url,omitempty"` Interval int `json:"interval,omitempty"` Source string `json:"source,omitempty"` Timeunit string `json:"timeunit,omitempty"` }
InputJSONPathAttrs represents JSON path Input's attributes.
func (InputJSONPathAttrs) InputType ¶
func (attrs InputJSONPathAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputNetFlowUDPAttrs ¶
type InputNetFlowUDPAttrs struct { NetFlow9DefinitionsPath string `json:"netflow9_definitions_path,omitempty"` OverrideSource string `json:"override_source,omitempty"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` }
InputNetFlowUDPAttrs represents net flow UDP Input's attributes.
func (InputNetFlowUDPAttrs) InputType ¶
func (attrs InputNetFlowUDPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputRawAMQPAttrs ¶
type InputRawAMQPAttrs struct { ParallelQueues int `json:"parallel_queues,omitempty"` HeartBeat int `json:"heartbeat,omitempty"` BrokerPort int `json:"broker_port,omitempty"` Prefetch int `json:"prefetch,omitempty"` RequeueInvalidMessages bool `json:"requeue_invalid_messages"` TLS bool `json:"tls"` ExchangeBind bool `json:"exchange_bind"` ThrottlingAllowed bool `json:"throttling_allowed"` Exchange string `json:"exchange,omitempty"` RoutingKey string `json:"routing_key,omitempty"` BrokerHostname string `json:"broker_hostname,omitempty"` Queue string `json:"queue,omitempty"` BrokerPassword string `json:"broker_password,omitempty"` BrokerVHost string `json:"broker_vhost,omitempty"` BrokerUsername string `json:"broker_username,omitempty"` OverrideSource string `json:"override_source,omitempty"` }
InputRawAMQPAttrs represents raw AMQP Input's attributes.
func (InputRawAMQPAttrs) InputType ¶
func (attrs InputRawAMQPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputRawKafkaAttrs ¶
type InputRawKafkaAttrs struct { TopicFilter string `json:"topic_filter,omitempty"` FetchWaitMax int `json:"fetch_wait_max,omitempty"` OffsetReset string `json:"offset_reset,omitempty"` Zookeeper string `json:"zookeeper,omitempty"` ThrottlingAllowed bool `json:"throttling_allowed"` FetchMinBytes int `json:"fetch_min_bytes,omitempty"` Threads int `json:"threads,omitempty"` OverrideSource string `json:"override_source,omitempty"` }
InputRawKafkaAttrs represents RawKafka Input's attributes.
func (InputRawKafkaAttrs) InputType ¶
func (attrs InputRawKafkaAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputSyslogAMQPAttrs ¶
type InputSyslogAMQPAttrs struct { Heartbeat int `json:"heartbeat,omitempty"` Prefetch int `json:"prefetch,omitempty"` BrokerPort int `json:"broker_port,omitempty"` ParallelQueues int `json:"parallel_queues,omitempty"` BrokerVHost string `json:"broker_vhost,omitempty"` BrokerUsername string `json:"broker_username,omitempty"` BrokerPassword string `json:"broker_password,omitempty"` Exchange string `json:"exchange,omitempty"` OverrideSource string `json:"override_source,omitempty"` RoutingKey string `json:"routing_key,omitempty"` BrokerHostname string `json:"broker_hostname,omitempty"` Queue string `json:"queue,omitempty"` ExchangeBind bool `json:"exchange_bind"` ForceRDNS bool `json:"force_rdns"` StoreFullMessage bool `json:"store_full_message"` ExpandStructuredData bool `json:"expand_structured_data"` ThrottlingAllowed bool `json:"throttling_allowed"` TLS bool `json:"tls"` AllowOverrideDate bool `json:"allow_override_date"` RequeueInvalidMessages bool `json:"requeue_invalid_messages"` }
InputSyslogAMQPAttrs represents SyslogAMQP Input's attributes.
func (InputSyslogAMQPAttrs) InputType ¶
func (attrs InputSyslogAMQPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputSyslogKafkaAttrs ¶
type InputSyslogKafkaAttrs struct { ForceRDNS bool `json:"force_rdns"` StoreFullMessage bool `json:"store_full_message"` ExpandStructuredData bool `json:"expand_structured_data"` AllowOverrideDate bool `json:"allow_override_date"` ThrottlingAllowed bool `json:"throttling_allowed"` OverrideSource string `json:"override_source,omitempty"` TopicFilter string `json:"topic_filter,omitempty"` FetchWaitMax int `json:"fetch_wait_max,omitempty"` OffsetReset string `json:"offset_reset,omitempty"` Zookeeper string `json:"zookeeper,omitempty"` FetchMinBytes int `json:"fetch_min_bytes,omitempty"` Threads int `json:"threads,omitempty"` }
InputSyslogKafkaAttrs represents SyslogKafka Input's attributes.
func (InputSyslogKafkaAttrs) InputType ¶
func (attrs InputSyslogKafkaAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputSyslogTCPAttrs ¶
type InputSyslogTCPAttrs struct { Port int `json:"port,omitempty" v-create:"required" v-update:"required"` BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` }
InputSyslogTCPAttrs represents SyslogTCP Input's attributes.
func (InputSyslogTCPAttrs) InputType ¶
func (attrs InputSyslogTCPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputSyslogUDPAttrs ¶
type InputSyslogUDPAttrs struct { BindAddress string `json:"bind_address,omitempty" v-create:"required" v-update:"required"` Port int `json:"port,omitempty" v-create:"required" v-update:"required"` RecvBufferSize int `json:"recv_buffer_size,omitempty" v-create:"required" v-update:"required"` TCPKeepAlive bool `json:"tcp_keepalive"` TLSEnable bool `json:"tls_enable"` ThrottlingAllowed bool `json:"throttling_allowed"` EnableCORS bool `json:"enable_cors"` UseNullDelimiter bool `json:"use_null_delimiter"` ExchangeBind bool `json:"exchange_bind"` ForceRDNS bool `json:"force_rdns"` StoreFullMessage bool `json:"store_full_message"` ExpandStructuredData bool `json:"expand_structured_data"` AllowOverrideDate bool `json:"allow_override_date"` RequeueInvalidMessages bool `json:"requeue_invalid_messages"` UseFullNames bool `json:"use_full_names"` TLS bool `json:"tls"` }
InputSyslogUDPAttrs represents SyslogUDP Input's attributes.
func (InputSyslogUDPAttrs) InputType ¶
func (attrs InputSyslogUDPAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputUnknownAttrs ¶
type InputUnknownAttrs struct { Data map[string]interface{} // contains filtered or unexported fields }
InputUnknownAttrs represents unknown type's Input Attrs.
func (InputUnknownAttrs) InputType ¶
func (attrs InputUnknownAttrs) InputType() string
InputType is the implementation of the InputAttrs interface.
type InputUpdateParams ¶
type InputUpdateParams struct { ID string `json:"id,omitempty" v-update:"required,objectid"` Title string `json:"title,omitempty" v-update:"required"` Type string `json:"type,omitempty" v-update:"required"` Attrs InputAttrs `json:"attributes,omitempty" v-update:"required"` Global *bool `json:"global,omitempty"` Node string `json:"node,omitempty"` }
InputUpdateParams represents Graylog Input update API's parameter.
type InputUpdateParamsData ¶
type InputUpdateParamsData struct { ID string `json:"id,omitempty"` Title string `json:"title,omitempty"` Type string `json:"type,omitempty"` Node string `json:"node,omitempty"` Global *bool `json:"global,omitempty"` Attrs map[string]interface{} `json:"attributes,omitempty"` }
InputUpdateParamsData represents InputUpdateParams's data. This is used for data conversion of InputUpdateParams. ex. json.Unmarshal
func (*InputUpdateParamsData) ToInputUpdateParams ¶
func (d *InputUpdateParamsData) ToInputUpdateParams(input *InputUpdateParams) error
ToInputUpdateParams copies InputUpdateParamsData's data to InputUpdateParams.
type InputsBody ¶
InputsBody represents Get Inputs API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type LDAPSetting ¶
type LDAPSetting struct { Enabled bool `json:"enabled"` UseStartTLS bool `json:"use_start_tls"` TrustAllCertificates bool `json:"trust_all_certificates"` ActiveDirectory bool `json:"active_directory"` SystemUsername string `json:"system_username" v-create:"required" v-update:"required"` SystemPassword string `json:"system_password" v-create:"required" v-update:"required"` LDAPURI string `json:"ldap_uri" v-create:"required" v-update:"required"` SearchBase string `json:"search_base" v-create:"required" v-update:"required"` SearchPattern string `json:"search_pattern" v-create:"required" v-update:"required"` DisplayNameAttribute string `json:"display_name_attribute" v-create:"required" v-update:"required"` DefaultGroup string `json:"default_group" v-create:"required" v-update:"required"` GroupSearchBase string `json:"group_search_base,omitempty"` GroupIDAttribute string `json:"group_id_attribute,omitempty"` GroupSearchPattern string `json:"group_search_pattern,omitempty"` GroupMapping map[string]string `json:"group_mapping,omitempty"` AdditionalDefaultGroups set.StrSet `json:"additional_default_groups,omitempty"` }
LDAPSetting represents a ldap settings.
type MessageCountAlertConditionParameters ¶
type MessageCountAlertConditionParameters struct { Grace int `json:"grace"` Backlog int `json:"backlog"` Threshold int `json:"threshold"` Time int `json:"time"` RepeatNotifications bool `json:"repeat_notifications"` Query string `json:"query,omitempty"` ThresholdType string `json:"threshold_type,omitempty" v-create:"required"` }
MessageCountAlertConditionParameters represents Field Aggregation Alert Condition's parameters.
func (MessageCountAlertConditionParameters) AlertConditionType ¶
func (p MessageCountAlertConditionParameters) AlertConditionType() string
AlertConditionType returns an alert condition type.
type NewInputAttrs ¶
type NewInputAttrs func() InputAttrs
NewInputAttrs is the constructor of InputAttrs.
type Output ¶
type Output struct { ID string `json:"id,omitempty"` Title string `json:"title"` Type string `json:"type"` CreatorUserID string `json:"creator_user_id,omitempty"` CreatedAt string `json:"created_at,omitempty"` Configuration interface{} `json:"configuration"` }
Output represents an output.
type OutputsBody ¶ added in v8.2.0
OutputsBody represents Get Outputs API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Pipeline ¶
type Pipeline struct { // required Source string `json:"source,omitempty" v-create:"required" v-update:"required"` ID string `json:"id,omitempty" v-create:"isdefault" v-update:"required"` Title string `json:"title,omitempty"` Stages []PipelineStage `json:"stages"` Description string `json:"description,omitempty"` }
Pipeline represents a Graylog's Pipeline. https://docs.graylog.org/en/latest/pages/pipelines/pipelines.html
type PipelineConnection ¶
type PipelineConnection struct { ID string `json:"id"` StreamID string `json:"stream_id"` PipelineIDs []string `json:"pipeline_ids"` }
PipelineConnection is a pipeline connection.
type PipelineRule ¶
type PipelineRule struct { // required Source string `json:"source,omitempty" v-create:"required" v-update:"required"` ID string `json:"id,omitempty" v-create:"isdefault" v-update:"required"` // Note that title is ignored in create and update API. Title string `json:"title,omitempty"` Description string `json:"description,omitempty"` }
PipelineRule represents a Graylog's Pipeline Rule. https://docs.graylog.org/en/latest/pages/pipelines/rules.html
type PipelineStage ¶
type PipelineStage struct { Stage int `json:"stage"` MatchAll bool `json:"match_all"` Rules []string `json:"rules"` }
PipelineStage is a stage of pipelines.
type Preferences ¶
type Preferences struct { UpdateUnfocussed bool `json:"updateUnfocussed"` EnableSmartSearch bool `json:"enableSmartSearch"` }
Preferences represents user's preferences.
type RetentionStrategy ¶
type RetentionStrategy struct { // ex. "org.graylog2.indexer.retention.strategies.DeletionRetentionStrategyConfig" Type string `json:"type,omitempty"` // ex. 20 MaxNumberOfIndices int `json:"max_number_of_indices,omitempty"` }
RetentionStrategy represents a Graylog's Index Set Retention Strategy.
func NewClosingRetentionStrategy ¶
func NewClosingRetentionStrategy(num int) *RetentionStrategy
NewClosingRetentionStrategy returns a new closing RetentionStrategy.
func NewDeletionRetentionStrategy ¶
func NewDeletionRetentionStrategy(num int) *RetentionStrategy
NewDeletionRetentionStrategy returns a new deletion RetentionStrategy.
func NewNoopRetentionStrategy ¶
func NewNoopRetentionStrategy(num int) *RetentionStrategy
NewNoopRetentionStrategy returns a new noop RetentionStrategy.
type Role ¶
type Role struct { Name string `json:"name,omitempty" v-create:"required" v-update:"required"` Description string `json:"description,omitempty"` // ex. ["clusterconfigentry:read", "users:edit"] Permissions set.StrSet `json:"permissions,omitempty" v-create:"required" v-update:"required"` ReadOnly bool `json:"read_only"` }
Role represents a role.
func (*Role) NewUpdateParams ¶
func (role *Role) NewUpdateParams() *RoleUpdateParams
NewUpdateParams returns Update Role API's parameters.
type RoleUpdateParams ¶
type RoleUpdateParams struct { Name string `json:"name,omitempty" v-create:"required" v-update:"required"` Description *string `json:"description,omitempty"` // ex. ["clusterconfigentry:read", "users:edit"] Permissions set.StrSet `json:"permissions,omitempty" v-create:"required" v-update:"required"` }
RoleUpdateParams represents Update Role API's parameters.
type RolesBody ¶
RolesBody represents Get Roles API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type RotationStrategy ¶
type RotationStrategy struct { // ex. "org.graylog2.indexer.rotation.strategies.MessageCountRotationStrategyConfig" Type string `json:"type,omitempty"` // ex. 20000000 // Maximum number of documents in an index before it gets rotated MaxDocsPerIndex int `json:"max_docs_per_index,omitempty"` // time based // How long an index gets written to before it is rotated. (i.e. "P1D" for 1 day, "PT6H" for 6 hours) RotationPeriod string `json:"rotation_period,omitempty"` // size based // Maximum size of an index before it gets rotated MaxSize int `json:"max_size,omitempty"` }
RotationStrategy represents a Graylog's Index Set Rotation Strategy.
func NewMessageCountRotationStrategy ¶
func NewMessageCountRotationStrategy(count int) *RotationStrategy
NewMessageCountRotationStrategy returns a new message count based RotationStrategy.
func NewSizeBasedRotationStrategy ¶
func NewSizeBasedRotationStrategy(size int) *RotationStrategy
NewSizeBasedRotationStrategy returns a new size based RotationStrategy.
func NewTimeBasedRotationStrategy ¶
func NewTimeBasedRotationStrategy(period string) *RotationStrategy
NewTimeBasedRotationStrategy returns a new time based RotationStrategy.
type SlackAlarmCallbackConfiguration ¶
type SlackAlarmCallbackConfiguration struct { Color string `json:"color" v-create:"required"` WebhookURL string `json:"webhook_url" v-create:"required"` Channel string `json:"channel" v-create:"required"` IconURL string `json:"icon_url,omitempty"` Graylog2URL string `json:"graylog2_url,omitempty"` IconEmoji string `json:"icon_emoji,omitempty"` UserName string `json:"user_name,omitempty"` ProxyAddress string `json:"proxy_address,omitempty"` CustomMessage string `json:"custom_message,omitempty"` BacklogItems int `json:"backlog_items,omitempty"` LinkNames bool `json:"link_names"` NotifyChannel bool `json:"notify_channel"` }
SlackAlarmCallbackConfiguration represents a configuration of SlackAlarmCallback. Note that SlackAlarmCallback is a third party plugin and not an official alarm callback. https://github.com/graylog-labs/graylog-plugin-slack
func (*SlackAlarmCallbackConfiguration) AlarmCallbackType ¶
func (ac *SlackAlarmCallbackConfiguration) AlarmCallbackType() string
AlarmCallbackType returns an alarm callback type.
type Stream ¶
type Stream struct { ID string `json:"id,omitempty" v-create:"isdefault" v-update:"required,objectid"` Title string `json:"title,omitempty" v-create:"required"` IndexSetID string `json:"index_set_id,omitempty" v-create:"required"` // ex. "2018-02-20T11:37:19.371Z" CreatedAt string `json:"created_at,omitempty" v-create:"isdefault"` // ex. local:admin CreatorUserID string `json:"creator_user_id,omitempty" v-create:"isdefault"` Description string `json:"description,omitempty"` // ex. "AND" MatchingType string `json:"matching_type,omitempty"` Outputs []Output `json:"outputs,omitempty" v-create:"isdefault"` Rules []StreamRule `json:"rules,omitempty"` AlertConditions []AlertCondition `json:"alert_conditions,omitempty" v-create:"isdefault"` AlertReceivers *AlertReceivers `json:"alert_receivers,omitempty" v-create:"isdefault"` // disabled and is_default must be "omitempty". Without "omitempty", it is failed to create an Stream. Disabled bool `json:"disabled,omitempty" v-create:"isdefault"` RemoveMatchesFromDefaultStream bool `json:"remove_matches_from_default_stream"` IsDefault bool `json:"is_default,omitempty" v-create:"isdefault"` }
Stream represents a steram.
func (*Stream) NewUpdateParams ¶
func (stream *Stream) NewUpdateParams() *StreamUpdateParams
NewUpdateParams converts Stream to StreamUpdateParams.
type StreamRule ¶
type StreamRule struct { ID string `json:"id,omitempty" v-create:"isdefault"` StreamID string `json:"stream_id,omitempty" v-create:"required"` Field string `json:"field,omitempty" v-create:"required"` Value string `json:"value,omitempty" v-create:"required"` Description string `json:"description,omitempty"` Type int `json:"type,omitempty"` Inverted bool `json:"inverted"` }
StreamRule represents a stream rule.
func (*StreamRule) NewUpdateParams ¶
func (rule *StreamRule) NewUpdateParams() *StreamRuleUpdateParams
NewUpdateParams converts StreamRule to StreamRuleUpdateParams.
type StreamRuleType ¶
type StreamRuleType struct { ID int `json:"id"` Name string `json:"name"` ShortDesc string `json:"short_desc"` LongDesc string `json:"long_desc"` }
StreamRuleType represents a stream rule type.
type StreamRuleUpdateParams ¶
type StreamRuleUpdateParams struct { ID string `json:"id,omitempty" v-update:"required,objectid"` StreamID string `json:"stream_id,omitempty" v-update:"required,objectid"` Field string `json:"field,omitempty" v-update:"required"` Value string `json:"value,omitempty" v-update:"required"` Description string `json:"description,omitempty"` Type *int `json:"type,omitempty"` Inverted *bool `json:"inverted,omitempty"` }
StreamRuleUpdateParams represents Update Stream API's paramteres.
type StreamRulesBody ¶
type StreamRulesBody struct { Total int `json:"total"` StreamRules []StreamRule `json:"stream_rules"` }
StreamRulesBody represents Get stream rules API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type StreamUpdateParams ¶
type StreamUpdateParams struct { ID string `json:"id,omitempty" v-update:"required,objectid"` Title string `json:"title,omitempty"` IndexSetID string `json:"index_set_id,omitempty"` Description string `json:"description,omitempty"` Outputs []Output `json:"outputs,omitempty"` MatchingType string `json:"matching_type,omitempty"` Rules []StreamRule `json:"rules,omitempty"` AlertConditions []AlertCondition `json:"alert_conditions,omitempty"` AlertReceivers *AlertReceivers `json:"alert_receivers,omitempty"` RemoveMatchesFromDefaultStream *bool `json:"remove_matches_from_default_stream,omitempty"` }
StreamUpdateParams represents a steram update params.
type StreamsBody ¶
type StreamsBody struct { Total int `json:"total,omitempty"` Streams []Stream `json:"streams,omitempty"` }
StreamsBody represents Get Streams API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Timerange ¶
type Timerange struct { Type string `json:"type" v-create:"required"` Range int `json:"range" v-create:"required"` }
Timerange represents a timerange.
type User ¶
type User struct { // a unique user name used to log in with. // ex. "local:admin" Username string `json:"username,omitempty" v-create:"required" v-update:"required"` // the contact email address Email string `json:"email,omitempty" v-create:"required"` // a descriptive name for this account, e.g. the full name. FullName string `json:"full_name,omitempty" v-create:"required"` Password string `json:"password,omitempty" v-create:"required"` ID string `json:"id,omitempty"` // the timezone to use to display times, or leave it as it is to use the system's default. // ex. "UTC" Timezone string `json:"timezone,omitempty"` // ex. "2018-03-02T06:32:01.841+0000" LastActivity string `json:"last_activity,omitempty"` // ex. "192.168.192.1" ClientAddress string `json:"client_address,omitempty"` // Session automatically end after this amount of time, unless they are actively used. // ex. 28800000 SessionTimeoutMs int `json:"session_timeout_ms,omitempty"` External bool `json:"external"` ReadOnly bool `json:"read_only"` SessionActive bool `json:"session_active"` Preferences *Preferences `json:"preferences,omitempty"` Startpage *Startpage `json:"startpage,omitempty"` // Assign the relevant roles to this user to grant them access to the relevant streams and dashboards. // The Reader role grants basic access to the system and will be enabled. // The Admin role grants access to everything in Graylog. // ex. ["Admin"] Roles set.StrSet `json:"roles,omitempty"` Permissions set.StrSet `json:"permissions" v-create:"required"` }
User represents a user.
func (*User) NewUpdateParams ¶
func (user *User) NewUpdateParams() *UserUpdateParams
NewUpdateParams returns Update User API's parameters.
func (*User) SetDefaultValues ¶
func (user *User) SetDefaultValues()
SetDefaultValues sets default values.
type UserUpdateParams ¶
type UserUpdateParams struct { Username string `json:"username,omitempty" v-update:"required"` Email *string `json:"email,omitempty"` FullName *string `json:"full_name,omitempty"` Password *string `json:"password,omitempty"` Timezone *string `json:"timezone,omitempty"` SessionTimeoutMs *int `json:"session_timeout_ms,omitempty"` Permissions set.StrSet `json:"permissions,omitempty"` Startpage *Startpage `json:"startpage,omitempty"` Roles set.StrSet `json:"roles,omitempty"` }
UserUpdateParams represents a user update API's parameter.
type UsersBody ¶
type UsersBody struct {
Users []User `json:"users"`
}
UsersBody represents Get Users API's response body. Basically users don't use this struct, but this struct is public because some sub packages use this struct.
type Widget ¶
type Widget struct { // ex. "STREAM_SEARCH_RESULT_COUNT" Description string `json:"description,omitempty" v-create:"required"` CreatorUserID string `json:"creator_user_id,omitempty" v-create:"isdefault"` ID string `json:"id,omitempty" v-create:"isdefault"` CacheTime *int `json:"cache_time,omitempty" v-create:"isdefault"` Config WidgetConfig `json:"config,omitempty" v-create:"required"` }
Widget represents a Graylog's Dashboard Widget.
func (*Widget) MarshalJSON ¶
func (*Widget) UnmarshalJSON ¶
type WidgetConfig ¶
type WidgetConfig interface {
Type() string
}
WidgetConfig represents a Graylog's Dashboard Widget configuration.
type WidgetConfigFieldChart ¶
type WidgetConfigFieldChart struct { Timerange *Timerange `json:"timerange"` StreamID string `json:"stream_id,omitempty"` Query string `json:"query"` Interval string `json:"interval,omitempty"` ValueType string `json:"valuetype,omitempty"` Renderer string `json:"renderer,omitempty"` Interpolation string `json:"interpolation,omitempty"` RangeType string `json:"rangeType,omitempty"` Field string `json:"field,omitempty"` Relative int `json:"relative,omitempty"` }
func (*WidgetConfigFieldChart) Type ¶
func (cfg *WidgetConfigFieldChart) Type() string
type WidgetConfigQuickValues ¶
type WidgetConfigQuickValues struct { Timerange *Timerange `json:"timerange" v-create:"required"` StreamID string `json:"stream_id,omitempty" v-create:"isdefault"` Query string `json:"query" v-create:"isdefault"` Interval string `json:"interval,omitempty"` Field string `json:"field,omitempty"` SortOrder string `json:"sort_order,omitempty"` StackedFields string `json:"stacked_fields,omitempty"` ShowDataTable bool `json:"show_data_table"` ShowPieChart bool `json:"show_pie_chart"` Limit int `json:"limit,omitempty"` DataTableLimit int `json:"data_table_limit,omitempty"` }
func (*WidgetConfigQuickValues) Type ¶
func (cfg *WidgetConfigQuickValues) Type() string
type WidgetConfigQuickValuesHistogram ¶
type WidgetConfigQuickValuesHistogram struct { Timerange *Timerange `json:"timerange" v-create:"required"` StreamID string `json:"stream_id,omitempty" v-create:"isdefault"` Query string `json:"query" v-create:"isdefault"` Field string `json:"field,omitempty"` SortOrder string `json:"sort_order,omitempty"` StackedFields string `json:"stacked_fields,omitempty"` Limit int `json:"limit,omitempty"` }
func (*WidgetConfigQuickValuesHistogram) Type ¶
func (cfg *WidgetConfigQuickValuesHistogram) Type() string
type WidgetConfigSearchResultChart ¶
type WidgetConfigSearchResultChart struct { Timerange *Timerange `json:"timerange" v-create:"required"` StreamID string `json:"stream_id,omitempty" v-create:"isdefault"` Query string `json:"query" v-create:"isdefault"` Interval string `json:"interval,omitempty"` }
func (*WidgetConfigSearchResultChart) Type ¶
func (cfg *WidgetConfigSearchResultChart) Type() string
type WidgetConfigStatsCount ¶
type WidgetConfigStatsCount struct { Timerange *Timerange `json:"timerange"` StreamID string `json:"stream_id,omitempty"` Query string `json:"query"` Field string `json:"field,omitempty"` StatsFunction string `json:"stats_function,omitempty"` LowerIsBetter bool `json:"lower_is_better"` Trend bool `json:"trend"` }
func (*WidgetConfigStatsCount) Type ¶
func (cfg *WidgetConfigStatsCount) Type() string
type WidgetConfigStreamSearchResultCount ¶
type WidgetConfigStreamSearchResultCount struct { Timerange *Timerange `json:"timerange" v-create:"required"` StreamID string `json:"stream_id,omitempty" v-create:"isdefault"` Query string `json:"query" v-create:"isdefault"` LowerIsBetter bool `json:"lower_is_better"` Trend bool `json:"trend"` }
func (*WidgetConfigStreamSearchResultCount) Type ¶
func (cfg *WidgetConfigStreamSearchResultCount) Type() string
type WidgetConfigUnknownType ¶
func (*WidgetConfigUnknownType) Type ¶
func (cfg *WidgetConfigUnknownType) Type() string
func (*WidgetConfigUnknownType) UnmarshalJSON ¶
func (cfg *WidgetConfigUnknownType) UnmarshalJSON(b []byte) error
Source Files ¶
- alarm_callback.go
- alert.go
- alert_condition.go
- collector_configuration.go
- dashboard.go
- dashboard_widget.go
- doc.go
- event_definition.go
- event_notification.go
- extractor.go
- grok_pattern.go
- index_set.go
- index_set_stats.go
- input.go
- input_attrs.go
- input_aws_flow_logs.go
- input_aws_logs.go
- input_beats.go
- input_cef_amqp.go
- input_cef_kafka.go
- input_cef_tcp.go
- input_cef_udp.go
- input_cloud_trail.go
- input_data.go
- input_fake_http_message.go
- input_gelf_amqp.go
- input_gelf_http.go
- input_gelf_kafka.go
- input_gelf_tcp.go
- input_gelf_udp.go
- input_json_path.go
- input_net_flow_udp.go
- input_raw_amqp.go
- input_raw_kafka.go
- input_syslog_amqp.go
- input_syslog_kafka.go
- input_syslog_tcp.go
- input_syslog_udp.go
- input_unknown_attrs.go
- ldap_setting.go
- output.go
- pipeline.go
- pipeline_connection.go
- pipeline_rule.go
- role.go
- stream.go
- stream_rule.go
- user.go
- version.go
Directories ¶
Path | Synopsis |
---|---|
Package client provides Graylog API client.
|
Package client provides Graylog API client. |
endpoint
Package endpoint provides Graylog API endpoints.
|
Package endpoint provides Graylog API endpoints. |
cmd
|
|
graylog
Package graylog provides the terraform provider for Graylog.
|
Package graylog provides the terraform provider for Graylog. |
Package testutil provides utilities for test.
|
Package testutil provides utilities for test. |
Package validator provides validators for graylog's create and update APIs.
|
Package validator provides validators for graylog's create and update APIs. |