Class: Google::Apis::CloudfunctionsV1beta2::CloudFunction

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
generated/google/apis/cloudfunctions_v1beta2/classes.rb,
generated/google/apis/cloudfunctions_v1beta2/representations.rb,
generated/google/apis/cloudfunctions_v1beta2/representations.rb

Overview

Describes a Cloud Function that contains user computation executed in response to an event. It encapsulate function and triggers configurations.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Google::Apis::Core::JsonObjectSupport

#to_json

Methods included from Google::Apis::Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ CloudFunction

Returns a new instance of CloudFunction



238
239
240
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 238

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#available_memory_mbFixnum

The amount of memory in MB available for a function. Defaults to 256MB. Corresponds to the JSON property availableMemoryMb

Returns:

  • (Fixnum)


86
87
88
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 86

def available_memory_mb
  @available_memory_mb
end

#entry_pointString

The name of the function (as defined in source code) that will be executed. Defaults to the resource name suffix, if not specified. For backward compatibility, if function with given name is not found, then the system will try to use function named "function". For Node.js this is name of a function exported by the module specified in source_location. Corresponds to the JSON property entryPoint

Returns:

  • (String)


96
97
98
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 96

def entry_point
  @entry_point
end

#environment_variablesHash<String,String>

Environment variables that shall be available during function execution. Corresponds to the JSON property environmentVariables

Returns:

  • (Hash<String,String>)


101
102
103
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 101

def environment_variables
  @environment_variables
end

#event_triggerGoogle::Apis::CloudfunctionsV1beta2::EventTrigger

Describes EventTrigger, used to request events be sent from another service. Corresponds to the JSON property eventTrigger



107
108
109
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 107

def event_trigger
  @event_trigger
end

#https_triggerGoogle::Apis::CloudfunctionsV1beta2::HttpsTrigger

Describes HTTPSTrigger, could be used to connect web hooks to function. Corresponds to the JSON property httpsTrigger



112
113
114
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 112

def https_trigger
  @https_trigger
end

#labelsHash<String,String>

Labels associated with this Cloud Function. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


117
118
119
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 117

def labels
  @labels
end

#latest_operationString

Output only. Name of the most recent operation modifying the function. If the function status is DEPLOYING or DELETING, then it points to the active operation. Corresponds to the JSON property latestOperation

Returns:

  • (String)


124
125
126
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 124

def latest_operation
  @latest_operation
end

#max_instancesFixnum

The limit on the maximum number of function instances that may coexist at a given time. This feature is currently in alpha, available only for whitelisted users. Corresponds to the JSON property maxInstances

Returns:

  • (Fixnum)


131
132
133
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 131

def max_instances
  @max_instances
end

#nameString

