Python library for PetKit's API
Project description
Petkit_api
Asynchronous Python library for PetKit's API.
This is PetKit's undocumented API. With that said, future changes made by PetKit may break this library. The API endpoint used is determined based on the region your account is locked to. See the Regions
section for available region values.
Currently Supported Devices:
Feeders
- Fresh Element
- D3 (Fresh Element Infinity)
- D4 (Fresh Element Solo)
- D4s (Fresh Element Gemini)
- Mini Feeder
- D4sh (YumShare Dual-Hopper) Video is not supported
Litter Boxes
Purifiers
Water Fountains
Workig on IT :
- CTW3 (Eversweet Max) partially supported, work in progress
- T6 (Purobot Ultra) partially supported, work in progress Video is not supported
Important
PetKit accounts can only be logged in on one device at a time. Using this library will result in getting signed out of the mobile app. If you want to continue using the mobile app, use the family share feature to share devices to a secondary account. Note
: The secondary account needs to be used with the mobile app while the primary account is used with this library as this library will not fetch devices that are part of family sharing.
This package depends on aiohttp and tzlocal. Python 3.7
or greater is required.
Usage
Regions
See regions available (click to expand)
Region |
---|
Afghanistan |
Aland Islands |
Albania |
Algeria |
American Samoa |
Andorra |
Angola |
Anguilla |
Antarctica |
Antigua and Barbuda |
Argentina |
Armenia |
Aruba |
Australia |
Austria |
Azerbaijan |
Bahamas |
Bahrain |
Bangladesh |
Barbados |
Belarus |
Belgium |
Belize |
Benin |
Bermuda |
Bhutan |
Bolivia |
Bosnia and Herzegovina |
Botswana |
Bouvet Island |
Brazil |
British Indian Ocean Territory |
Brunei Darussalam |
Bulgaria |
Burkina Faso |
Burundi |
Cambodia |
Cameroon |
Canada |
Cape Verde |
Cayman Islands |
Central African Republic |
Chad |
Chile |
China |
Christmas Island |
Cocos (Keeling) Islands |
Colombia |
Comoros |
Congo |
Congo (the Democratic Republic of the Congo) |
Cook Islands |
Costa Rica |
Côte d'Ivoire |
Croatia |
Cuba |
Cyprus |
Czech Republic |
Denmark |
Djibouti |
Dominica |
Dominican Republic |
Ecuador |
Egypt |
El Salvador |
Equatorial Guinea |
Eritrea |
Estonia |
Ethiopia |
Falkland Islands [Malvinas] |
Faroe Islands |
Fiji |
Finland |
France |
French Guiana |
French Polynesia |
French Southern Territories |
Gabon |
Gambia |
Georgia |
Germany |
Ghana |
Gibraltar |
Greece |
Greenland |
Grenada |
Guadeloupe |
Guam |
Guatemala |
Guernsey |
Guinea |
Guinea-Bissau |
Guyana |
Haiti |
Heard Island and McDonald Islands |
Holy See [Vatican City State] |
Honduras |
Hong Kong |
Hungary |
Iceland |
India |
Indonesia |
Iran (the Islamic Republic of Iran) |
Iraq |
Ireland |
Isle of Man |
Israel |
Italy |
Jamaica |
Japan |
Jersey |
Jordan |
Kazakhstan |
Kenya |
Kiribati |
Korea (the Democratic People's Republic of Korea) |
Korea (the Republic of Korea) |
Kuwait |
Kyrgyzstan |
Lao People's Democratic Republic |
Latvia |
Lebanon |
Lesotho |
Liberia |
Libyan Arab Jamahiriya |
Liechtenstein |
Lithuania |
Luxembourg |
Macao |
Macedonia (the former Yugoslav Republic of Macedonia) |
Madagascar |
Malawi |
Malaysia |
Maldives |
Mali |
Malta |
Marshall Islands |
Martinique |
Mauritania |
Mauritius |
Mayotte |
Mexico |
Micronesia (the Federated States of Micronesia) |
Moldova (the Republic of Moldova) |
Monaco |
Mongolia |
Montenegro |
Montserrat |
Morocco |
Mozambique |
Myanmar |
Namibia |
Nauru |
Nepal |
Netherlands |
Netherlands Antilles |
New Caledonia |
New Zealand |
Nicaragua |
Niger |
Nigeria |
Niue |
Norfolk Island |
Northern Mariana Islands |
Norway |
Oman |
Pakistan |
Palau |
Palestinian Territory |
Panama |
Papua New Guinea |
Paraguay |
Peru |
Philippines |
Pitcairn |
Poland |
Portugal |
Puerto Rico |
Qatar |
Réunion |
Romania |
Russian Federation |
Rwanda |
Saint Helena |
Saint Kitts and Nevis |
Saint Lucia |
Saint Pierre and Miquelon |
Saint Vincent and the Grenadines |
Samoa |
San Marino |
Sao Tome and Principe |
Saudi Arabia |
Senegal |
Serbia |
Seychelles |
Sierra Leone |
Singapore |
Slovakia |
Slovenia |
Solomon Islands |
Somalia |
South Africa |
South Georgia and the South Sandwich Islands |
Spain |
Sri Lanka |
Sudan |
Suriname |
Svalbard and Jan Mayen |
Swaziland |
Sweden |
Switzerland |
Syrian Arab Republic |
Taiwan (Province of China) |
Tajikistan |
Tanzania,United Republic of |
Thailand |
Timor-Leste |
Togo |
Tokelau |
Tonga |
Trinidad and Tobago |
Tunisia |
Turkey |
Turkmenistan |
Turks and Caicos Islands |
Tuvalu |
Uganda |
Ukraine |
United Arab Emirates |
United Kingdom |
United States |
United States Minor Outlying Islands |
Uruguay |
Uzbekistan |
Vanuatu |
Venezuela |
Viet Nam |
Virgin Islands (British) |
Virgin Islands (U.S.) |
Wallis and Futuna |
Western Sahara |
Yemen |
Zambia |
Zimbabwe |
Creating Client
import asyncio
from petkit_api import PetKitClient
from aiohttp import ClientSession
async def main():
async with ClientSession() as session:
# Create a client using PetKit account email, password, and region
client = PetKitClient('email', 'password', session, 'United States')
###################################################################################
Examples within the examples section utilize the PetKitClient instance created above
###################################################################################
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
Examples
Retrieving all PetKit devices on account
# See model.py for details regarding Data Classes created
devices = await client.get_petkit_data()
Manual Feeding
# See model.py for details regarding "Feeder" class
# Reusing retrieved devices from above. Note: A valid amount (in grams) will depend on the capabilities of the feeder.
await client.manual_feeding(feeder=devices.feeders[feederid], amount=10)
Change Feeder Setting
# See constants.py FeederSetting class for available settings
# Additional import needed:
from petkit_api.constants import FeederSetting
# Enabling child lock on a D4 feeder. Note: Mini Feeders use a different setting.
# Reusing retrieved devices from above.
await client.update_feeder_settings(feeder=devices.feeders[feederid], setting=FeederSetting.CHILD_LOCK, value=1)
Reset Feeder Desiccant
# Reusing retrieved devices from above.
await client.reset_feeder_desiccant(feeder=devices.feeders[feederid])
Control Water Fountain via BLE Relay
# A valid relay (set up through the PetKit app) is required in order to send commands to the Eversweet 3 Pro
# See constants.py W5Command class for available commands
# Additional import needed:
from petkit_api.constants import FountainCommand
# Set Water Fountain to Smart Mode. Reusing retrieved devices from above.
await client.control_water_fountain(water_fountain=devices.water_fountains[water_fountain_id],
command=FountainCommand.SMART)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file petkit_api-0.1.2.tar.gz
.
File metadata
- Download URL: petkit_api-0.1.2.tar.gz
- Upload date:
- Size: 28.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 03eccf1bad3fac92cccbfb1ef45995f7c6a7f0712e53b831f1d81941e37442ed |
|
MD5 | d56073fe6bb6306715a84d9a7b4ab438 |
|
BLAKE2b-256 | c6ceaf69167c3d31f7c910588b78d20374d57f137746a6c007f43355cb76b701 |
Provenance
The following attestation bundles were made for petkit_api-0.1.2.tar.gz
:
Publisher:
publish.yml
on Jezza34000/petkit-api
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
petkit_api-0.1.2.tar.gz
- Subject digest:
03eccf1bad3fac92cccbfb1ef45995f7c6a7f0712e53b831f1d81941e37442ed
- Sigstore transparency entry: 151752863
- Sigstore integration time:
- Predicate type:
File details
Details for the file petkit_api-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: petkit_api-0.1.2-py3-none-any.whl
- Upload date:
- Size: 24.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 612b86cc28aafe59a57a3814350d5f6a3b74b66d44c749c5eb03e8ccb828a90d |
|
MD5 | ab4d9159f9745b77bc8b3bf3e001e883 |
|
BLAKE2b-256 | 157ba5144f15121a096995e2aa877e36ed0fb6c13a40545ebce1a011c37efcec |
Provenance
The following attestation bundles were made for petkit_api-0.1.2-py3-none-any.whl
:
Publisher:
publish.yml
on Jezza34000/petkit-api
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
petkit_api-0.1.2-py3-none-any.whl
- Subject digest:
612b86cc28aafe59a57a3814350d5f6a3b74b66d44c749c5eb03e8ccb828a90d
- Sigstore transparency entry: 151752865
- Sigstore integration time:
- Predicate type: