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.3.3.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

firestore_wrapper-0.3.3-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: firestore_wrapper-0.3.3.tar.gz
  • Upload date:
  • Size: 10.2 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.3.3.tar.gz
Algorithm Hash digest
SHA256 100a0dd88ce91f9b31aea7a9933c1b1e1968726e42bb1a209a936c75a9ecba8c
MD5 ea87aa82f2df84b42ca363e4ba353b10
BLAKE2b-256 d842b7929673e8da02e09694704fc242d73af8da44475f8c2b30e58116e1150f

See more details on using hashes here.

Provenance

File details

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

File metadata

File hashes

Hashes for firestore_wrapper-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 dbc56026dcec53a62985122fbf115c3f7e0312e65a49ce613107adf3faefac07
MD5 394221069cd50457ec096fcd5248432e
BLAKE2b-256 894eddb5912281d4a6d5fad48edb2447f552ebaf3fb035fd0837300eaf0459f2

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