module Google::Cloud::Monitoring::V3::ServiceMonitoringService::Paths

Path helper methods for the ServiceMonitoringService API.

Public Instance Methods

folder_path(folder: "folders/ click to toggle source

Create a fully-qualified Folder resource string.

The resource will be in the following format:

`folders/{folder}`

@param folder [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 37
def folder_path folder:
  "folders/#{folder}"
end
organization_path(organization: "organizations/ click to toggle source

Create a fully-qualified Organization resource string.

The resource will be in the following format:

`organizations/{organization}`

@param organization [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 51
def organization_path organization:
  "organizations/#{organization}"
end
project_path(project: "projects/ click to toggle source

Create a fully-qualified Project resource string.

The resource will be in the following format:

`projects/{project}`

@param project [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 65
def project_path project:
  "projects/#{project}"
end
service_level_objective_path(**args) click to toggle source

Create a fully-qualified ServiceLevelObjective resource string.

@overload service_level_objective_path(project:, service:, service_level_objective:)

The resource will be in the following format:

`projects/{project}/services/{service}/serviceLevelObjectives/{service_level_objective}`

@param project [String]
@param service [String]
@param service_level_objective [String]

@overload service_level_objective_path(organization:, service:, service_level_objective:)

The resource will be in the following format:

`organizations/{organization}/services/{service}/serviceLevelObjectives/{service_level_objective}`

@param organization [String]
@param service [String]
@param service_level_objective [String]

@overload service_level_objective_path(folder:, service:, service_level_objective:)

The resource will be in the following format:

`folders/{folder}/services/{service}/serviceLevelObjectives/{service_level_objective}`

@param folder [String]
@param service [String]
@param service_level_objective [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 152
def service_level_objective_path **args
  resources = {
    "project:service:service_level_objective" => (proc do |project:, service:, service_level_objective:|
      raise ::ArgumentError, "project cannot contain /" if project.to_s.include? "/"
      raise ::ArgumentError, "service cannot contain /" if service.to_s.include? "/"

      "projects/#{project}/services/#{service}/serviceLevelObjectives/#{service_level_objective}"
    end),
    "organization:service:service_level_objective" => (proc do |organization:, service:, service_level_objective:|
      raise ::ArgumentError, "organization cannot contain /" if organization.to_s.include? "/"
      raise ::ArgumentError, "service cannot contain /" if service.to_s.include? "/"

      "organizations/#{organization}/services/#{service}/serviceLevelObjectives/#{service_level_objective}"
    end),
    "folder:service:service_level_objective" => (proc do |folder:, service:, service_level_objective:|
      raise ::ArgumentError, "folder cannot contain /" if folder.to_s.include? "/"
      raise ::ArgumentError, "service cannot contain /" if service.to_s.include? "/"

      "folders/#{folder}/services/#{service}/serviceLevelObjectives/#{service_level_objective}"
    end)
  }

  resource = resources[args.keys.sort.join(":")]
  raise ::ArgumentError, "no resource found for values #{args.keys}" if resource.nil?
  resource.call(**args)
end
service_path(**args) click to toggle source

Create a fully-qualified Service resource string.

@overload service_path(project:, service:)

The resource will be in the following format:

`projects/{project}/services/{service}`

@param project [String]
@param service [String]

@overload service_path(organization:, service:)

The resource will be in the following format:

`organizations/{organization}/services/{service}`

@param organization [String]
@param service [String]

@overload service_path(folder:, service:)

The resource will be in the following format:

`folders/{folder}/services/{service}`

@param folder [String]
@param service [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 97
def service_path **args
  resources = {
    "project:service" => (proc do |project:, service:|
      raise ::ArgumentError, "project cannot contain /" if project.to_s.include? "/"

      "projects/#{project}/services/#{service}"
    end),
    "organization:service" => (proc do |organization:, service:|
      raise ::ArgumentError, "organization cannot contain /" if organization.to_s.include? "/"

      "organizations/#{organization}/services/#{service}"
    end),
    "folder:service" => (proc do |folder:, service:|
      raise ::ArgumentError, "folder cannot contain /" if folder.to_s.include? "/"

      "folders/#{folder}/services/#{service}"
    end)
  }

  resource = resources[args.keys.sort.join(":")]
  raise ::ArgumentError, "no resource found for values #{args.keys}" if resource.nil?
  resource.call(**args)
end
workspace_path(**args) click to toggle source

Create a fully-qualified Workspace resource string.

@overload workspace_path(project:)

The resource will be in the following format:

`projects/{project}`

@param project [String]

@overload workspace_path(workspace:)

The resource will be in the following format:

`workspaces/{workspace}`

@param workspace [String]

@return [::String]

# File lib/google/cloud/monitoring/v3/service_monitoring_service/paths.rb, line 197
def workspace_path **args
  resources = {
    "project" => (proc do |project:|
      "projects/#{project}"
    end),
    "workspace" => (proc do |workspace:|
      "workspaces/#{workspace}"
    end)
  }

  resource = resources[args.keys.sort.join(":")]
  raise ::ArgumentError, "no resource found for values #{args.keys}" if resource.nil?
  resource.call(**args)
end