Module: Google::Cloud::Monitoring::V3::NotificationChannelService::Paths

Extended by:
Paths
Included in:
Client, Paths
Defined in:
lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb

Overview

Path helper methods for the NotificationChannelService API.

Instance Method Summary collapse

Instance Method Details

#folder_path(folder:) ⇒ ::String

Create a fully-qualified Folder resource string.

The resource will be in the following format:

folders/{folder}

Parameters:

  • folder (String)

Returns:

  • (::String)


37
38
39
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 37

def folder_path folder:
  "folders/#{folder}"
end

#notification_channel_descriptor_path(project: , channel_descriptor: ) ⇒ ::String #notification_channel_descriptor_path(organization: , channel_descriptor: ) ⇒ ::String #notification_channel_descriptor_path(folder: , channel_descriptor: ) ⇒ ::String

Create a fully-qualified NotificationChannelDescriptor resource string.

Overloads:

  • #notification_channel_descriptor_path(project: , channel_descriptor: ) ⇒ ::String

    The resource will be in the following format:

    projects/{project}/notificationChannelDescriptors/{channel_descriptor}

    Parameters:

    • project (String) (defaults to: )
    • channel_descriptor (String) (defaults to: )
  • #notification_channel_descriptor_path(organization: , channel_descriptor: ) ⇒ ::String

    The resource will be in the following format:

    organizations/{organization}/notificationChannelDescriptors/{channel_descriptor}

    Parameters:

    • organization (String) (defaults to: )
    • channel_descriptor (String) (defaults to: )
  • #notification_channel_descriptor_path(folder: , channel_descriptor: ) ⇒ ::String

    The resource will be in the following format:

    folders/{folder}/notificationChannelDescriptors/{channel_descriptor}

    Parameters:

    • folder (String) (defaults to: )
    • channel_descriptor (String) (defaults to: )

Returns:

  • (::String)

Raises:

  • (::ArgumentError)


121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 121

def notification_channel_descriptor_path **args
  resources = {
    "channel_descriptor:project" => (proc do |project:, channel_descriptor:|
      raise ::ArgumentError, "project cannot contain /" if project.to_s.include? "/"

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

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

      "folders/#{folder}/notificationChannelDescriptors/#{channel_descriptor}"
    end)
  }

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

#notification_channel_path(project: , notification_channel: ) ⇒ ::String #notification_channel_path(organization: , notification_channel: ) ⇒ ::String #notification_channel_path(folder: , notification_channel: ) ⇒ ::String

Create a fully-qualified NotificationChannel resource string.

Overloads:

  • #notification_channel_path(project: , notification_channel: ) ⇒ ::String

    The resource will be in the following format:

    projects/{project}/notificationChannels/{notification_channel}

    Parameters:

    • project (String) (defaults to: )
    • notification_channel (String) (defaults to: )
  • #notification_channel_path(organization: , notification_channel: ) ⇒ ::String

    The resource will be in the following format:

    organizations/{organization}/notificationChannels/{notification_channel}

    Parameters:

    • organization (String) (defaults to: )
    • notification_channel (String) (defaults to: )
  • #notification_channel_path(folder: , notification_channel: ) ⇒ ::String

    The resource will be in the following format:

    folders/{folder}/notificationChannels/{notification_channel}

    Parameters:

    • folder (String) (defaults to: )
    • notification_channel (String) (defaults to: )

Returns:

  • (::String)

Raises:

  • (::ArgumentError)


69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 69

def notification_channel_path **args
  resources = {
    "notification_channel:project" => (proc do |project:, notification_channel:|
      raise ::ArgumentError, "project cannot contain /" if project.to_s.include? "/"

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

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

      "folders/#{folder}/notificationChannels/#{notification_channel}"
    end)
  }

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

#organization_path(organization:) ⇒ ::String

Create a fully-qualified Organization resource string.

The resource will be in the following format:

organizations/{organization}

Parameters:

  • organization (String)

Returns:

  • (::String)


155
156
157
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 155

def organization_path organization:
  "organizations/#{organization}"
end

#project_path(project:) ⇒ ::String

Create a fully-qualified Project resource string.

The resource will be in the following format:

projects/{project}

Parameters:

  • project (String)

Returns:

  • (::String)


169
170
171
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 169

def project_path project:
  "projects/#{project}"
end

#workspace_path(project: ) ⇒ ::String #workspace_path(workspace: ) ⇒ ::String

Create a fully-qualified Workspace resource string.

Overloads:

  • #workspace_path(project: ) ⇒ ::String

    The resource will be in the following format:

    projects/{project}

    Parameters:

    • project (String) (defaults to: )
  • #workspace_path(workspace: ) ⇒ ::String

    The resource will be in the following format:

    workspaces/{workspace}

    Parameters:

    • workspace (String) (defaults to: )

Returns:

  • (::String)

Raises:

  • (::ArgumentError)


191
192
193
194
195
196
197
198
199
200
201
202
203
204
# File 'lib/google/cloud/monitoring/v3/notification_channel_service/paths.rb', line 191

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