Class: Google::Apis::LoggingV2beta1::LogSink

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
generated/google/apis/logging_v2beta1/classes.rb,
generated/google/apis/logging_v2beta1/representations.rb,
generated/google/apis/logging_v2beta1/representations.rb

Overview

Describes a sink used to export log entries to one of the following destinations in any project: a Cloud Storage bucket, a BigQuery dataset, or a Cloud Pub/Sub topic. A logs filter controls which log entries are exported. The sink must be created within a project, organization, billing account, or folder.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Core::JsonObjectSupport

#to_json

Methods included from Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ LogSink

Returns a new instance of LogSink



1040
1041
1042
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1040

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#destinationString

Required. The export destination: "storage.googleapis.com/[GCS_BUCKET]" "bigquery.googleapis.com/projects/[PROJECT_ID]/datasets/[DATASET]" "pubsub.googleapis.com/projects/[PROJECT_ID]/topics/[TOPIC_ID]" The sink's writer_identity, set when the sink is created, must have permission to write to the destination or else the log entries are not exported. For more information, see Exporting Logs With Sinks. Corresponds to the JSON property destination

Returns:

  • (String)


977
978
979
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 977

def destination
  @destination
end

#end_timeString

Deprecated. This field is ignored when creating or updating sinks. Corresponds to the JSON property endTime

Returns:

  • (String)


982
983
984
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 982

def end_time
  @end_time
end

#filterString

Optional. An advanced logs filter. The only exported log entries are those that are in the resource owning the sink and that match the filter. For example: logName="projects/[PROJECT_ID]/logs/[LOG_ID]" AND severity>=ERROR Corresponds to the JSON property filter

Returns:

  • (String)


990
991
992
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 990

def filter
  @filter
end

#include_childrenBoolean Also known as: include_children?

Optional. This field applies only to sinks owned by organizations and folders. If the field is false, the default, only the logs owned by the sink's parent resource are available for export. If the field is true, then logs from all the projects, folders, and billing accounts contained in the sink's parent resource are also available for export. Whether a particular log entry from the children is exported depends on the sink's filter expression. For example, if this field is true, then the filter resource.type=gce_instance would export all Compute Engine VM instance log entries from all projects in the sink's parent. To only export entries from certain child projects, filter on the project part of the log name: logName:("projects/test-project1/" OR "projects/test-project2/") AND resource.type=gce_instance Corresponds to the JSON property includeChildren

Returns:

  • (Boolean)


1006
1007
1008
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1006

def include_children
  @include_children
end

#nameString

Required. The client-assigned sink identifier, unique within the project. Example: "my-syslog-errors-to-pubsub". Sink identifiers are limited to 100 characters and can include only the following characters: upper and lower-case alphanumeric characters, underscores, hyphens, and periods. Corresponds to the JSON property name

Returns:

  • (String)


1015
1016
1017
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1015

def name
  @name
end

#output_version_formatString

Deprecated. The log entry format to use for this sink's exported log entries. The v2 format is used by default and cannot be changed. Corresponds to the JSON property outputVersionFormat

Returns:

  • (String)


1021
1022
1023
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1021

def output_version_format
  @output_version_format
end

#start_timeString

Deprecated. This field is ignored when creating or updating sinks. Corresponds to the JSON property startTime

Returns:

  • (String)


1026
1027
1028
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1026

def start_time
  @start_time
end

#writer_identityString

Output only. An IAM identity—a service account or group—under which Stackdriver Logging writes the exported log entries to the sink's destination. This field is set by sinks.create and sinks.update, based on the setting of unique_writer_identity in those methods.Until you grant this identity write-access to the destination, log entry exports from this sink will fail. For more information, see Granting access for a resource. Consult the destination service's documentation to determine the appropriate IAM roles to assign to the identity. Corresponds to the JSON property writerIdentity

Returns:

  • (String)


1038
1039
1040
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1038

def writer_identity
  @writer_identity
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
# File 'generated/google/apis/logging_v2beta1/classes.rb', line 1045

def update!(**args)
  @destination = args[:destination] if args.key?(:destination)
  @end_time = args[:end_time] if args.key?(:end_time)
  @filter = args[:filter] if args.key?(:filter)
  @include_children = args[:include_children] if args.key?(:include_children)
  @name = args[:name] if args.key?(:name)
  @output_version_format = args[:output_version_format] if args.key?(:output_version_format)
  @start_time = args[:start_time] if args.key?(:start_time)
  @writer_identity = args[:writer_identity] if args.key?(:writer_identity)
end