lib/google/cloud/monitoring.rb in google-cloud-monitoring-0.38.0 vs lib/google/cloud/monitoring.rb in google-cloud-monitoring-1.0.0
- old
+ new
@@ -1,5 +1,7 @@
+# frozen_string_literal: true
+
# 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
@@ -10,475 +12,285 @@
# 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.
+# Auto-generated by gapic-generator-ruby. DO NOT EDIT!
-require "google/gax"
-require "pathname"
+# Require this file early so that the version constant gets defined before
+# requiring "google/cloud". This is because google-cloud-core will load the
+# entrypoint (gem name) file, which in turn re-requires this file (hence
+# causing a require cycle) unless the version constant is already defined.
+require "google/cloud/monitoring/version"
+require "googleauth"
+gem "google-cloud-core"
+require "google/cloud" unless defined? ::Google::Cloud.new
+require "google/cloud/config"
+
+# Set the default configuration
+::Google::Cloud.configure.add_config! :monitoring do |config|
+ config.add_field! :endpoint, "monitoring.googleapis.com", match: ::String
+ config.add_field! :credentials, nil, match: [::String, ::Hash, ::Google::Auth::Credentials]
+ config.add_field! :scope, nil, match: [::Array, ::String]
+ config.add_field! :lib_name, nil, match: ::String
+ config.add_field! :lib_version, nil, match: ::String
+ config.add_field! :interceptors, nil, match: ::Array
+ config.add_field! :timeout, nil, match: ::Numeric
+ config.add_field! :metadata, nil, match: ::Hash
+ config.add_field! :retry_policy, nil, match: [::Hash, ::Proc]
+ config.add_field! :quota_project, nil, match: ::String
+end
+
module Google
module Cloud
- # rubocop:disable LineLength
-
- ##
- # # Ruby Client for Cloud Monitoring API
- #
- # [Cloud Monitoring API][Product Documentation]:
- # Manages your Cloud Monitoring data and configurations. Most projects must
- # be associated with a Workspace, with a few exceptions as noted on the
- # individual method pages. The table entries below are presented in
- # alphabetical order, not in order of common use. For explanations of the
- # concepts found in the table entries, read the [Cloud Monitoring
- # documentation](https://cloud.google.com/monitoring/docs).
- # - [Product Documentation][]
- #
- # ## Quick Start
- # In order to use this library, you first need to go through the following
- # steps:
- #
- # 1. [Select or create a Cloud Platform project.](https://console.cloud.google.com/project)
- # 2. [Enable billing for your project.](https://cloud.google.com/billing/docs/how-to/modify-project#enable_billing_for_a_project)
- # 3. [Enable the Cloud Monitoring API.](https://console.cloud.google.com/apis/library/monitoring.googleapis.com)
- # 4. [Setup Authentication.](https://googleapis.dev/ruby/google-cloud-monitoring/latest/file.AUTHENTICATION.html)
- #
- # ### Installation
- # ```
- # $ gem install google-cloud-monitoring
- # ```
- #
- # ### Preview
- # #### MetricServiceClient
- # ```rb
- # require "google/cloud/monitoring"
- #
- # metric_client = Google::Cloud::Monitoring::Metric.new
- # formatted_name = Google::Cloud::Monitoring::V3::MetricServiceClient.project_path(project_id)
- #
- # # Iterate over all results.
- # metric_client.list_monitored_resource_descriptors(formatted_name).each do |element|
- # # Process element.
- # end
- #
- # # Or iterate over results one page at a time.
- # metric_client.list_monitored_resource_descriptors(formatted_name).each_page do |page|
- # # Process each page at a time.
- # page.each do |element|
- # # Process element.
- # end
- # end
- # ```
- #
- # ### Next Steps
- # - Read the [Cloud Monitoring API Product documentation][Product Documentation]
- # to learn more about the product and see How-to Guides.
- # - View this [repository's main README](https://github.com/googleapis/google-cloud-ruby/blob/master/README.md)
- # to see the full list of Cloud APIs that we cover.
- #
- # [Product Documentation]: https://cloud.google.com/monitoring
- #
- # ## Enabling Logging
- #
- # To enable logging for this library, set the logger for the underlying [gRPC](https://github.com/grpc/grpc/tree/master/src/ruby) library.
- # The logger that you set may be a Ruby stdlib [`Logger`](https://ruby-doc.org/stdlib-2.5.0/libdoc/logger/rdoc/Logger.html) as shown below,
- # or a [`Google::Cloud::Logging::Logger`](https://googleapis.dev/ruby/google-cloud-logging/latest)
- # that will write logs to [Stackdriver Logging](https://cloud.google.com/logging/). See [grpc/logconfig.rb](https://github.com/grpc/grpc/blob/master/src/ruby/lib/grpc/logconfig.rb)
- # and the gRPC [spec_helper.rb](https://github.com/grpc/grpc/blob/master/src/ruby/spec/spec_helper.rb) for additional information.
- #
- # Configuring a Ruby stdlib logger:
- #
- # ```ruby
- # require "logger"
- #
- # module MyLogger
- # LOGGER = Logger.new $stderr, level: Logger::WARN
- # def logger
- # LOGGER
- # end
- # end
- #
- # # Define a gRPC module-level logger method before grpc/logconfig.rb loads.
- # module GRPC
- # extend MyLogger
- # end
- # ```
- #
module Monitoring
- # rubocop:enable LineLength
+ ##
+ # Create a new client object for AlertPolicyService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::AlertPolicyService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/AlertPolicyService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the AlertPolicyService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About AlertPolicyService
+ #
+ # The AlertPolicyService API is used to manage (list, create, delete,
+ # edit) alert policies in Stackdriver Monitoring. An alerting policy is
+ # a description of the conditions under which some aspect of your
+ # system is considered to be "unhealthy" and the ways to notify
+ # people or services about this state. In addition to using this API, alert
+ # policies can also be managed through
+ # [Stackdriver Monitoring](https://cloud.google.com/monitoring/docs/),
+ # which can be reached by clicking the "Monitoring" tab in
+ # [Cloud Console](https://console.cloud.google.com/).
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [AlertPolicyService::Client] A client object for the specified version.
+ #
+ def self.alert_policy_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- FILE_DIR = File.realdirpath(Pathname.new(__FILE__).join("..").join("monitoring"))
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:AlertPolicyService).const_get(:Client).new(&block)
+ end
- AVAILABLE_VERSIONS = Dir["#{FILE_DIR}/*"]
- .select { |file| File.directory?(file) }
- .select { |dir| Google::Gax::VERSION_MATCHER.match(File.basename(dir)) }
- .select { |dir| File.exist?(dir + ".rb") }
- .map { |dir| File.basename(dir) }
+ ##
+ # Create a new client object for GroupService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::GroupService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/GroupService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the GroupService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About GroupService
+ #
+ # The Group API lets you inspect and manage your
+ # [groups](#google.monitoring.v3.Group).
+ #
+ # A group is a named filter that is used to identify
+ # a collection of monitored resources. Groups are typically used to
+ # mirror the physical and/or logical topology of the environment.
+ # Because group membership is computed dynamically, monitored
+ # resources that are started in the future are automatically placed
+ # in matching groups. By using a group to name monitored resources in,
+ # for example, an alert policy, the target of that alert policy is
+ # updated automatically as monitored resources are added and removed
+ # from the infrastructure.
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [GroupService::Client] A client object for the specified version.
+ #
+ def self.group_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- module AlertPolicy
- ##
- # The AlertPolicyService API is used to manage (list, create, delete,
- # edit) alert policies in Stackdriver Monitoring. An alerting policy is
- # a description of the conditions under which some aspect of your
- # system is considered to be "unhealthy" and the ways to notify
- # people or services about this state. In addition to using this API, alert
- # policies can also be managed through
- # [Stackdriver Monitoring](https://cloud.google.com/monitoring/docs/),
- # which can be reached by clicking the "Monitoring" tab in
- # [Cloud Console](https://console.cloud.google.com/).
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
-
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::AlertPolicy.new(*args, **kwargs)
- end
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:GroupService).const_get(:Client).new(&block)
end
- module Group
- ##
- # The Group API lets you inspect and manage your
- # [groups](https://cloud.google.com#google.monitoring.v3.Group).
- #
- # A group is a named filter that is used to identify
- # a collection of monitored resources. Groups are typically used to
- # mirror the physical and/or logical topology of the environment.
- # Because group membership is computed dynamically, monitored
- # resources that are started in the future are automatically placed
- # in matching groups. By using a group to name monitored resources in,
- # for example, an alert policy, the target of that alert policy is
- # updated automatically as monitored resources are added and removed
- # from the infrastructure.
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
+ ##
+ # Create a new client object for MetricService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::MetricService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/MetricService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the MetricService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About MetricService
+ #
+ # Manages metric descriptors, monitored resource descriptors, and
+ # time series data.
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [MetricService::Client] A client object for the specified version.
+ #
+ def self.metric_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::Group.new(*args, **kwargs)
- end
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:MetricService).const_get(:Client).new(&block)
end
- module Metric
- ##
- # Manages metric descriptors, monitored resource descriptors, and
- # time series data.
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
+ ##
+ # Create a new client object for NotificationChannelService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::NotificationChannelService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/NotificationChannelService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the NotificationChannelService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About NotificationChannelService
+ #
+ # The Notification Channel API provides access to configuration that
+ # controls how messages related to incidents are sent.
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [NotificationChannelService::Client] A client object for the specified version.
+ #
+ def self.notification_channel_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::Metric.new(*args, **kwargs)
- end
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:NotificationChannelService).const_get(:Client).new(&block)
end
- module NotificationChannel
- ##
- # The Notification Channel API provides access to configuration that
- # controls how messages related to incidents are sent.
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
+ ##
+ # Create a new client object for ServiceMonitoringService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::ServiceMonitoringService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/ServiceMonitoringService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the ServiceMonitoringService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About ServiceMonitoringService
+ #
+ # The Cloud Monitoring Service-Oriented Monitoring API has endpoints for
+ # managing and querying aspects of a workspace's services. These include the
+ # `Service`'s monitored resources, its Service-Level Objectives, and a taxonomy
+ # of categorized Health Metrics.
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [ServiceMonitoringService::Client] A client object for the specified version.
+ #
+ def self.service_monitoring_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::NotificationChannel.new(*args, **kwargs)
- end
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:ServiceMonitoringService).const_get(:Client).new(&block)
end
- module ServiceMonitoring
- ##
- # The Cloud Monitoring Service-Oriented Monitoring API has endpoints for
- # managing and querying aspects of a workspace's services. These include the
- # `Service`'s monitored resources, its Service-Level Objectives, and a taxonomy
- # of categorized Health Metrics.
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
+ ##
+ # Create a new client object for UptimeCheckService.
+ #
+ # By default, this returns an instance of
+ # [Google::Cloud::Monitoring::V3::UptimeCheckService::Client](https://googleapis.dev/ruby/google-cloud-monitoring-v3/latest/Google/Cloud/Monitoring/V3/UptimeCheckService/Client.html)
+ # for version V3 of the API.
+ # However, you can specify specify a different API version by passing it in the
+ # `version` parameter. If the UptimeCheckService service is
+ # supported by that API version, and the corresponding gem is available, the
+ # appropriate versioned client will be returned.
+ #
+ # ## About UptimeCheckService
+ #
+ # The UptimeCheckService API is used to manage (list, create, delete, edit)
+ # Uptime check configurations in the Stackdriver Monitoring product. An Uptime
+ # check is a piece of configuration that determines which resources and
+ # services to monitor for availability. These configurations can also be
+ # configured interactively by navigating to the [Cloud Console]
+ # (http://console.cloud.google.com), selecting the appropriate project,
+ # clicking on "Monitoring" on the left-hand side to navigate to Stackdriver,
+ # and then clicking on "Uptime".
+ #
+ # @param version [::String, ::Symbol] The API version to connect to. Optional.
+ # Defaults to `:v3`.
+ # @return [UptimeCheckService::Client] A client object for the specified version.
+ #
+ def self.uptime_check_service version: :v3, &block
+ require "google/cloud/monitoring/#{version.to_s.downcase}"
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::ServiceMonitoring.new(*args, **kwargs)
- end
+ package_name = Google::Cloud::Monitoring
+ .constants
+ .select { |sym| sym.to_s.downcase == version.to_s.downcase.tr("_", "") }
+ .first
+ package_module = Google::Cloud::Monitoring.const_get package_name
+ package_module.const_get(:UptimeCheckService).const_get(:Client).new(&block)
end
- module UptimeCheck
- ##
- # The UptimeCheckService API is used to manage (list, create, delete, edit)
- # Uptime check configurations in the Stackdriver Monitoring product. An Uptime
- # check is a piece of configuration that determines which resources and
- # services to monitor for availability. These configurations can also be
- # configured interactively by navigating to the [Cloud Console]
- # (http://console.cloud.google.com), selecting the appropriate project,
- # clicking on "Monitoring" on the left-hand side to navigate to Stackdriver,
- # and then clicking on "Uptime".
- #
- # @param version [Symbol, String]
- # The major version of the service to be used. By default :v3
- # is used.
- # @overload new(version:, credentials:, scopes:, client_config:, timeout:)
- # @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]
- # Provides the means for authenticating requests made by the client. This parameter can
- # be many types.
- # A `Google::Auth::Credentials` uses a the properties of its represented keyfile for
- # authenticating requests made by this client.
- # A `String` will be treated as the path to the keyfile to be used for the construction of
- # credentials for this client.
- # A `Hash` will be treated as the contents of a keyfile to be used for the construction of
- # credentials for this client.
- # A `GRPC::Core::Channel` will be used to make calls through.
- # A `GRPC::Core::ChannelCredentials` for the setting up the RPC client. The channel credentials
- # should already be composed with a `GRPC::Core::CallCredentials` object.
- # A `Proc` will be used as an updater_proc for the Grpc channel. The proc transforms the
- # metadata for requests, generally, to give OAuth credentials.
- # @param scopes [Array<String>]
- # The OAuth scopes for this service. This parameter is ignored if
- # an updater_proc is supplied.
- # @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.
- # @param metadata [Hash]
- # Default metadata to be sent with each request. This can be overridden on a per call basis.
- # @param service_address [String]
- # Override for the service hostname, or `nil` to leave as the default.
- # @param service_port [Integer]
- # Override for the service port, or `nil` to leave as the default.
- # @param exception_transformer [Proc]
- # An optional proc that intercepts any exceptions raised during an API call to inject
- # custom error handling.
- def self.new(*args, version: :v3, **kwargs)
- unless AVAILABLE_VERSIONS.include?(version.to_s.downcase)
- raise "The version: #{version} is not available. The available versions " \
- "are: [#{AVAILABLE_VERSIONS.join(", ")}]"
- end
+ ##
+ # Configure the google-cloud-monitoring library.
+ #
+ # The following configuration parameters are supported:
+ #
+ # * `credentials` (*type:* `String, Hash, Google::Auth::Credentials`) -
+ # The path to the keyfile as a String, the contents of the keyfile as a
+ # Hash, or a Google::Auth::Credentials object.
+ # * `lib_name` (*type:* `String`) -
+ # The library name as recorded in instrumentation and logging.
+ # * `lib_version` (*type:* `String`) -
+ # The library version as recorded in instrumentation and logging.
+ # * `interceptors` (*type:* `Array<GRPC::ClientInterceptor>`) -
+ # An array of interceptors that are run before calls are executed.
+ # * `timeout` (*type:* `Integer`) -
+ # Default timeout in milliseconds.
+ # * `metadata` (*type:* `Hash{Symbol=>String}`) -
+ # Additional gRPC headers to be sent with the call.
+ # * `retry_policy` (*type:* `Hash`) -
+ # The retry policy. The value is a hash with the following keys:
+ # * `:initial_delay` (*type:* `Numeric`) - The initial delay in seconds.
+ # * `:max_delay` (*type:* `Numeric`) - The max delay in seconds.
+ # * `:multiplier` (*type:* `Numeric`) - The incremental backoff multiplier.
+ # * `:retry_codes` (*type:* `Array<String>`) -
+ # The error codes that should trigger a retry.
+ #
+ # @return [::Google::Cloud::Config] The default configuration used by this library
+ #
+ def self.configure
+ yield ::Google::Cloud.configure.monitoring if block_given?
- require "#{FILE_DIR}/#{version.to_s.downcase}"
- version_module = Google::Cloud::Monitoring
- .constants
- .select {|sym| sym.to_s.downcase == version.to_s.downcase}
- .first
- Google::Cloud::Monitoring.const_get(version_module)::UptimeCheck.new(*args, **kwargs)
- end
+ ::Google::Cloud.configure.monitoring
end
end
end
end
+
+helper_path = ::File.join __dir__, "monitoring", "helpers.rb"
+require "google/cloud/monitoring/helpers" if ::File.file? helper_path