# Copyright 2017, Google Inc. All rights reserved.
#
# 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
#
# http://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.
#
# EDITING INSTRUCTIONS
# This file was generated from the file
# https://github.com/googleapis/googleapis/blob/master/google/devtools/clouderrorreporting/v1beta1/error_stats_service.proto,
# and updates to that file get reflected here through a refresh process.
# For the short term, the refresh process will only be runnable by Google
# engineers.
#
# The only allowed edits are to method and file documentation. A 3-way
# merge preserves those additions if the generated source changes.
require "json"
require "pathname"
require "google/gax"
require "google/devtools/clouderrorreporting/v1beta1/error_stats_service_pb"
module Google
module Cloud
module ErrorReporting
module V1beta1
# An API for retrieving and managing error statistics as well as data for
# individual events.
#
# @!attribute [r] error_stats_service_stub
# @return [Google::Devtools::Clouderrorreporting::V1beta1::ErrorStatsService::Stub]
class ErrorStatsServiceClient
attr_reader :error_stats_service_stub
# The default address of the service.
SERVICE_ADDRESS = "clouderrorreporting.googleapis.com".freeze
# The default port of the service.
DEFAULT_SERVICE_PORT = 443
DEFAULT_TIMEOUT = 30
PAGE_DESCRIPTORS = {
"list_group_stats" => Google::Gax::PageDescriptor.new(
"page_token",
"next_page_token",
"error_group_stats"),
"list_events" => Google::Gax::PageDescriptor.new(
"page_token",
"next_page_token",
"error_events")
}.freeze
private_constant :PAGE_DESCRIPTORS
# The scopes needed to make gRPC calls to all of the methods defined in
# this service.
ALL_SCOPES = [
"https://www.googleapis.com/auth/cloud-platform"
].freeze
PROJECT_PATH_TEMPLATE = Google::Gax::PathTemplate.new(
"projects/{project}"
)
private_constant :PROJECT_PATH_TEMPLATE
# Returns a fully-qualified project resource name string.
# @param project [String]
# @return [String]
def self.project_path project
PROJECT_PATH_TEMPLATE.render(
:"project" => project
)
end
# Parses the project from a project resource.
# @param project_name [String]
# @return [String]
def self.match_project_from_project_name project_name
PROJECT_PATH_TEMPLATE.match(project_name)["project"]
end
# @param service_path [String]
# The domain name of the API remote host.
# @param port [Integer]
# The port on which to connect to the remote host.
# @param channel [Channel]
# A Channel object through which to make calls.
# @param chan_creds [Grpc::ChannelCredentials]
# A ChannelCredentials for the setting up the RPC client.
# @param client_config[Hash]
# A Hash for call options for each method. See
# Google::Gax#construct_settings for the structure of
# this data. Falls back to the default config if not specified
# or the specified config is missing data points.
# @param timeout [Numeric]
# The default timeout, in seconds, for calls made through this client.
def initialize \
service_path: SERVICE_ADDRESS,
port: DEFAULT_SERVICE_PORT,
channel: nil,
chan_creds: nil,
scopes: ALL_SCOPES,
client_config: {},
timeout: DEFAULT_TIMEOUT,
app_name: nil,
app_version: nil,
lib_name: nil,
lib_version: ""
# These require statements are intentionally placed here to initialize
# the gRPC module only when it's required.
# See https://github.com/googleapis/toolkit/issues/446
require "google/gax/grpc"
require "google/devtools/clouderrorreporting/v1beta1/error_stats_service_services_pb"
if app_name || app_version
warn "`app_name` and `app_version` are no longer being used in the request headers."
end
google_api_client = "gl-ruby/#{RUBY_VERSION}"
google_api_client << " #{lib_name}/#{lib_version}" if lib_name
google_api_client << " gapic/0.6.8 gax/#{Google::Gax::VERSION}"
google_api_client << " grpc/#{GRPC::VERSION}"
google_api_client.freeze
headers = { :"x-goog-api-client" => google_api_client }
client_config_file = Pathname.new(__dir__).join(
"error_stats_service_client_config.json"
)
defaults = client_config_file.open do |f|
Google::Gax.construct_settings(
"google.devtools.clouderrorreporting.v1beta1.ErrorStatsService",
JSON.parse(f.read),
client_config,
Google::Gax::Grpc::STATUS_CODE_NAMES,
timeout,
page_descriptors: PAGE_DESCRIPTORS,
errors: Google::Gax::Grpc::API_ERRORS,
kwargs: headers
)
end
@error_stats_service_stub = Google::Gax::Grpc.create_stub(
service_path,
port,
chan_creds: chan_creds,
channel: channel,
scopes: scopes,
&Google::Devtools::Clouderrorreporting::V1beta1::ErrorStatsService::Stub.method(:new)
)
@list_group_stats = Google::Gax.create_api_call(
@error_stats_service_stub.method(:list_group_stats),
defaults["list_group_stats"]
)
@list_events = Google::Gax.create_api_call(
@error_stats_service_stub.method(:list_events),
defaults["list_events"]
)
@delete_events = Google::Gax.create_api_call(
@error_stats_service_stub.method(:delete_events),
defaults["delete_events"]
)
end
# Service calls
# Lists the specified groups.
#
# @param project_name [String]
# [Required] The resource name of the Google Cloud Platform project. Written
# as projects/
plus the
# Google Cloud
# Platform project ID.
#
# Example: projects/my-project-123
.
# @param time_range [Google::Devtools::Clouderrorreporting::V1beta1::QueryTimeRange]
# [Optional] List data for the given time range.
# If not set a default time range is used. The field time_range_begin
# in the response will specify the beginning of this time range.
# Only ErrorGroupStats
with a non-zero count in the given time
# range are returned, unless the request contains an explicit group_id list.
# If a group_id list is given, also ErrorGroupStats
with zero
# occurrences are returned.
# @param group_id [Array]
# [Optional] List all ErrorGroupStats
with these IDs.
# @param service_filter [Google::Devtools::Clouderrorreporting::V1beta1::ServiceContextFilter]
# [Optional] List only ErrorGroupStats
which belong to a service
# context that matches the filter.
# Data for all service contexts is returned if this field is not specified.
# @param timed_count_duration [Google::Protobuf::Duration]
# [Optional] The preferred duration for a single returned +TimedCount+.
# If not set, no timed counts are returned.
# @param alignment [Google::Devtools::Clouderrorreporting::V1beta1::TimedCountAlignment]
# [Optional] The alignment of the timed counts to be returned.
# Default is +ALIGNMENT_EQUAL_AT_END+.
# @param alignment_time [Google::Protobuf::Timestamp]
# [Optional] Time where the timed counts shall be aligned if rounded
# alignment is chosen. Default is 00:00 UTC.
# @param order [Google::Devtools::Clouderrorreporting::V1beta1::ErrorGroupOrder]
# [Optional] The sort order in which the results are returned.
# Default is +COUNT_DESC+.
# @param page_size [Integer]
# The maximum number of resources contained in the underlying API
# response. If page streaming is performed per-resource, this
# parameter does not affect the return value. If page streaming is
# performed per-page, this determines the maximum number of
# resources in a page.
# @param options [Google::Gax::CallOptions]
# Overrides the default settings for this call, e.g, timeout,
# retries, etc.
# @return [Google::Gax::PagedEnumerable]
# An enumerable of Google::Devtools::Clouderrorreporting::V1beta1::ErrorGroupStats instances.
# See Google::Gax::PagedEnumerable documentation for other
# operations such as per-page iteration or access to the response
# object.
# @raise [Google::Gax::GaxError] if the RPC is aborted.
# @example
# require "google/cloud/error_reporting/v1beta1/error_stats_service_client"
#
# ErrorStatsServiceClient = Google::Cloud::ErrorReporting::V1beta1::ErrorStatsServiceClient
# QueryTimeRange = Google::Devtools::Clouderrorreporting::V1beta1::QueryTimeRange
#
# error_stats_service_client = ErrorStatsServiceClient.new
# formatted_project_name = ErrorStatsServiceClient.project_path("[PROJECT]")
# time_range = QueryTimeRange.new
#
# # Iterate over all results.
# error_stats_service_client.list_group_stats(formatted_project_name, time_range).each do |element|
# # Process element.
# end
#
# # Or iterate over results one page at a time.
# error_stats_service_client.list_group_stats(formatted_project_name, time_range).each_page do |page|
# # Process each page at a time.
# page.each do |element|
# # Process element.
# end
# end
def list_group_stats \
project_name,
time_range,
group_id: nil,
service_filter: nil,
timed_count_duration: nil,
alignment: nil,
alignment_time: nil,
order: nil,
page_size: nil,
options: nil
req = Google::Devtools::Clouderrorreporting::V1beta1::ListGroupStatsRequest.new({
project_name: project_name,
time_range: time_range,
group_id: group_id,
service_filter: service_filter,
timed_count_duration: timed_count_duration,
alignment: alignment,
alignment_time: alignment_time,
order: order,
page_size: page_size
}.delete_if { |_, v| v.nil? })
@list_group_stats.call(req, options)
end
# Lists the specified events.
#
# @param project_name [String]
# [Required] The resource name of the Google Cloud Platform project. Written
# as +projects/+ plus the
# {Google Cloud Platform project
# ID}[https://support.google.com/cloud/answer/6158840].
# Example: +projects/my-project-123+.
# @param group_id [String]
# [Required] The group for which events shall be returned.
# @param service_filter [Google::Devtools::Clouderrorreporting::V1beta1::ServiceContextFilter]
# [Optional] List only ErrorGroups which belong to a service context that
# matches the filter.
# Data for all service contexts is returned if this field is not specified.
# @param time_range [Google::Devtools::Clouderrorreporting::V1beta1::QueryTimeRange]
# [Optional] List only data for the given time range.
# If not set a default time range is used. The field time_range_begin
# in the response will specify the beginning of this time range.
# @param page_size [Integer]
# The maximum number of resources contained in the underlying API
# response. If page streaming is performed per-resource, this
# parameter does not affect the return value. If page streaming is
# performed per-page, this determines the maximum number of
# resources in a page.
# @param options [Google::Gax::CallOptions]
# Overrides the default settings for this call, e.g, timeout,
# retries, etc.
# @return [Google::Gax::PagedEnumerable]
# An enumerable of Google::Devtools::Clouderrorreporting::V1beta1::ErrorEvent instances.
# See Google::Gax::PagedEnumerable documentation for other
# operations such as per-page iteration or access to the response
# object.
# @raise [Google::Gax::GaxError] if the RPC is aborted.
# @example
# require "google/cloud/error_reporting/v1beta1/error_stats_service_client"
#
# ErrorStatsServiceClient = Google::Cloud::ErrorReporting::V1beta1::ErrorStatsServiceClient
#
# error_stats_service_client = ErrorStatsServiceClient.new
# formatted_project_name = ErrorStatsServiceClient.project_path("[PROJECT]")
# group_id = ''
#
# # Iterate over all results.
# error_stats_service_client.list_events(formatted_project_name, group_id).each do |element|
# # Process element.
# end
#
# # Or iterate over results one page at a time.
# error_stats_service_client.list_events(formatted_project_name, group_id).each_page do |page|
# # Process each page at a time.
# page.each do |element|
# # Process element.
# end
# end
def list_events \
project_name,
group_id,
service_filter: nil,
time_range: nil,
page_size: nil,
options: nil
req = Google::Devtools::Clouderrorreporting::V1beta1::ListEventsRequest.new({
project_name: project_name,
group_id: group_id,
service_filter: service_filter,
time_range: time_range,
page_size: page_size
}.delete_if { |_, v| v.nil? })
@list_events.call(req, options)
end
# Deletes all error events of a given project.
#
# @param project_name [String]
# [Required] The resource name of the Google Cloud Platform project. Written
# as +projects/+ plus the
# {Google Cloud Platform project
# ID}[https://support.google.com/cloud/answer/6158840].
# Example: +projects/my-project-123+.
# @param options [Google::Gax::CallOptions]
# Overrides the default settings for this call, e.g, timeout,
# retries, etc.
# @return [Google::Devtools::Clouderrorreporting::V1beta1::DeleteEventsResponse]
# @raise [Google::Gax::GaxError] if the RPC is aborted.
# @example
# require "google/cloud/error_reporting/v1beta1/error_stats_service_client"
#
# ErrorStatsServiceClient = Google::Cloud::ErrorReporting::V1beta1::ErrorStatsServiceClient
#
# error_stats_service_client = ErrorStatsServiceClient.new
# formatted_project_name = ErrorStatsServiceClient.project_path("[PROJECT]")
# response = error_stats_service_client.delete_events(formatted_project_name)
def delete_events \
project_name,
options: nil
req = Google::Devtools::Clouderrorreporting::V1beta1::DeleteEventsRequest.new({
project_name: project_name
}.delete_if { |_, v| v.nil? })
@delete_events.call(req, options)
end
end
end
end
end
end