Class: Google::Apis::LoggingV2::LogSink
- Inherits:
-
Object
- Object
- Google::Apis::LoggingV2::LogSink
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/logging_v2/classes.rb,
lib/google/apis/logging_v2/representations.rb,
lib/google/apis/logging_v2/representations.rb
Overview
Describes a sink used to export log entries to one of the following destinations: a Cloud Logging log bucket, a Cloud Storage bucket, a BigQuery dataset, a Pub/Sub topic, a Cloud project.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
-
#bigquery_options ⇒ Google::Apis::LoggingV2::BigQueryOptions
Options that change functionality of a sink exporting data to BigQuery.
-
#create_time ⇒ String
Output only.
-
#description ⇒ String
Optional.
-
#destination ⇒ String
Required.
-
#disabled ⇒ Boolean
(also: #disabled?)
Optional.
-
#exclusions ⇒ Array<Google::Apis::LoggingV2::LogExclusion>
Optional.
-
#filter ⇒ String
Optional.
-
#include_children ⇒ Boolean
(also: #include_children?)
Optional.
-
#intercept_children ⇒ Boolean
(also: #intercept_children?)
Optional.
-
#name ⇒ String
Output only.
-
#output_version_format ⇒ String
Deprecated.
-
#resource_name ⇒ String
Output only.
-
#update_time ⇒ String
Output only.
-
#writer_identity ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ LogSink
constructor
A new instance of LogSink.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ LogSink
Returns a new instance of LogSink.
2625 2626 2627 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2625 def initialize(**args) update!(**args) end |
Instance Attribute Details
#bigquery_options ⇒ Google::Apis::LoggingV2::BigQueryOptions
Options that change functionality of a sink exporting data to BigQuery.
Corresponds to the JSON property bigqueryOptions
2503 2504 2505 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2503 def @bigquery_options end |
#create_time ⇒ String
Output only. The creation timestamp of the sink.This field may not be present
for older sinks.
Corresponds to the JSON property createTime
2509 2510 2511 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2509 def create_time @create_time end |
#description ⇒ String
Optional. A description of this sink.The maximum length of the description is
8000 characters.
Corresponds to the JSON property description
2515 2516 2517 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2515 def description @description end |
#destination ⇒ String
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]" "logging.googleapis.
com/projects/[PROJECT_ID]" "logging.googleapis.com/projects/[PROJECT_ID]/
locations/[LOCATION_ID]/buckets/[BUCKET_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 (https://cloud.google.com/logging/docs/api/tasks/exporting-
logs).
Corresponds to the JSON property destination
2528 2529 2530 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2528 def destination @destination end |
#disabled ⇒ Boolean Also known as: disabled?
Optional. If set to true, then this sink is disabled and it does not export
any log entries.
Corresponds to the JSON property disabled
2534 2535 2536 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2534 def disabled @disabled end |
#exclusions ⇒ Array<Google::Apis::LoggingV2::LogExclusion>
Optional. Log entries that match any of these exclusion filters will not be
exported.If a log entry is matched by both filter and one of exclusion_filters
it will not be exported.
Corresponds to the JSON property exclusions
2542 2543 2544 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2542 def exclusions @exclusions end |
#filter ⇒ String
Optional. An advanced logs filter (https://cloud.google.com/logging/docs/view/
advanced-queries). 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
2550 2551 2552 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2550 def filter @filter end |
#include_children ⇒ Boolean 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 log entries 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
2565 2566 2567 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2565 def include_children @include_children end |
#intercept_children ⇒ Boolean Also known as: intercept_children?
Optional. This field applies only to sinks owned by organizations and folders.
When the value of 'intercept_children' is true, the following restrictions
apply: The sink must have the include_children flag set to true. The sink
destination must be a Cloud project.Also, the following behaviors apply: Any
logs matched by the sink won't be included by non-_Required sinks owned by
child resources. The sink appears in the results of a ListSinks call from a
child resource if the value of the filter field in its request is either '
in_scope("ALL")' or 'in_scope("ANCESTOR")'.
Corresponds to the JSON property interceptChildren
2578 2579 2580 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2578 def intercept_children @intercept_children end |
#name ⇒ String
Output only. The client-assigned sink identifier, unique within the project.
For 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, periods.First character has to
be alphanumeric.
Corresponds to the JSON property name
2588 2589 2590 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2588 def name @name end |
#output_version_format ⇒ String
Deprecated. This field is unused.
Corresponds to the JSON property outputVersionFormat
2593 2594 2595 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2593 def output_version_format @output_version_format end |
#resource_name ⇒ String
Output only. The resource name of the sink. "projects/[PROJECT_ID]/sinks/[
SINK_NAME] "organizations/[ORGANIZATION_ID]/sinks/[SINK_NAME] "billingAccounts/
[BILLING_ACCOUNT_ID]/sinks/[SINK_NAME] "folders/[FOLDER_ID]/sinks/[SINK_NAME]
For example: projects/my_project/sinks/SINK_NAME
Corresponds to the JSON property resourceName
2601 2602 2603 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2601 def resource_name @resource_name end |
#update_time ⇒ String
Output only. The last update timestamp of the sink.This field may not be
present for older sinks.
Corresponds to the JSON property updateTime
2607 2608 2609 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2607 def update_time @update_time end |
#writer_identity ⇒ String
Output only. An IAM identity—a service account or group—under which Cloud
Logging writes the exported log entries to the sink's destination. This field
is either set by specifying custom_writer_identity or set automatically by
sinks.create and sinks.update based on the value 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 (https://cloud.google.com/iam/docs/granting-roles-to-
service-accounts#granting_access_to_a_service_account_for_a_resource). Consult
the destination service's documentation to determine the appropriate IAM roles
to assign to the identity.Sinks that have a destination that is a log bucket
in the same project as the sink cannot have a writer_identity and no
additional permissions are required.
Corresponds to the JSON property writerIdentity
2623 2624 2625 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2623 def writer_identity @writer_identity end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 |
# File 'lib/google/apis/logging_v2/classes.rb', line 2630 def update!(**args) @bigquery_options = args[:bigquery_options] if args.key?(:bigquery_options) @create_time = args[:create_time] if args.key?(:create_time) @description = args[:description] if args.key?(:description) @destination = args[:destination] if args.key?(:destination) @disabled = args[:disabled] if args.key?(:disabled) @exclusions = args[:exclusions] if args.key?(:exclusions) @filter = args[:filter] if args.key?(:filter) @include_children = args[:include_children] if args.key?(:include_children) @intercept_children = args[:intercept_children] if args.key?(:intercept_children) @name = args[:name] if args.key?(:name) @output_version_format = args[:output_version_format] if args.key?(:output_version_format) @resource_name = args[:resource_name] if args.key?(:resource_name) @update_time = args[:update_time] if args.key?(:update_time) @writer_identity = args[:writer_identity] if args.key?(:writer_identity) end |