Class: Google::Apis::PubsubV1::BigQueryConfig

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/pubsub_v1/classes.rb,
lib/google/apis/pubsub_v1/representations.rb,
lib/google/apis/pubsub_v1/representations.rb

Overview

Configuration for a BigQuery subscription.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ BigQueryConfig

Returns a new instance of BigQueryConfig.



347
348
349
# File 'lib/google/apis/pubsub_v1/classes.rb', line 347

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

Instance Attribute Details

#drop_unknown_fieldsBoolean Also known as: drop_unknown_fields?

Optional. When true and use_topic_schema is true, any fields that are a part of the topic schema that are not part of the BigQuery table schema are dropped when writing to BigQuery. Otherwise, the schemas must be kept in sync and any messages with extra fields are not written and remain in the subscription's backlog. Corresponds to the JSON property dropUnknownFields

Returns:

  • (Boolean)


297
298
299
# File 'lib/google/apis/pubsub_v1/classes.rb', line 297

def drop_unknown_fields
  @drop_unknown_fields
end

#service_account_emailString

Optional. The service account to use to write to BigQuery. The subscription creator or updater that specifies this field must have iam.serviceAccounts. actAs permission on the service account. If not specified, the Pub/Sub service agent, service- project_number@gcp-sa-pubsub.iam.gserviceaccount.com, is used. Corresponds to the JSON property serviceAccountEmail

Returns:

  • (String)


307
308
309
# File 'lib/google/apis/pubsub_v1/classes.rb', line 307

def 
  @service_account_email
end

#stateString

Output only. An output-only field that indicates whether or not the subscription can receive messages. Corresponds to the JSON property state

Returns:

  • (String)


313
314
315
# File 'lib/google/apis/pubsub_v1/classes.rb', line 313

def state
  @state
end

#tableString

Optional. The name of the table to which to write data, of the form projectId .datasetId.tableId Corresponds to the JSON property table

Returns:

  • (String)


319
320
321
# File 'lib/google/apis/pubsub_v1/classes.rb', line 319

def table
  @table
end

#use_table_schemaBoolean Also known as: use_table_schema?

Optional. When true, use the BigQuery table's schema as the columns to write to in BigQuery. use_table_schema and use_topic_schema cannot be enabled at the same time. Corresponds to the JSON property useTableSchema

Returns:

  • (Boolean)


326
327
328
# File 'lib/google/apis/pubsub_v1/classes.rb', line 326

def use_table_schema
  @use_table_schema
end

#use_topic_schemaBoolean Also known as: use_topic_schema?

Optional. When true, use the topic's schema as the columns to write to in BigQuery, if it exists. use_topic_schema and use_table_schema cannot be enabled at the same time. Corresponds to the JSON property useTopicSchema

Returns:

  • (Boolean)


334
335
336
# File 'lib/google/apis/pubsub_v1/classes.rb', line 334

def use_topic_schema
  @use_topic_schema
end

#write_metadataBoolean Also known as: write_metadata?

Optional. When true, write the subscription name, message_id, publish_time, attributes, and ordering_key to additional columns in the table. The subscription name, message_id, and publish_time fields are put in their own columns while all other message properties (other than data) are written to a JSON object in the attributes column. Corresponds to the JSON property writeMetadata

Returns:

  • (Boolean)


344
345
346
# File 'lib/google/apis/pubsub_v1/classes.rb', line 344

def 
  @write_metadata
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



352
353
354
355
356
357
358
359
360
# File 'lib/google/apis/pubsub_v1/classes.rb', line 352

def update!(**args)
  @drop_unknown_fields = args[:drop_unknown_fields] if args.key?(:drop_unknown_fields)
  @service_account_email = args[:service_account_email] if args.key?(:service_account_email)
  @state = args[:state] if args.key?(:state)
  @table = args[:table] if args.key?(:table)
  @use_table_schema = args[:use_table_schema] if args.key?(:use_table_schema)
  @use_topic_schema = args[:use_topic_schema] if args.key?(:use_topic_schema)
  @write_metadata = args[:write_metadata] if args.key?(:write_metadata)
end