Python package for controlling Whisker connected self-cleaning litter boxes and feeders.
This is an unofficial API for controlling various Whisker automated robots. It currently supports Litter-Robot 3 (with connect), Litter-Robot 4 and Feeder-Robot.
This API is experimental and was reverse-engineered by monitoring network traffic and decompiling source code from the Whisker app since no public API is currently available at this time. It may cease to work at any time. Use at your own risk.
Install using pip
pip install pylitterbotAlternatively, clone the repository and run
uv syncimport asyncio
from pylitterbot import Account
# Set email and password for initial authentication.
username = "Your username"
password = "Your password"
async def main():
# Create an account.
account = Account()
try:
# Connect to the API and load robots.
await account.connect(username=username, password=password, load_robots=True)
# Print robots associated with account.
print("Robots:")
for robot in account.robots:
print(robot)
finally:
# Disconnect from the API.
await account.disconnect()
if __name__ == "__main__":
asyncio.run(main())which will output something like:
Name: Litter-Robot Name, Serial: LR3C012345, id: a0123b4567cd8e
If you only want to discover specific robot families, pass the classes you want to query when you create the account or when you load robots:
from pylitterbot import Account, LitterRobot4, LitterRobot5
...
account = Account(robot_types=[LitterRobot4, LitterRobot5])
await account.connect(
username=username,
password=password,
load_robots=True,
)To start a clean cycle
await robot.start_cleaning()If no exception occurred, your Litter-Robot should now perform a clean cycle.
Currently the following methods are available in the Robot class:
- refresh()
- start_cleaning()
- reset_settings()
- set_panel_lockout()
- set_night_light()
- set_power_status()
- set_sleep_mode()
- set_wait_time()
- set_name()
- get_activity_history()
- get_insight()
Thank you for your interest in contributing! Please see CONTRIBUTING.md for how to get started.
- Add support for Litter-Robot 5 cameras
I maintain this python project in my spare time. If you find it useful, consider supporting development:
- 💜 Sponsor me on GitHub
- ☕ Buy me a coffee / beer
- 💸 PayPal (direct support)
- ⭐ Star this project
- 📦 If you’d like to support in other ways, such as donating hardware for testing, feel free to reach out to me
If you don't already own a Litter-Robot, please consider using my referral link to purchase your own robot and save $50!