airflow.providers.google.cloud.hooks.datastore

This module contains Google Datastore hook.

Module Contents

Classes

DatastoreHook

Interact with Google Cloud Datastore. This hook uses the Google Cloud connection.

class airflow.providers.google.cloud.hooks.datastore.DatastoreHook(gcp_conn_id='google_cloud_default', delegate_to=None, api_version='v1', datastore_conn_id=None, impersonation_chain=None)[source]

Bases: airflow.providers.google.common.hooks.base_google.GoogleBaseHook

Interact with Google Cloud Datastore. This hook uses the Google Cloud connection.

This object is not threads safe. If you want to make multiple requests simultaneously, you will need to create a hook per thread.

Parameters

api_version (str) -- The version of the API it is going to connect to.

get_conn(self)[source]

Establishes a connection to the Google API.

Returns

a Google Cloud Datastore service object.

Return type

Resource

allocate_ids(self, partial_keys, project_id)[source]

Allocate IDs for incomplete keys.

Parameters
  • partial_keys (list) -- a list of partial keys.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

a list of full keys.

Return type

list

begin_transaction(self, project_id, transaction_options)[source]

Begins a new transaction.

Parameters
  • project_id (str) -- Google Cloud project ID against which to make the request.

  • transaction_options (Dict[str, Any]) -- Options for a new transaction.

Returns

a transaction handle.

Return type

str

commit(self, body, project_id)[source]

Commit a transaction, optionally creating, deleting or modifying some entities.

Parameters
  • body (dict) -- the body of the commit request.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

the response body of the commit request.

Return type

dict

lookup(self, keys, project_id, read_consistency=None, transaction=None)[source]

Lookup some entities by key.

Parameters
  • keys (list) -- the keys to lookup.

  • read_consistency (Optional[str]) -- the read consistency to use. default, strong or eventual. Cannot be used with a transaction.

  • transaction (Optional[str]) -- the transaction to use, if any.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

the response body of the lookup request.

Return type

dict

rollback(self, transaction, project_id)[source]

Roll back a transaction.

Parameters
  • transaction (str) -- the transaction to roll back.

  • project_id (str) -- Google Cloud project ID against which to make the request.

run_query(self, body, project_id)[source]

Run a query for entities.

Parameters
  • body (dict) -- the body of the query request.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

the batch of query results.

Return type

dict

get_operation(self, name)[source]

Gets the latest state of a long-running operation.

Parameters

name (str) -- the name of the operation resource.

Returns

a resource operation instance.

Return type

dict

delete_operation(self, name)[source]

Deletes the long-running operation.

Parameters

name (str) -- the name of the operation resource.

Returns

none if successful.

Return type

dict

poll_operation_until_done(self, name, polling_interval_in_seconds)[source]

Poll backup operation state until it's completed.

Parameters
  • name (str) -- the name of the operation resource

  • polling_interval_in_seconds (float) -- The number of seconds to wait before calling another request.

Returns

a resource operation instance.

Return type

dict

export_to_storage_bucket(self, bucket, project_id, namespace=None, entity_filter=None, labels=None)[source]

Export entities from Cloud Datastore to Cloud Storage for backup.

Note

Keep in mind that this requests the Admin API not the Data API.

Parameters
  • bucket (str) -- The name of the Cloud Storage bucket.

  • namespace (Optional[str]) -- The Cloud Storage namespace path.

  • entity_filter (Optional[dict]) -- Description of what data from the project is included in the export.

  • labels (Optional[Dict[str, str]]) -- Client-assigned labels.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

a resource operation instance.

Return type

dict

import_from_storage_bucket(self, bucket, file, project_id, namespace=None, entity_filter=None, labels=None)[source]

Import a backup from Cloud Storage to Cloud Datastore.

Note

Keep in mind that this requests the Admin API not the Data API.

Parameters
  • bucket (str) -- The name of the Cloud Storage bucket.

  • file (str) -- the metadata file written by the projects.export operation.

  • namespace (Optional[str]) -- The Cloud Storage namespace path.

  • entity_filter (Optional[dict]) -- specify which kinds/namespaces are to be imported.

  • labels (Optional[Union[dict, str]]) -- Client-assigned labels.

  • project_id (str) -- Google Cloud project ID against which to make the request.

Returns

a resource operation instance.

Return type

dict

Was this entry helpful?