Tradekart wrapper SDK for Groww trading APIs
Project description
TradeKart API
TradeKart API is a Python wrapper around the official Groww SDK with a service-oriented design for trading workflows.
It provides custom service layers for common operations (Orders, Portfolio) with request models, response models, and consistent exception handling so teams can build reliable trading integrations faster.
Why TradeKart API
- Built on top of
growwapi, so you can continue to use Groww's official SDK. - Clean service abstraction for business use-cases instead of raw SDK calls everywhere.
- Typed request models for safer payload construction.
- Structured response handling for predictable downstream processing.
- Custom exceptions for easier debugging and application-level error handling.
Installation
pip install tradekartapi
Quick Start (Jupyter / Notebook)
from tradekartapi.client import TradeKartClient
from growwapi import GrowwAPI
access_token = "your_access_token"
client = TradeKartClient.from_access_token(access_token, GrowwAPI)
# Now client is ready to use the service
Service Architecture
TradeKart API uses:
- Groww SDK Adapter to initialize and hold the SDK client.
- Custom Services to expose trading operations as business-level methods.
- Models to keep request and response shapes explicit and reusable.
Available Services
- Order Service
- Place order
- Modify order
- Cancel order
- Get order status
- Get order list
- Get order detail
- Portfolio Service
- Get holdings
- Get positions
- Get positions by trading symbol
Margin Service
Margin-related service support is planned as part of upcoming releases.
Orders Example
from tradekartapi.models.orders import PlaceOrderRequest
from tradekartapi.models.annexures import (
Exchange, Segment, Product, OrderType, TransactionType, Validity
)
request = PlaceOrderRequest(
trading_symbol="SBIN",
quantity=1,
validity=Validity.DAY,
exchange=Exchange.NSE,
segment=Segment.CASH,
product=Product.CNC,
order_type=OrderType.MARKET,
transaction_type=TransactionType.BUY,
)
response = client.order_service.place_order(request)
print(response)
Portfolio Example
holdings = client.portfolio_service.get_holdings()
positions = client.portfolio_service.get_positions()
print([h.to_dict() for h in holdings])
print([p.to_dict() for p in positions])
Response Formats
Depending on the service method, you may receive:
- Native
dictfrom direct SDK passthrough methods. - Dataclass-based response objects from modeled service methods.
For dataclass responses, use:
to_dict()for Python dictionary output.to_json()for JSON string output.
Error Handling
TradeKart API raises structured custom exceptions for validation and service-level failures, making it easier to map failures to API responses or logs in production systems.
Compatibility
- Python
>=3.10 - Depends on
growwapi
Changelog
Full changelog: https://tradekartapi.readthedocs.io/en/latest/changelog.html
License
MIT
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
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 tradekartapi-0.1.4.tar.gz.
File metadata
- Download URL: tradekartapi-0.1.4.tar.gz
- Upload date:
- Size: 15.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2eef55e200fd15482bddc568f4bb0f92fb1109bdc558bbd1ea4d92f86bd7e24
|
|
| MD5 |
be9dd5651df6c553e3c622080acc4e6d
|
|
| BLAKE2b-256 |
198f9c51522edcf60787542e73695dbe93f1d09334a4b000a3d41614a92c6ce1
|
File details
Details for the file tradekartapi-0.1.4-py3-none-any.whl.
File metadata
- Download URL: tradekartapi-0.1.4-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b00d082038e71a5027592fa90e8c797c8f9e675641634b31cf13b82b1c0e2149
|
|
| MD5 |
22bcc8fcee4cbd3fba7e1177e59ef249
|
|
| BLAKE2b-256 |
f2b47b35f13688cdb28e5f728c4e17104fd3c03331d3a241883171705a25b161
|