# Copyright 2020 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. module Google module Logging module V2 # An individual entry in a log. # @!attribute [rw] log_name # @return [String] # Required. The resource name of the log to which this log entry belongs: # # "projects/[PROJECT_ID]/logs/[LOG_ID]" # "organizations/[ORGANIZATION_ID]/logs/[LOG_ID]" # "billingAccounts/[BILLING_ACCOUNT_ID]/logs/[LOG_ID]" # "folders/[FOLDER_ID]/logs/[LOG_ID]" # # A project number may be used in place of PROJECT_ID. The project number is # translated to its corresponding PROJECT_ID internally and the `log_name` # field will contain PROJECT_ID in queries and exports. # # `[LOG_ID]` must be URL-encoded within `log_name`. Example: # `"organizations/1234567890/logs/cloudresourcemanager.googleapis.com%2Factivity"`. # `[LOG_ID]` must be less than 512 characters long and can only include the # following characters: upper and lower case alphanumeric characters, # forward-slash, underscore, hyphen, and period. # # For backward compatibility, if `log_name` begins with a forward-slash, such # as `/projects/...`, then the log entry is ingested as usual but the # forward-slash is removed. Listing the log entry will not show the leading # slash and filtering for a log name with a leading slash will never return # any results. # @!attribute [rw] resource # @return [Google::Api::MonitoredResource] # Required. The monitored resource that produced this log entry. # # Example: a log entry that reports a database error would be associated with # the monitored resource designating the particular database that reported # the error. # @!attribute [rw] proto_payload # @return [Google::Protobuf::Any] # The log entry payload, represented as a protocol buffer. Some Google # Cloud Platform services use this field for their log entry payloads. # # The following protocol buffer types are supported; user-defined types # are not supported: # # "type.googleapis.com/google.cloud.audit.AuditLog" # "type.googleapis.com/google.appengine.logging.v1.RequestLog" # @!attribute [rw] text_payload # @return [String] # The log entry payload, represented as a Unicode string (UTF-8). # @!attribute [rw] json_payload # @return [Google::Protobuf::Struct] # The log entry payload, represented as a structure that is # expressed as a JSON object. # @!attribute [rw] timestamp # @return [Google::Protobuf::Timestamp] # Optional. The time the event described by the log entry occurred. This time is used # to compute the log entry's age and to enforce the logs retention period. # If this field is omitted in a new log entry, then Logging assigns it the # current time. Timestamps have nanosecond accuracy, but trailing zeros in # the fractional seconds might be omitted when the timestamp is displayed. # # Incoming log entries should have timestamps that are no more than the [logs # retention period](https://cloud.google.com/logging/quotas) in the past, and no more than 24 hours # in the future. Log entries outside those time boundaries will not be # available when calling `entries.list`, but those log entries can still be # [exported with LogSinks](https://cloud.google.com/logging/docs/api/tasks/exporting-logs). # @!attribute [rw] receive_timestamp # @return [Google::Protobuf::Timestamp] # Output only. The time the log entry was received by Logging. # @!attribute [rw] severity # @return [Google::Logging::Type::LogSeverity] # Optional. The severity of the log entry. The default value is `LogSeverity.DEFAULT`. # @!attribute [rw] insert_id # @return [String] # Optional. A unique identifier for the log entry. If you provide a value, then # Logging considers other log entries in the same project, with the same # `timestamp`, and with the same `insert_id` to be duplicates which are # removed in a single query result. However, there are no guarantees of # de-duplication in the export of logs. # # If the `insert_id` is omitted when writing a log entry, the Logging API # assigns its own unique identifier in this field. # # In queries, the `insert_id` is also used to order log entries that have # the same `log_name` and `timestamp` values. # @!attribute [rw] http_request # @return [Google::Logging::Type::HttpRequest] # Optional. Information about the HTTP request associated with this log entry, if # applicable. # @!attribute [rw] labels # @return [Hash{String => String}] # Optional. A set of user-defined (key, value) data that provides additional # information about the log entry. # @!attribute [rw] operation # @return [Google::Logging::V2::LogEntryOperation] # Optional. Information about an operation associated with the log entry, if # applicable. # @!attribute [rw] trace # @return [String] # Optional. Resource name of the trace associated with the log entry, if any. If it # contains a relative resource name, the name is assumed to be relative to # `//tracing.googleapis.com`. Example: # `projects/my-projectid/traces/06796866738c859f2f19b7cfb3214824` # @!attribute [rw] span_id # @return [String] # Optional. The span ID within the trace associated with the log entry. # # For Trace spans, this is the same format that the Trace API v2 uses: a # 16-character hexadecimal encoding of an 8-byte array, such as # `000000000000004a`. # @!attribute [rw] trace_sampled # @return [true, false] # Optional. The sampling decision of the trace associated with the log entry. # # True means that the trace resource name in the `trace` field was sampled # for storage in a trace backend. False means that the trace was not sampled # for storage when this log entry was written, or the sampling decision was # unknown at the time. A non-sampled `trace` value is still useful as a # request correlation identifier. The default is False. # @!attribute [rw] source_location # @return [Google::Logging::V2::LogEntrySourceLocation] # Optional. Source code location information associated with the log entry, if any. class LogEntry; end # Additional information about a potentially long-running operation with which # a log entry is associated. # @!attribute [rw] id # @return [String] # Optional. An arbitrary operation identifier. Log entries with the same # identifier are assumed to be part of the same operation. # @!attribute [rw] producer # @return [String] # Optional. An arbitrary producer identifier. The combination of `id` and # `producer` must be globally unique. Examples for `producer`: # `"MyDivision.MyBigCompany.com"`, `"github.com/MyProject/MyApplication"`. # @!attribute [rw] first # @return [true, false] # Optional. Set this to True if this is the first log entry in the operation. # @!attribute [rw] last # @return [true, false] # Optional. Set this to True if this is the last log entry in the operation. class LogEntryOperation; end # Additional information about the source code location that produced the log # entry. # @!attribute [rw] file # @return [String] # Optional. Source file name. Depending on the runtime environment, this # might be a simple name or a fully-qualified name. # @!attribute [rw] line # @return [Integer] # Optional. Line within the source file. 1-based; 0 indicates no line number # available. # @!attribute [rw] function # @return [String] # Optional. Human-readable name of the function or method being invoked, with # optional context such as the class or package name. This information may be # used in contexts such as the logs viewer, where a file and line number are # less meaningful. The format can vary by language. For example: # `qual.if.ied.Class.method` (Java), `dir/package.func` (Go), `function` # (Python). class LogEntrySourceLocation; end end end end