Python library for iiko.services API
Project description
iiko-pkg
A Python library for the iiko.services API. This library provides a simple and easy-to-use interface for interacting with the iiko.services API.
Features
- Authentication with automatic token refresh
- Organizations management
- Menu retrieval and management
- Order creation and management
- Delivery management
- Terminal groups management
- Customer management
- Payment types, order types, and discounts
- Address management (regions, cities, streets)
- Employee management (couriers)
- Marketing sources
- Error handling with custom exceptions
- Type hints and validation with Pydantic models
- Comprehensive test suite
- And more...
Installation
pip install iiko-pkg
Or install from source:
git clone https://github.com/yourusername/iiko-pkg.git
cd iiko-pkg
pip install -e .
Requirements
- Python 3.7+
- requests
- pydantic (version 2.0.0 or higher)
API Key Setup
To use this library, you need an API key from iiko. For security reasons, it's recommended to use environment variables to store your API key instead of hardcoding it in your source code.
Setting up environment variables
# Linux/macOS
export IIKO_API_KEY="your_api_key"
# Windows (Command Prompt)
set IIKO_API_KEY=your_api_key
# Windows (PowerShell)
$env:IIKO_API_KEY="your_api_key"
Using the API key in your code
import os
from iiko_pkg import IikoClient
# Get API key from environment variable
API_KEY = os.environ.get("IIKO_API_KEY", "")
# Initialize the client with your API key
client = IikoClient(api_key=API_KEY)
Basic Usage
import os
from iiko_pkg import IikoClient
# Get API key from environment variable
API_KEY = os.environ.get("IIKO_API_KEY", "")
# Initialize the client with your API key
client = IikoClient(api_key=API_KEY)
# Get organizations
organizations = client.get_organizations()
for org in organizations.organizations:
print(f"Organization: {org.name} (ID: {org.id})")
# Get terminal groups for an organization
org_id = organizations.organizations[0].id
terminal_groups = client.get_terminal_groups([org_id])
print(terminal_groups)
# Get menu for an organization
menu = client.get_menu([org_id])
for product in menu.menus[0].products[:5]: # Print first 5 products
print(f"Product: {product.name} (Price: {product.price})")
# Create an order
order_response = client.create_order(
organization_id=org_id,
terminal_group_id=terminal_groups["terminalGroups"][0]["id"],
order={
"items": [
{
"productId": menu.menus[0].products[0].id,
"amount": 1
}
],
"phone": "+1234567890",
"customer": {
"name": "John Doe"
}
}
)
print(f"Order created with ID: {order_response.order_id}")
Advanced Usage
See the examples directory for more detailed examples.
Error Handling
The library provides custom exceptions for different types of errors:
import os
from iiko_pkg import IikoClient
from iiko_pkg.exceptions import AuthenticationError, ApiError, NetworkError, ValidationError
# Get API key from environment variable
API_KEY = os.environ.get("IIKO_API_KEY", "")
client = IikoClient(api_key=API_KEY)
try:
organizations = client.get_organizations()
except AuthenticationError as e:
print(f"Authentication error: {e}")
except ApiError as e:
print(f"API error {e.status_code}: {e.error_message}")
except NetworkError as e:
print(f"Network error: {e}")
except ValidationError as e:
print(f"Validation error: {e}")
Working with Models
All responses are returned as Pydantic models, which provide type hints and validation:
import os
from iiko_pkg import IikoClient
from iiko_pkg.models import Organization, Menu, Product
# Get API key from environment variable
API_KEY = os.environ.get("IIKO_API_KEY", "")
client = IikoClient(api_key=API_KEY)
# Get organizations
response = client.get_organizations()
org: Organization = response.organizations[0]
# Access organization properties
print(f"Organization: {org.name}")
print(f"Address: {org.restaurant_address}")
print(f"Coordinates: {org.latitude}, {org.longitude}")
# Get menu
menu_response = client.get_menu([org.id])
menu: Menu = menu_response.menus[0]
# Access menu properties
print(f"Menu: {menu.name}")
print(f"Categories: {len(menu.categories)}")
print(f"Products: {len(menu.products)}")
# Access product properties
product: Product = menu.products[0]
print(f"Product: {product.name}")
print(f"Price: {product.price}")
print(f"Category: {product.category_id}")
API Documentation
For more information about the iiko.services API, visit the official documentation at https://api-ru.iiko.services/
Development
Setup Development Environment
# Clone the repository
git clone https://github.com/yourusername/iiko-pkg.git
cd iiko-pkg
# Create a virtual environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install development dependencies
pip install -e ".[dev]"
Running Tests
python run_tests.py
Or using tox:
tox
Code Style
This project uses:
- Black for code formatting
- isort for import sorting
- flake8 for linting
- mypy for type checking
You can run all of these with:
tox -e lint
tox -e type
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
See CONTRIBUTING.md for more information.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iiko_pkg-0.1.2.tar.gz.
File metadata
- Download URL: iiko_pkg-0.1.2.tar.gz
- Upload date:
- Size: 30.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6db2143c0d4fb14b6a740ea8cf4b6302c82248d66767266b0e375c5173625ee6
|
|
| MD5 |
806a61dfc5db9ef2c2eaeb734e065ba9
|
|
| BLAKE2b-256 |
990b84ac166006123fc0276b4da633f5c9d13b62b025de6b4990c2a91d085598
|
File details
Details for the file iiko_pkg-0.1.2-py3-none-any.whl.
File metadata
- Download URL: iiko_pkg-0.1.2-py3-none-any.whl
- Upload date:
- Size: 42.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c984a46970bd95e8055476898a8a6f46d3ed75a167b5680c68edfaef9a2cb571
|
|
| MD5 |
945ee8d71f0527b3f621e80974e36e46
|
|
| BLAKE2b-256 |
5ca41c45367bd781edbc02672fbfc107e5978ad60c988427823b3d2950221a83
|