Skip to main content

A custom wrapper for Google Firestore.

Project description

firestore-wrapper

firestore-wrapper is a custom Python wrapper designed to simplify and streamline operations with Google Firestore. By abstracting the complexities of direct Firestore interaction, it provides an easier and more Pythonic way to work with Firestore databases, including document management, querying, and batch operations.

Features

  • Simplified document addition, update, and retrieval
  • Batch operations support
  • Automated backup and restoration capabilities
  • Customizable query methods

Installation

Install firestore-wrapper using pip:

pip install firestore-wrapper

Ensure you have a Google Cloud project with Firestore enabled and service account credentials available.

Quick Start

First, set up your Firestore credentials:

  1. Go to the Google Cloud Console.
  2. Navigate to IAM & Admin > Service Accounts.
  3. Create a service account and download the JSON credentials file.

Next, initialize FirestoreDB with your credentials:

from firestore_wrapper import FirestoreDB

# Path to your Firestore credentials JSON file
credentials_path = 'path/to/your/credentials.json'
database_url = 'your-database-url'  # Optional, if using a custom Firestore database

# Initialize the FirestoreDB instance
db = FirestoreDB(credentials_path=credentials_path, database=database_url)

Adding a Document

# Define your document data
data = {
    'name': 'John Doe',
    'email': 'john.doe@example.com',
    'signup_date': '2023-01-01'
}

# Add a document to the 'users' collection
document_name = db.add_document(collection_name='users', data=data, document_name='user_johndoe')
print(f'Document added with name: {document_name}')

Retrieving a Document

# Retrieve a document by name
user_document = db.get_document_data(collection_name='users', document_name='user_johndoe')
print(user_document)

Updating a Document

# Update a document with new data
update_data = {'email': 'new.email@example.com'}
db.update_document(collection_name='users', document_name='user_johndoe', data=update_data)

Getting Help

If you encounter any issues or have questions about using firestore-wrapper, please create an issue in the GitHub repository.

Contributing

Contributions to firestore-wrapper are welcome! Whether it's bug reports, feature requests, or code contributions, please feel free to make a contribution. For code contributions, please:

  1. Fork the repository.
  2. Create a new branch for your feature or fix.
  3. Submit a pull request.

Please ensure your code adheres to the project's coding standards and includes appropriate tests.

License

firestore-wrapper is released under the MIT License. See the LICENSE file for more details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

firestore_wrapper-0.2.2.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

firestore_wrapper-0.2.2-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

Details for the file firestore_wrapper-0.2.2.tar.gz.

File metadata

  • Download URL: firestore_wrapper-0.2.2.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for firestore_wrapper-0.2.2.tar.gz
Algorithm Hash digest
SHA256 2e1baec6a2554189449abaa70987d7c4599da77f756ed9fb733c56403841922d
MD5 40d6696d69d0ebb32b58d516356862da
BLAKE2b-256 a8b93853471033e1ae79efe9aa892d9d780b8b168d3aa7a8a946056fd83a0698

See more details on using hashes here.

Provenance

File details

Details for the file firestore_wrapper-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for firestore_wrapper-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e3e8e9da9bc40d84707455a1d658eac497900cc73cb865bca30966ff70b4b8a3
MD5 8f370bd9caa3caeedfdb35eac688ac93
BLAKE2b-256 865b50cd79f44ed285eb1b96a7f8109dd121f304901e6421cb896701a004eaa7

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page