A user-defined name of the function. Function names must be unique globally and match pattern projects/*/locations/*/functions/* Corresponds to the JSON property name

Returns:

  • (String)


137
138
139
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 137

def name
  @name
end

#networkString

The VPC Network that this cloud function can connect to. It can be either the fully-qualified URI, or the short name of the network resource. If the short network name is used, the network must belong to the same project. Otherwise, it must belong to a project within the same organization. The format of this field is either projects/project/global/networks/networkornetwork`, where projectis a project id where the network is defined, andnetworkis the short name of the network. This field is mutually exclusive withvpc_connectorand will be replaced by it. See [the VPC documentation](https://cloud.google.com/compute/docs/vpc) for more information on connecting Cloud projects. This feature is currently in alpha, available only for whitelisted users. Corresponds to the JSON propertynetwork`

Returns:

  • (String)


154
155
156
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 154

def network
  @network
end

#runtimeString

The runtime in which the function is going to run. If empty, defaults to Node.js 6. Corresponds to the JSON property runtime

Returns:

  • (String)


160
161
162
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 160

def runtime
  @runtime
end

#service_accountString

Output only. The service account of the function. Corresponds to the JSON property serviceAccount

Returns:

  • (String)


165
166
167
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 165

def 
  @service_account
end

#source_archive_urlString

The Google Cloud Storage URL, starting with gs://, pointing to the zip archive which contains the function. Corresponds to the JSON property sourceArchiveUrl

Returns:

  • (String)


171
172
173
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 171

def source_archive_url
  @source_archive_url
end

#source_repositoryGoogle::Apis::CloudfunctionsV1beta2::SourceRepository

Describes the location of the function source in a remote repository. Corresponds to the JSON property sourceRepository



176
177
178
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 176

def source_repository
  @source_repository
end

#source_repository_urlString

The URL pointing to the hosted repository where the function is defined. There are supported Cloud Source Repository URLs in the following formats: To refer to a specific commit: https://source.developers.google.com/projects/*/repos/*/revisions/*/paths/* To refer to a moveable alias (branch): https://source.developers.google.com/projects/*/repos/*/moveable-aliases/*/ paths/* In particular, to refer to HEAD use master moveable alias. To refer to a specific fixed alias (tag): https://source.developers.google.com/projects/*/repos/*/fixed-aliases/*/paths/ * You may omit paths/* if you want to use the main directory. Corresponds to the JSON property sourceRepositoryUrl

Returns:

  • (String)


193
194
195
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 193

def source_repository_url
  @source_repository_url
end

#source_upload_urlString

The Google Cloud Storage signed URL used for source uploading, generated by google.cloud.functions.v1beta2.GenerateUploadUrl Corresponds to the JSON property sourceUploadUrl

Returns:

  • (String)


199
200
201
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 199

def source_upload_url
  @source_upload_url
end

#statusString

Output only. Status of the function deployment. Corresponds to the JSON property status

Returns:

  • (String)


204
205
206
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 204

def status
  @status
end

#timeoutString

The function execution timeout. Execution is considered failed and can be terminated if the function is not completed at the end of the timeout period. Defaults to 60 seconds. Corresponds to the JSON property timeout

Returns:

  • (String)


211
212
213
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 211

def timeout
  @timeout
end

#update_timeString

Output only. The last update timestamp of a Cloud Function. Corresponds to the JSON property updateTime

Returns:

  • (String)


216
217
218
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 216

def update_time
  @update_time
end

#version_idFixnum

Output only. The version identifier of the Cloud Function. Each deployment attempt results in a new version of a function being created. Corresponds to the JSON property versionId

Returns:

  • (Fixnum)


223
224
225
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 223

def version_id
  @version_id
end

#vpc_connectorString

The VPC Network Connector that this cloud function can connect to. It can be either the fully-qualified URI, or the short name of the network connector resource. The format of this field is projects/*/locations/*/connectors/* This field is mutually exclusive with network field and will eventually replace it. See the VPC documentation for more information on connecting Cloud projects. This feature is currently in alpha, available only for whitelisted users. Corresponds to the JSON property vpcConnector

Returns:

  • (String)


236
237
238
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 236

def vpc_connector
  @vpc_connector
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
# File 'generated/google/apis/cloudfunctions_v1beta2/classes.rb', line 243

def update!(**args)
  @available_memory_mb = args[:available_memory_mb] if args.key?(:available_memory_mb)
  @entry_point = args[:entry_point] if args.key?(:entry_point)
  @environment_variables = args[:environment_variables] if args.key?(:environment_variables)
  @event_trigger = args[:event_trigger] if args.key?(:event_trigger)
  @https_trigger = args[:https_trigger] if args.key?(:https_trigger)
  @labels = args[:labels] if args.key?(:labels)
  @latest_operation = args[:latest_operation] if args.key?(:latest_operation)
  @max_instances = args[:max_instances] if args.key?(:max_instances)
  @name = args[:name] if args.key?(:name)
  @network = args[:network] if args.key?(:network)
  @runtime = args[:runtime] if args.key?(:runtime)
  @service_account = args[:service_account] if args.key?(:service_account)
  @source_archive_url = args[:source_archive_url] if args.key?(:source_archive_url)
  @source_repository = args[:source_repository] if args.key?(:source_repository)
  @source_repository_url = args[:source_repository_url] if args.key?(:source_repository_url)
  @source_upload_url = args[:source_upload_url] if args.key?(:source_upload_url)
  @status = args[:status] if args.key?(:status)
  @timeout = args[:timeout] if args.key?(:timeout)
  @update_time = args[:update_time] if args.key?(:update_time)
  @version_id = args[:version_id] if args.key?(:version_id)
  @vpc_connector = args[:vpc_connector] if args.key?(:vpc_connector)
end