Skip to main content

A Python3, asyncio-based API for interacting with Ridwell waste recycling

Project description

♻️ aioridwell: A Python3, asyncio-based API for interacting with Ridwell

CI PyPi Version License Code Coverage Maintainability Say Thanks

aioridwell is a Python 3, asyncio-friendly library for interacting with Ridwell to view information on upcoming recycling pickups.

Installation

pip install aioridwell

Python Versions

aioridwell is currently supported on:

  • Python 3.8
  • Python 3.9
  • Python 3.10

Usage

Creating and Using a Client

The Client is the primary method of interacting with the API:

import asyncio

from aioridwell import async_get_client


async def main() -> None:
    client = await async_get_client("<EMAIL>", "<PASSWORD>")
    # ...


asyncio.run(main())

By default, the library creates a new connection to the API with each coroutine. If you are calling a large number of coroutines (or merely want to squeeze out every second of runtime savings possible), an aiohttp ClientSession can be used for connection pooling:

import asyncio

from aiohttp import ClientSession

from aiowatttime import Client


async def main() -> None:
    async with ClientSession() as session:
        client = await async_get_client("<EMAIL>", "<PASSWORD>", session=session)
        # ...


asyncio.run(main())

Getting Accounts

Getting all accounts associated with this email address is easy:

import asyncio

from aioridwell import async_get_client


async def main() -> None:
    client = await async_get_client("<EMAIL>", "<PASSWORD>")

    accounts = await client.async_get_accounts()
    # >>> {"account_id_1": RidwellAccount(...), ...}


asyncio.run(main())

The RidwellAccount object comes with some useful properties:

  • account_id: the Ridwell ID for the account
  • address: the address being serviced
  • email: the email address on the account
  • full_name: the full name of the account owner
  • phone: the phone number of the account owner
  • subscription_id: the Ridwell ID for the primary subscription
  • subscription_active: whether the primary subscription is active

Getting Pickup Events

Getting pickup events associated with an account is easy, too:

import asyncio

from aioridwell import async_get_client


async def main() -> None:
    client = await async_get_client("<EMAIL>", "<PASSWORD>")

    accounts = await client.async_get_accounts()
    for account in accounts.values():
        events = await account.async_get_pickup_events()
        # >>> [RidwellPickupEvent(...), ...]

        # You can also get just the next pickup event from today's date:
        next_event = await account.async_get_next_pickup_event()
        # >>> RidwellPickupEvent(...)


asyncio.run(main())

The RidwellPickupEvent object comes with some useful properties:

  • pickup_date: the date of the pickup (in datetime.date format)
  • pickups: a list of RidwellPickup objects
  • state: an EventState enum whose name represents the current state of the pickup event

Likewise, the RidwellPickup object comes with some useful properties:

  • category: a PickupCategory enum whose name represents the type of pickup
  • name: the name of the item being picked up
  • offer_id: the Ridwell ID for this particular offer
  • priority: the pickup priority
  • product_id: the Ridwell ID for this particular product
  • quantity: the amount of the product being picked up

Opting Into or Out Of a Pickup Event

import asyncio

from aioridwell import async_get_client


async def main() -> None:
    client = await async_get_client("<EMAIL>", "<PASSWORD>")

    accounts = await client.async_get_accounts()
    for account in accounts.values():
        events = await account.async_get_pickup_events()
        # >>> [RidwellPickupEvent(...), ...]

        await events[0].async_opt_in()
        await events[0].async_opt_out()


asyncio.run(main())

Calculating a Pickup Event's Esimated Cost

import asyncio

from aioridwell import async_get_client


async def main() -> None:
    client = await async_get_client("<EMAIL>", "<PASSWORD>")

    accounts = await client.async_get_accounts()
    for account in accounts.values():
        events = await account.async_get_pickup_events()
        # >>> [RidwellPickupEvent(...), ...]

        event_1_cost = await events[0].async_get_estimated_cost()
        # >>> 22.00


asyncio.run(main())

Contributing

  1. Check for open features/bugs or initiate a discussion on one.
  2. Fork the repository.
  3. (optional, but highly recommended) Create a virtual environment: python3 -m venv .venv
  4. (optional, but highly recommended) Enter the virtual environment: source ./.venv/bin/activate
  5. Install the dev environment: script/setup
  6. Code your new feature or bug fix.
  7. Write tests that cover your new functionality.
  8. Run tests and ensure 100% code coverage: script/test
  9. Update README.md with any new documentation.
  10. Add yourself to AUTHORS.md.
  11. Submit a pull request!

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

aioridwell-2021.12.1.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aioridwell-2021.12.1-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file aioridwell-2021.12.1.tar.gz.

File metadata

  • Download URL: aioridwell-2021.12.1.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.7.12 Linux/5.11.0-1022-azure

File hashes

Hashes for aioridwell-2021.12.1.tar.gz
Algorithm Hash digest
SHA256 4eb97e4b7d5de4b8459f62e79968f782ae6cce685be3a72bb293320ddec89e9f
MD5 eb2ca92e2aeff70714a9318e18ed681e
BLAKE2b-256 d2ef1dfc54b0f6f73d46bd89c7eb0103c41afd63ef529ce28436770071ba8f50

See more details on using hashes here.

File details

Details for the file aioridwell-2021.12.1-py3-none-any.whl.

File metadata

  • Download URL: aioridwell-2021.12.1-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.7.12 Linux/5.11.0-1022-azure

File hashes

Hashes for aioridwell-2021.12.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8374ec0542b4fbc3bfddcd3674c08723019d1a4e3521e5bef531fa82818a994e
MD5 9ddf75566eaca60c9bc19610148f4b58
BLAKE2b-256 8e675974f6b58b9ed18dec24bcd0bb247e9b373efc99000154cb87516fdc5e65

See more details on using hashes here.

Supported by

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