Documentation ¶
Index ¶
- Constants
- Variables
- func AzureBlobStorageFromModel(plan *AzureBlobStorageDestinationModel, ...) (*Destination, diag.Diagnostics)
- func AzureBlobStorageToModel(plan *AzureBlobStorageDestinationModel, component *Destination)
- func BlackholeDestinationFromModel(plan *BlackholeDestinationModel, previousState *BlackholeDestinationModel) (*Destination, diag.Diagnostics)
- func BlackholeDestinationToModel(plan *BlackholeDestinationModel, component *Destination)
- func DatadogLogsDestinationToModel(plan *DatadogLogsDestinationModel, component *Destination)
- func DatadogLogsFromModel(plan *DatadogLogsDestinationModel, previousState *DatadogLogsDestinationModel) (*Destination, diag.Diagnostics)
- func DatadogMetricsDestinationToModel(plan *DatadogMetricsDestinationModel, component *Destination)
- func DatadogMetricsFromModel(plan *DatadogMetricsDestinationModel, ...) (*Destination, diag.Diagnostics)
- func ElasticSearchDestinationFromModel(plan *ElasticSearchDestinationModel, ...) (*Destination, diag.Diagnostics)
- func ElasticSearchDestinationToModel(plan *ElasticSearchDestinationModel, component *Destination)
- func GcpCloudStorageDestinationFromModel(plan *GcpCloudStorageDestinationModel, ...) (*Destination, diag.Diagnostics)
- func GcpCloudStorageDestinationToModel(plan *GcpCloudStorageDestinationModel, component *Destination)
- func HoneycombLogsFromModel(plan *HoneycombLogsDestinationModel, ...) (*Destination, diag.Diagnostics)
- func HoneycombLogsToModel(plan *HoneycombLogsDestinationModel, component *Destination)
- func HttpDestinationFromModel(plan *HttpDestinationModel, previousState *HttpDestinationModel) (*Destination, diag.Diagnostics)
- func HttpDestinationToModel(plan *HttpDestinationModel, component *Destination)
- func KafkaDestinationFromModel(plan *KafkaDestinationModel, previousState *KafkaDestinationModel) (*Destination, diag.Diagnostics)
- func KafkaDestinationToModel(plan *KafkaDestinationModel, component *Destination)
- func LokiDestinationToModel(plan *LokiDestinationModel, component *Destination)
- func LokiFromModel(plan *LokiDestinationModel, previousState *LokiDestinationModel) (*Destination, diag.Diagnostics)
- func MezmoDestinationFromModel(plan *MezmoDestinationModel, previousState *MezmoDestinationModel) (*Destination, diag.Diagnostics)
- func MezmoDestinationToModel(plan *MezmoDestinationModel, component *Destination)
- func NewRelicDestinationFromModel(plan *NewRelicDestinationModel, previousState *NewRelicDestinationModel) (*Destination, diag.Diagnostics)
- func NewRelicDestinationToModel(plan *NewRelicDestinationModel, component *Destination)
- func PrometheusRemoteWriteDestinationFromModel(plan *PrometheusRemoteWriteDestinationModel, ...) (*Destination, diag.Diagnostics)
- func PrometheusRemoteWriteDestinationToModel(plan *PrometheusRemoteWriteDestinationModel, component *Destination)
- func S3DestinationFromModel(plan *S3DestinationModel, previousState *S3DestinationModel) (*Destination, diag.Diagnostics)
- func S3DestinationToModel(plan *S3DestinationModel, component *Destination)
- func SplunkHecLogsDestinationFromModel(plan *SplunkHecLogsDestinationModel, ...) (*Destination, diag.Diagnostics)
- func SplunkHecLogsDestinationToModel(plan *SplunkHecLogsDestinationModel, component *Destination)
- type AzureBlobStorageDestinationModel
- type BlackholeDestinationModel
- type DatadogLogsDestinationModel
- type DatadogMetricsDestinationModel
- type ElasticSearchDestinationModel
- type GcpCloudStorageDestinationModel
- type HoneycombLogsDestinationModel
- type HttpDestinationModel
- type KafkaDestinationModel
- type LokiDestinationModel
- type MezmoDestinationModel
- type NewRelicDestinationModel
- type PrometheusRemoteWriteDestinationModel
- type S3DestinationModel
- type SchemaAttributes
- type SplunkHecLogsDestinationModel
Constants ¶
View Source
const AZURE_BLOB_STORAGE_DESTINATION_NODE_NAME = "azure-blob-storage"
View Source
const AZURE_BLOB_STORAGE_DESTINATION_TYPE_NAME = "azure_blob_storage"
View Source
const BLACKHOLE_DESTINATION_NODE_NAME = "blackhole"
View Source
const BLACKHOLE_DESTINATION_TYPE_NAME = BLACKHOLE_DESTINATION_NODE_NAME
View Source
const DATADOG_LOGS_DESTINATION_NODE_NAME = "datadog-logs"
View Source
const DATADOG_LOGS_DESTINATION_TYPE_NAME = "datadog_logs"
View Source
const DATADOG_METRICS_DESTINATION_NODE_NAME = "datadog-metrics"
View Source
const DATADOG_METRICS_DESTINATION_TYPE_NAME = "datadog_metrics"
View Source
const ELASTICSEARCH_DESTINATION_NODE_NAME = ELASTICSEARCH_DESTINATION_TYPE_NAME
View Source
const ELASTICSEARCH_DESTINATION_TYPE_NAME = "elasticsearch"
View Source
const GCP_CLOUD_STORAGE_DESTINATION_NODE_NAME = "gcp-cloud-storage"
View Source
const GCP_CLOUD_STORAGE_DESTINATION_TYPE_NAME = "gcp_cloud_storage"
View Source
const HONEYCOMB_LOGS_DESTINATION_NODE_NAME = "honeycomb-logs"
View Source
const HONEYCOMB_LOGS_DESTINATION_TYPE_NAME = "honeycomb_logs"
View Source
const HTTP_DESTINATION_NODE_NAME = HTTP_DESTINATION_TYPE_NAME
View Source
const HTTP_DESTINATION_TYPE_NAME = "http"
View Source
const KAFKA_DESTINATION_NODE_NAME = KAFKA_DESTINATION_TYPE_NAME
View Source
const KAFKA_DESTINATION_TYPE_NAME = "kafka"
View Source
const LOKI_DESTINATION_NODE_NAME = "loki"
View Source
const LOKI_DESTINATION_TYPE_NAME = "loki"
View Source
const MEZMO_DESTINATION_NODE_NAME = "mezmo"
View Source
const MEZMO_DESTINATION_TYPE_NAME = "logs"
View Source
const NEWRELIC_DESTINATION_NODE_NAME = "new-relic"
View Source
const NEWRELIC_DESTINATION_TYPE_NAME = "new_relic"
View Source
const PROMETHEUS_REMOTE_WRITE_DESTINATION_NODE_NAME = "prometheus-remote-write"
View Source
const PROMETHEUS_REMOTE_WRITE_DESTINATION_TYPE_NAME = "prometheus_remote_write"
View Source
const S3_DESTINATION_NODE_NAME = S3_DESTINATION_TYPE_NAME
View Source
const S3_DESTINATION_TYPE_NAME = "s3"
View Source
const SPLUNK_HEC_LOGS_DESTINATION_NODE_NAME = "splunk-hec-logs"
View Source
const SPLUNK_HEC_LOGS_DESTINATION_TYPE_NAME = "splunk_hec_logs"
Variables ¶
View Source
var AzureBlobStorageResourceSchema = schema.Schema{ Description: "Publishes events to Azure Blob Storage", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "encoding": schema.StringAttribute{ Optional: true, Computed: true, Description: "The encoding to apply to the data", Default: stringdefault.StaticString("text"), Validators: []validator.String{stringvalidator.OneOf("json", "text")}, }, "compression": schema.StringAttribute{ Optional: true, Computed: true, Description: "The compression strategy used on the encoded data prior to sending", Default: stringdefault.StaticString("none"), Validators: []validator.String{stringvalidator.OneOf("gzip", "none")}, }, "container_name": schema.StringAttribute{ Required: true, Description: "The name of the container for blob storage", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "connection_string": schema.StringAttribute{ Required: true, Sensitive: true, Description: "A connection string for the account that contains an access key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "prefix": schema.StringAttribute{ Optional: true, Description: "A prefix to be applied to all object keys", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, []string{"batch_timeout_secs"}), }
View Source
var BlackholeDestinationResourceSchema = schema.Schema{ Description: "Represents a blackhole destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{}, nil), }
View Source
var DatadogLogsDestinationResourceSchema = schema.Schema{ Description: "Publishes log events to Datadog", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "api_key": schema.StringAttribute{ Sensitive: true, Required: true, Description: "Datadog logs application API key.", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "site": schema.StringAttribute{ Required: true, Description: "The Datadog site (region) to send logs to.", Validators: []validator.String{stringvalidator.OneOf("us1", "us3", "us5", "eu1")}, }, "compression": schema.StringAttribute{ Required: true, Description: "The compression strategy used on the encoded data prior to sending..", Validators: []validator.String{stringvalidator.OneOf("none", "gzip")}, }, }, nil), }
View Source
var DatadogMetricsDestinationResourceSchema = schema.Schema{ Description: "Publishes metric events to Datadog", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "api_key": schema.StringAttribute{ Sensitive: true, Required: true, Description: "Datadog metrics application API key.", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "site": schema.StringAttribute{ Required: true, Description: "The Datadog site (region) to send metrics to.", Validators: []validator.String{stringvalidator.OneOf("us1", "us3", "us5", "eu1")}, }, }, nil), }
View Source
var ElasticSearchDestinationResourceSchema = schema.Schema{ Description: "Represents an ElasticSearch destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "compression": schema.StringAttribute{ Optional: true, Computed: true, Description: "The compression strategy used on the encoded data prior to sending", Default: stringdefault.StaticString("none"), Validators: []validator.String{stringvalidator.OneOf("gzip", "none")}, }, "auth": schema.SingleNestedAttribute{ Required: true, Description: "Configures ES authentication", Attributes: map[string]schema.Attribute{ "strategy": schema.StringAttribute{ Required: true, Description: "The ES authentication strategy to use", Validators: []validator.String{stringvalidator.OneOf("basic", "aws")}, }, "user": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The username for basic authentication", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "password": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The password to use for basic authentication", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "access_key_id": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The AWS access key id", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "secret_access_key": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The AWS secret access key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "region": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The AWS Region", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, }, "endpoints": schema.ListAttribute{ ElementType: StringType, Required: true, Description: "An array of ElasticSearch endpoints", Validators: []validator.List{ listvalidator.ValueStringsAre(stringvalidator.LengthAtLeast(1)), }, }, "pipeline": schema.StringAttribute{ Optional: true, Description: "Name of an ES ingest pipeline to include", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "index": schema.StringAttribute{ Optional: true, Computed: true, Description: "Index to use when writing ES events (default = mezmo-%Y.%m.%d)", Default: stringdefault.StaticString("mezmo-%Y.%m.%d"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, nil), }
View Source
var GcpCloudStorageResourceSchema = schema.Schema{ Description: "Publish log events to GCP Cloud Storage", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "encoding": schema.StringAttribute{ Optional: true, Computed: true, Description: "Dictates how the data will be serialized before storing.", Default: stringdefault.StaticString("text"), Validators: []validator.String{ stringvalidator.OneOf("json", "text"), }, }, "bucket": schema.StringAttribute{ Required: true, Description: "The name of the bucket in GCP where the data will be stored.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, "compression": schema.StringAttribute{ Optional: true, Computed: true, Description: "The compression strategy used on the encoded data prior to sending.", Default: stringdefault.StaticString("none"), Validators: []validator.String{ stringvalidator.OneOf("gzip", "none"), }, }, "bucket_prefix": schema.StringAttribute{ Optional: true, Computed: false, Description: "The prefix applied to the bucket name, giving the appearance of having directories.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, "auth": schema.SingleNestedAttribute{ Required: true, Description: "Configure GCP Cloud Storage authentication", Attributes: map[string]schema.Attribute{ "type": schema.StringAttribute{ Required: true, Description: "The type of authentication to use.", Validators: []validator.String{ stringvalidator.OneOf("api_key", "credentials_json"), }, }, "value": schema.StringAttribute{ Required: true, Sensitive: true, Description: "Authentication secret value.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, }, }, }, []string{"batch_timeout_secs"}), }
View Source
var HoneycombLogsResourceSchema = schema.Schema{ Description: "Send log data to Honeycomb", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "api_key": schema.StringAttribute{ Required: true, Sensitive: true, Description: "Honeycomb API key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "dataset": schema.StringAttribute{ Required: true, Description: "The name of the targeted dataset", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, nil), }
View Source
var HttpDestinationResourceSchema = schema.Schema{ Description: "Represents an HTTP destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "uri": schema.StringAttribute{ Required: true, Description: "The full URI to make HTTP requests to. This should include the " + "protocol and host, but can also include the port, path, and any other valid " + "part of a URI.", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "encoding": schema.StringAttribute{ Optional: true, Description: "The encoding to apply to the data", Computed: true, Default: stringdefault.StaticString("text"), Validators: []validator.String{stringvalidator.OneOf("json", "ndjson", "text")}, }, "compression": schema.StringAttribute{ Optional: true, Description: "The compression strategy used on the encoded data prior to sending", Computed: true, Default: stringdefault.StaticString("none"), Validators: []validator.String{stringvalidator.OneOf("gzip", "none")}, }, "auth": schema.SingleNestedAttribute{ Optional: true, Description: "Configures HTTP authentication", Attributes: map[string]schema.Attribute{ "strategy": schema.StringAttribute{ Required: true, Validators: []validator.String{stringvalidator.OneOf("basic", "bearer")}, }, "user": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString(""), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "password": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "token": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, }, "headers": schema.MapAttribute{ Optional: true, Description: "A key/value object describing a header name and its value", ElementType: StringType{}, Validators: []validator.Map{ mapvalidator.All( mapvalidator.KeysAre(stringvalidator.LengthAtLeast(1)), mapvalidator.ValueStringsAre(stringvalidator.LengthAtLeast(1)), ), }, }, }, nil), }
View Source
var KafkaDestinationResourceSchema = schema.Schema{ Description: "Represents a Kafka destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "encoding": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("text"), Description: "The encoding to apply to the data.", Validators: []validator.String{ stringvalidator.OneOf("json", "text"), }, }, "compression": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("none"), Description: "The compression strategy used on the encoded data prior to sending.", Validators: []validator.String{ stringvalidator.OneOf("gzip", "lz4", "snappy", "zstd", "none"), }, }, "event_key_field": schema.StringAttribute{ Optional: true, Description: "The field in the log whose value is used as Kafka's event key.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, "brokers": schema.ListNestedAttribute{ Required: true, Description: "The Kafka brokers to connect to.", NestedObject: schema.NestedAttributeObject{ Attributes: map[string]schema.Attribute{ "host": schema.StringAttribute{ Required: true, Description: "The host of the Kafka broker.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(255), }, }, "port": schema.Int64Attribute{ Required: true, Description: "The port of the Kafka broker.", Validators: []validator.Int64{ int64validator.Between(1, 65535), }, }, }, }, Validators: []validator.List{ listvalidator.UniqueValues(), listvalidator.SizeAtLeast(1), }, }, "topic": schema.StringAttribute{ Required: true, Description: "The name of the topic to publish to.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, "tls_enabled": schema.BoolAttribute{ Optional: true, Computed: true, Default: booldefault.StaticBool(true), Description: "Whether to use TLS when connecting to Kafka.", }, "sasl": schema.SingleNestedAttribute{ Optional: true, Description: "The SASL configuration to use when connecting to Kafka.", Attributes: map[string]schema.Attribute{ "mechanism": schema.StringAttribute{ Optional: true, Computed: true, Description: "The SASL mechanism to use when connecting to Kafka.", Validators: []validator.String{ stringvalidator.OneOf("PLAIN", "SCRAM-SHA-256", "SCRAM-SHA-512"), }, }, "username": schema.StringAttribute{ Required: true, Description: "The SASL username to use when connecting to Kafka.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, "password": schema.StringAttribute{ Required: true, Sensitive: true, Description: "The SASL password to use when connecting to Kafka.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), }, }, }, }, }, nil), }
View Source
var LokiDestinationResourceSchema = schema.Schema{ Description: "Publish log events to Loki", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "auth": schema.SingleNestedAttribute{ Required: true, Description: "The authentication strategy to use (only basic supported)", Attributes: map[string]schema.Attribute{ "strategy": schema.StringAttribute{ Required: true, Description: "The authentication strategy to use (only basic supported)", Validators: []validator.String{stringvalidator.OneOf("basic")}, }, "user": schema.StringAttribute{ Required: true, Description: "The basic authentication user", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "password": schema.StringAttribute{ Sensitive: true, Required: true, Description: "The basic authentication password", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, }, "endpoint": schema.StringAttribute{ Required: true, Description: "The Loki base URL", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "encoding": schema.StringAttribute{ Required: true, Description: "Configures how event are encoded", Validators: []validator.String{stringvalidator.OneOf("json", "text")}, }, "path": schema.StringAttribute{ Optional: true, Description: "The path appended to the Loki base URL, (defaults to /loki/api/v1/push)", Computed: true, Default: stringdefault.StaticString("/loki/api/v1/push"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "labels": schema.MapAttribute{ Required: true, ElementType: StringType, Description: "Key/Value pair used to describe Loki data", Validators: []validator.Map{ mapvalidator.All( mapvalidator.KeysAre(stringvalidator.LengthAtLeast(1)), mapvalidator.ValueStringsAre(stringvalidator.LengthAtLeast(1)), ), }, }, }, nil), }
View Source
var MezmoDestinationResourceSchema = schema.Schema{ Description: "Represents a Mezmo destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "host": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("logs.logdna.com"), Description: "The host for your Log Analysis environment", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "ingestion_key": schema.StringAttribute{ Required: true, Sensitive: true, Description: "Ingestion key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "query": schema.SingleNestedAttribute{ Optional: true, Computed: true, Description: "Query Parameters", Attributes: map[string]schema.Attribute{ "hostname": schema.StringAttribute{ Optional: true, Computed: true, Description: "Hostname string or template to attach to logs", Default: stringdefault.StaticString("mezmo"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "tags": schema.ListAttribute{ ElementType: StringType, Optional: true, Description: "List of tag strings or templates to attach to logs", Validators: []validator.List{ listvalidator.ValueStringsAre(stringvalidator.LengthAtLeast(1)), }, }, "ip": schema.StringAttribute{ Optional: true, Description: "IP address template to attach to logs", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, "mac": schema.StringAttribute{ Optional: true, Description: "MAC address template to attach to logs", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, }, }, "log_construction_scheme": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("explicit"), Description: "How to construct the log message", Validators: []validator.String{ stringvalidator.OneOf(MapKeys(log_construction_schemes)...), }, }, "explicit_scheme_options": schema.SingleNestedAttribute{ Optional: true, Description: "Log construction options for the explicit scheme", Attributes: map[string]schema.Attribute{ "line": schema.StringAttribute{ Optional: true, Description: "Template or field reference to use as the log line. " + "Field reference can point to an object.", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(1024), }, }, "meta_field": schema.StringAttribute{ Optional: true, Description: "Field containing the meta object for the log", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, "app": schema.StringAttribute{ Optional: true, Description: "App name template to attach to logs", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, "file": schema.StringAttribute{ Optional: true, Description: "File name template to attach to logs", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, "timestamp_field": schema.StringAttribute{ Optional: true, Description: "Field containing the timestamp for the log, for example ._ts", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, "env": schema.StringAttribute{ Optional: true, Description: "Environment name template to attach to logs", Validators: []validator.String{ stringvalidator.LengthAtLeast(1), stringvalidator.LengthAtMost(512), }, }, }, }, }, nil), }
View Source
var NewRelicDestinationResourceSchema = schema.Schema{ Description: "Represents a NewRelic destination.", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "api": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("logs"), Description: "New Relic API endpoint type", Validators: []validator.String{stringvalidator.OneOf("logs", "metrics")}, }, "account_id": schema.StringAttribute{ Required: true, Sensitive: true, Description: "New Relic Account ID", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "license_key": schema.StringAttribute{ Required: true, Sensitive: true, Description: "New Relic License Key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, nil), }
View Source
var PrometheusRemoteWriteDestinationResourceSchema = schema.Schema{ Description: "Represents Prometheus remote-write destination that publishes metrics to a " + "Prometheus endpoint", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "endpoint": schema.StringAttribute{ Required: true, Description: "The full URI to make HTTP requests to. This should include the " + "protocol and host, but can also include the port, path, and any other valid " + "part of a URI. Example: http://example.org:8080/api/v1/push", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "auth": schema.SingleNestedAttribute{ Optional: true, Description: "Configures authentication", Attributes: map[string]schema.Attribute{ "strategy": schema.StringAttribute{ Required: true, Description: "The authentication strategy to use", Validators: []validator.String{stringvalidator.OneOf("basic", "bearer")}, }, "user": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The username for basic authentication", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "password": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The password to use for basic authentication", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "token": schema.StringAttribute{ Sensitive: true, Optional: true, Computed: true, Default: stringdefault.StaticString(""), Description: "The token to use for bearer auth strategy", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, }, }, nil), }
View Source
var S3DestinationResourceSchema = schema.Schema{ Description: "Publishes events as objects in AWS S3", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "auth": schema.SingleNestedAttribute{ Required: true, Description: "Configures AWS authentication", Attributes: map[string]schema.Attribute{ "access_key_id": schema.StringAttribute{ Required: true, Description: "The AWS access key id", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "secret_access_key": schema.StringAttribute{ Required: true, Sensitive: true, Description: "The AWS secret access key", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, }, }, "region": schema.StringAttribute{ Required: true, Description: "The name of the AWS region", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "bucket": schema.StringAttribute{ Required: true, Description: "The S3 bucket name. Do not include a leading s3:// or a trailing /", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "prefix": schema.StringAttribute{ Optional: true, Computed: true, Description: "A prefix to apply to all object key names.", Default: stringdefault.StaticString("/"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "encoding": schema.StringAttribute{ Optional: true, Computed: true, Description: "The encoding to apply to the data", Default: stringdefault.StaticString("text"), Validators: []validator.String{stringvalidator.OneOf("json", "ndjson", "text")}, }, "compression": schema.StringAttribute{ Optional: true, Computed: true, Default: stringdefault.StaticString("none"), Description: "The compression format of the S3 objects", Validators: []validator.String{stringvalidator.OneOf([]string{"gzip", "none"}...)}, }, }, []string{"batch_timeout_secs"}), }
View Source
var SplunkHecLogsDestinationResourceSchema = schema.Schema{ Description: "Publishes log events to a Splunk HTTP Event Collector", Attributes: ExtendBaseAttributes(map[string]schema.Attribute{ "compression": schema.StringAttribute{ Optional: true, Computed: true, Description: "The compression strategy used on the encoded data prior to sending", Default: stringdefault.StaticString("none"), Validators: []validator.String{stringvalidator.OneOf("gzip", "none")}, }, "endpoint": schema.StringAttribute{ Required: true, Description: "The base URL for the Splunk instance. The collector path, such as " + "`/services/collector/events`, will be automatically inferred from the " + "destination's configuration.", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "token": schema.StringAttribute{ Required: true, Sensitive: true, Description: "The default token to authenticate to Splunk HEC", Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "tls_verify_certificate": schema.BoolAttribute{ Optional: true, Computed: true, Description: "Verify TLS Certificate", Default: booldefault.StaticBool(true), }, "host_field": schema.StringAttribute{ Optional: true, Computed: true, Description: "The field that contains the hostname to include in the event", Default: stringdefault.StaticString("metadata.host"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "timestamp_field": schema.StringAttribute{ Optional: true, Computed: true, Description: "The field that contains the timestamp to include in the event", Default: stringdefault.StaticString("metadata.time"), Validators: []validator.String{stringvalidator.LengthAtLeast(1)}, }, "source": schema.SingleNestedAttribute{ Optional: true, Description: "The source of events sent to this destination. This is typically the filename " + "the logs originated from. Use the field path \"metadata.source\" to use the" + " upstream source value from a HEC log source", Attributes: splunkValueTypeAttributes, }, "source_type": schema.SingleNestedAttribute{ Optional: true, Description: "The sourcetype of events sent to this destination. Use the field path" + " \"metadata.sourcetype\" to use the upstream sourcetype value from a HEC" + " log source", Attributes: splunkValueTypeAttributes, }, "index": schema.SingleNestedAttribute{ Optional: true, Description: "The name of the index to send events to. Use the field path " + " \"metadata.index\" to use the upstream index value from a HEC log source", Attributes: splunkValueTypeAttributes, }, }, nil), }
Functions ¶
func AzureBlobStorageFromModel ¶
func AzureBlobStorageFromModel(plan *AzureBlobStorageDestinationModel, previousState *AzureBlobStorageDestinationModel) (*Destination, diag.Diagnostics)
func AzureBlobStorageToModel ¶
func AzureBlobStorageToModel(plan *AzureBlobStorageDestinationModel, component *Destination)
func BlackholeDestinationFromModel ¶
func BlackholeDestinationFromModel(plan *BlackholeDestinationModel, previousState *BlackholeDestinationModel) (*Destination, diag.Diagnostics)
func BlackholeDestinationToModel ¶
func BlackholeDestinationToModel(plan *BlackholeDestinationModel, component *Destination)
func DatadogLogsDestinationToModel ¶
func DatadogLogsDestinationToModel(plan *DatadogLogsDestinationModel, component *Destination)
func DatadogLogsFromModel ¶
func DatadogLogsFromModel(plan *DatadogLogsDestinationModel, previousState *DatadogLogsDestinationModel) (*Destination, diag.Diagnostics)
func DatadogMetricsDestinationToModel ¶
func DatadogMetricsDestinationToModel(plan *DatadogMetricsDestinationModel, component *Destination)
func DatadogMetricsFromModel ¶
func DatadogMetricsFromModel(plan *DatadogMetricsDestinationModel, previousState *DatadogMetricsDestinationModel) (*Destination, diag.Diagnostics)
func ElasticSearchDestinationFromModel ¶
func ElasticSearchDestinationFromModel(plan *ElasticSearchDestinationModel, previousState *ElasticSearchDestinationModel) (*Destination, diag.Diagnostics)
func ElasticSearchDestinationToModel ¶
func ElasticSearchDestinationToModel(plan *ElasticSearchDestinationModel, component *Destination)
func GcpCloudStorageDestinationFromModel ¶
func GcpCloudStorageDestinationFromModel(plan *GcpCloudStorageDestinationModel, previousState *GcpCloudStorageDestinationModel) (*Destination, diag.Diagnostics)
func GcpCloudStorageDestinationToModel ¶
func GcpCloudStorageDestinationToModel(plan *GcpCloudStorageDestinationModel, component *Destination)
func HoneycombLogsFromModel ¶
func HoneycombLogsFromModel(plan *HoneycombLogsDestinationModel, previousState *HoneycombLogsDestinationModel) (*Destination, diag.Diagnostics)
func HoneycombLogsToModel ¶
func HoneycombLogsToModel(plan *HoneycombLogsDestinationModel, component *Destination)
func HttpDestinationFromModel ¶
func HttpDestinationFromModel(plan *HttpDestinationModel, previousState *HttpDestinationModel) (*Destination, diag.Diagnostics)
func HttpDestinationToModel ¶
func HttpDestinationToModel(plan *HttpDestinationModel, component *Destination)
func KafkaDestinationFromModel ¶
func KafkaDestinationFromModel(plan *KafkaDestinationModel, previousState *KafkaDestinationModel) (*Destination, diag.Diagnostics)
func KafkaDestinationToModel ¶
func KafkaDestinationToModel(plan *KafkaDestinationModel, component *Destination)
func LokiDestinationToModel ¶
func LokiDestinationToModel(plan *LokiDestinationModel, component *Destination)
func LokiFromModel ¶
func LokiFromModel(plan *LokiDestinationModel, previousState *LokiDestinationModel) (*Destination, diag.Diagnostics)
func MezmoDestinationFromModel ¶
func MezmoDestinationFromModel(plan *MezmoDestinationModel, previousState *MezmoDestinationModel) (*Destination, diag.Diagnostics)
func MezmoDestinationToModel ¶
func MezmoDestinationToModel(plan *MezmoDestinationModel, component *Destination)
func NewRelicDestinationFromModel ¶
func NewRelicDestinationFromModel(plan *NewRelicDestinationModel, previousState *NewRelicDestinationModel) (*Destination, diag.Diagnostics)
func NewRelicDestinationToModel ¶
func NewRelicDestinationToModel(plan *NewRelicDestinationModel, component *Destination)
func PrometheusRemoteWriteDestinationFromModel ¶
func PrometheusRemoteWriteDestinationFromModel(plan *PrometheusRemoteWriteDestinationModel, previousState *PrometheusRemoteWriteDestinationModel) (*Destination, diag.Diagnostics)
func PrometheusRemoteWriteDestinationToModel ¶
func PrometheusRemoteWriteDestinationToModel(plan *PrometheusRemoteWriteDestinationModel, component *Destination)
func S3DestinationFromModel ¶
func S3DestinationFromModel(plan *S3DestinationModel, previousState *S3DestinationModel) (*Destination, diag.Diagnostics)
func S3DestinationToModel ¶
func S3DestinationToModel(plan *S3DestinationModel, component *Destination)
func SplunkHecLogsDestinationFromModel ¶
func SplunkHecLogsDestinationFromModel(plan *SplunkHecLogsDestinationModel, previousState *SplunkHecLogsDestinationModel) (*Destination, diag.Diagnostics)
func SplunkHecLogsDestinationToModel ¶
func SplunkHecLogsDestinationToModel(plan *SplunkHecLogsDestinationModel, component *Destination)
Types ¶
type AzureBlobStorageDestinationModel ¶
type AzureBlobStorageDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` BatchTimeoutSeconds Int64 `tfsdk:"batch_timeout_secs" user_config:"true"` Encoding String `tfsdk:"encoding" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` ContainerName String `tfsdk:"container_name" user_config:"true"` ConnectionString String `tfsdk:"connection_string" user_config:"true"` Prefix String `tfsdk:"prefix" user_config:"true"` }
type BlackholeDestinationModel ¶
type BlackholeDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` }
type DatadogLogsDestinationModel ¶
type DatadogLogsDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` ApiKey String `tfsdk:"api_key" user_config:"true"` Site String `tfsdk:"site" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` }
type DatadogMetricsDestinationModel ¶
type DatadogMetricsDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` ApiKey String `tfsdk:"api_key" user_config:"true"` Site String `tfsdk:"site" user_config:"true"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` }
type ElasticSearchDestinationModel ¶
type ElasticSearchDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` Auth Object `tfsdk:"auth" user_config:"true"` Endpoints List `tfsdk:"endpoints" user_config:"true"` Pipeline String `tfsdk:"pipeline" user_config:"true"` Index String `tfsdk:"index" user_config:"true"` }
type GcpCloudStorageDestinationModel ¶
type GcpCloudStorageDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` Encoding String `tfsdk:"encoding" user_config:"true"` Bucket String `tfsdk:"bucket" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` BucketPrefix String `tfsdk:"bucket_prefix" user_config:"true"` Auth Object `tfsdk:"auth" user_config:"true"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` BatchTimeoutSeconds Int64 `tfsdk:"batch_timeout_secs" user_config:"true"` }
type HoneycombLogsDestinationModel ¶
type HoneycombLogsDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` DataSet String `tfsdk:"dataset" user_config:"true"` ApiKey String `tfsdk:"api_key" user_config:"true"` }
type HttpDestinationModel ¶
type HttpDestinationModel struct { Id StringValue `tfsdk:"id"` PipelineId StringValue `tfsdk:"pipeline_id"` Title StringValue `tfsdk:"title"` Description StringValue `tfsdk:"description"` Inputs ListValue `tfsdk:"inputs"` GenerationId Int64Value `tfsdk:"generation_id"` Uri StringValue `tfsdk:"uri" user_config:"true"` Encoding StringValue `tfsdk:"encoding" user_config:"true"` Compression StringValue `tfsdk:"compression" user_config:"true"` Auth ObjectValue `tfsdk:"auth" user_config:"true"` Headers MapValue `tfsdk:"headers" user_config:"true"` AckEnabled BoolValue `tfsdk:"ack_enabled" user_config:"true"` }
type KafkaDestinationModel ¶
type KafkaDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` Encoding String `tfsdk:"encoding" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` EventKeyField String `tfsdk:"event_key_field" user_config:"true"` Brokers List `tfsdk:"brokers" user_config:"true"` Topic String `tfsdk:"topic" user_config:"true"` TLSEnabled Bool `tfsdk:"tls_enabled" user_config:"true"` SASL Object `tfsdk:"sasl" user_config:"true"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` }
type LokiDestinationModel ¶
type LokiDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` GenerationId Int64 `tfsdk:"generation_id"` Endpoint String `tfsdk:"endpoint" user_config:"true"` Path String `tfsdk:"path" user_config:"true"` Encoding String `tfsdk:"encoding" user_config:"true"` Auth Object `tfsdk:"auth" user_config:"true"` Labels Map `tfsdk:"labels" user_config:"true"` Inputs List `tfsdk:"inputs" user_config:"true"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` }
type MezmoDestinationModel ¶
type MezmoDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` Host String `tfsdk:"host" user_config:"true"` IngestionKey String `tfsdk:"ingestion_key" user_config:"true"` Query Object `tfsdk:"query" user_config:"true"` LogConstructionScheme String `tfsdk:"log_construction_scheme" user_config:"true"` ExplicitSchemeOptions Object `tfsdk:"explicit_scheme_options" user_config:"true"` }
type NewRelicDestinationModel ¶
type NewRelicDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` Api String `tfsdk:"api" user_config:"true"` AccountId String `tfsdk:"account_id" user_config:"true"` LicenseKey String `tfsdk:"license_key" user_config:"true"` }
type PrometheusRemoteWriteDestinationModel ¶
type PrometheusRemoteWriteDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` Endpoint String `tfsdk:"endpoint" user_config:"true"` Auth Object `tfsdk:"auth" user_config:"true"` }
type S3DestinationModel ¶
type S3DestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` BatchTimeoutSeconds Int64 `tfsdk:"batch_timeout_secs" user_config:"true"` Auth Object `tfsdk:"auth" user_config:"true"` Region String `tfsdk:"region" user_config:"true"` Bucket String `tfsdk:"bucket" user_config:"true"` Prefix String `tfsdk:"prefix" user_config:"true"` Encoding String `tfsdk:"encoding" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` }
type SchemaAttributes ¶
func ExtendBaseAttributes ¶
func ExtendBaseAttributes(target SchemaAttributes, addons []string) SchemaAttributes
type SplunkHecLogsDestinationModel ¶
type SplunkHecLogsDestinationModel struct { Id String `tfsdk:"id"` PipelineId String `tfsdk:"pipeline_id"` Title String `tfsdk:"title"` Description String `tfsdk:"description"` Inputs List `tfsdk:"inputs"` GenerationId Int64 `tfsdk:"generation_id"` AckEnabled Bool `tfsdk:"ack_enabled" user_config:"true"` Compression String `tfsdk:"compression" user_config:"true"` Endpoint String `tfsdk:"endpoint" user_config:"true"` Token String `tfsdk:"token" user_config:"true"` HostField String `tfsdk:"host_field" user_config:"true"` TimestampField String `tfsdk:"timestamp_field" user_config:"true"` TlsVerifyCertificate Bool `tfsdk:"tls_verify_certificate" user_config:"true"` Source Object `tfsdk:"source" user_config:"true"` SourceType Object `tfsdk:"source_type" user_config:"true"` Index Object `tfsdk:"index" user_config:"true"` }
Source Files ¶
Click to show internal directories.
Click to hide internal directories.