A Python package for tracking parcels from Bangladeshi courier services
Project description
Bangladeshi Parcel Tracker
A Python package for tracking parcels from various Bangladeshi courier services including Redx, Steadfast, Pathao, Rokomari, and Sundarban.
Features
- 🚚 Support for major Bangladeshi courier services
- 📦 Unified tracking interface across all providers
- ⏱️ Detailed timeline of parcel journey
- 🎯 Easy-to-use delivery status checking
- 🔄 Real-time tracking with live API integration
- 📊 Comprehensive tracking event data
- 🐍 Python 3.8+ support
- 🛠️ Command-line interface included
Supported Courier Services
- Redx - Leading courier service in Bangladesh
- Steadfast - Reliable delivery solutions
- Pathao - Fast and efficient courier service
- Rokomari - Book and product delivery specialist
- Sundarban - Comprehensive logistics and courier solutions
Installation
The package is available on PyPI. Install it using pip:
pip install bangladeshi-parcel-tracker
For development installation:
git clone https://github.com/yourusername/bangladeshi-parcel-tracker.git
cd bangladeshi-parcel-tracker
pip install -e .
Quick Start
Basic Usage
from bangladeshi_parcel_tracker import RedxTracker, SteadfastTracker
# Track a Redx parcel
tracker = RedxTracker("RDX123456789")
events = tracker.track()
# Check if delivered
if tracker.is_delivered():
print("Package has been delivered!")
else:
print(f"Current status: {tracker.get_current_status().value}")
# Print timeline
for event in events:
print(event)
Using Different Providers
from bangladeshi_parcel_tracker import (
RedxTracker, SteadfastTracker,
PathaoTracker, RokomariTracker, SundarbanTracker
)
tracking_number = "YOUR_TRACKING_NUMBER"
# For Pathao and Rokomari, you may need phone number
phone_number = "01700000000" # Required for some providers
# Choose your provider
trackers = {
'redx': RedxTracker(tracking_number),
'steadfast': SteadfastTracker(tracking_number),
'pathao': PathaoTracker(tracking_number, phone=phone_number),
'rokomari': RokomariTracker(tracking_number, phone=phone_number),
'sundarban': SundarbanTracker(tracking_number)
}
for name, tracker in trackers.items():
try:
events = tracker.track()
print(f"\\n{tracker.provider_name} Tracking:")
print(f"Status: {tracker.get_current_status().value}")
print(f"Delivered: {tracker.is_delivered()}")
print(f"Last Update: {tracker.get_last_update()}")
for event in events:
print(f" {event}")
except Exception as e:
print(f"Error tracking with {name}: {e}")
Command Line Interface
The package includes a powerful CLI for tracking parcels from the terminal:
Installation & Usage
After installing the package from pip, you can use the bangladeshi-parcel-tracker command:
# Basic usage
bangladeshi-parcel-tracker <provider> <tracking_number>
# Show help
bangladeshi-parcel-tracker --help
# Show version
bangladeshi-parcel-tracker --version
CLI Examples
# Track with Redx (detailed timeline)
bangladeshi-parcel-tracker redx RDX123456789
# Track with Steadfast (status only)
bangladeshi-parcel-tracker steadfast SF987654321 --status-only
# Track with Pathao (JSON output) - requires phone number
bangladeshi-parcel-tracker pathao PA456789123 --phone 01700000000 --json
# Track with Rokomari (detailed timeline) - requires phone number
bangladeshi-parcel-tracker rokomari RK789123456 --phone 01700000000 --detailed
# Track with Sundarban (detailed timeline)
bangladeshi-parcel-tracker sundarban 70003000778899 --detailed
CLI Options
--status-only,-s: Show only the current delivery status--detailed,-d: Show detailed timeline with all events (default)--json,-j: Output results in JSON format--phone,-p: Phone number (required for Pathao and Rokomari)--version,-v: Show version information--help,-h: Show help message
CLI Output Examples
Status Only Output:
📊 Tracking Status for RDX123456789
==================================================
Provider: Redx
Status: 🚛 Out For Delivery
Delivered: ❌ No
Last Update: 2025-01-15 15:45:00
Detailed Timeline:
📦 Detailed Tracking for SF987654321
============================================================
Provider: Steadfast
Current Status: ✅ Delivered
Delivered: ✅ Yes
Total Events: 4
📅 Timeline:
------------------------------------------------------------
1. ⏳ [2025-01-15 08:00:00] Pending
📍 Location: Steadfast Hub
📝 Order received and processing
2. 📦 [2025-01-15 10:30:00] Picked Up
📍 Location: Pickup Point
📝 Package collected from merchant
3. 🚚 [2025-01-15 14:15:00] In Transit
📍 Location: Transit Hub
📝 Package in transit to destination
4. ✅ [2025-01-15 16:00:00] Delivered
📍 Location: Customer Address
📝 Package delivered successfully
JSON Output:
{
"tracking_number": "PA456789123",
"provider": "Pathao",
"current_status": "in_transit",
"is_delivered": false,
"last_update": "2025-01-15T13:20:00",
"total_events": 3,
"events": [
{
"timestamp": "2025-01-15T09:15:00",
"status": "pending",
"location": "Pathao Warehouse",
"description": "Parcel received at warehouse",
"details": null
}
]
}
API Reference
BaseTracker
All provider classes inherit from BaseTracker and implement these methods:
Properties
provider_name: str- Name of the courier servicetracking_number: str- The tracking/consignment number
Methods
track() -> List[TrackingEvent]- Fetch tracking eventsis_delivered() -> bool- Check if parcel is deliveredget_current_status() -> TrackingStatus- Get current tracking statusget_last_update() -> Optional[datetime]- Get timestamp of last updaterefresh() -> List[TrackingEvent]- Force refresh tracking data
TrackingEvent
Represents a single tracking event:
@dataclass
class TrackingEvent:
timestamp: datetime
status: TrackingStatus
location: Optional[str] = None
description: Optional[str] = None
details: Optional[str] = None
TrackingStatus
Enumeration of possible tracking statuses:
PENDING- Order received/processingPICKED_UP- Package picked upIN_TRANSIT- Package in transitOUT_FOR_DELIVERY- Out for deliveryDELIVERED- Successfully deliveredRETURNED- Returned to senderCANCELLED- Order cancelledFAILED_DELIVERY- Delivery attempt failedUNKNOWN- Status unknown
Error Handling
The package provides a custom TrackingError exception:
from bangladeshi_parcel_tracker import TrackingError
try:
tracker = RedxTracker("INVALID123")
events = tracker.track()
except TrackingError as e:
print(f"Tracking failed: {e}")
print(f"Provider: {e.provider}")
print(f"Tracking Number: {e.tracking_number}")
Development
Setting up Development Environment
# Clone the repository
git clone https://github.com/yourusername/bangladeshi-parcel-tracker.git
cd bangladeshi-parcel-tracker
# Install in development mode
pip install -e .
# Format code
black src/
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
Guidelines
- Follow the existing code style (Black formatting)
- Update documentation as needed
- Ensure your changes work with the existing API structure
Provider Implementation
To add a new courier service provider:
- Create a new file in
src/bangladeshi_parcel_tracker/providers/ - Inherit from
BaseTracker - Implement the
track()method - Add provider to
__init__.py
Example:
from ..base import BaseTracker, TrackingEvent, TrackingStatus
class NewProviderTracker(BaseTracker):
@property
def provider_name(self) -> str:
return "New Provider"
def track(self) -> List[TrackingEvent]:
# Implementation here
pass
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Available on PyPI as
bangladeshi-parcel-tracker - Thanks to all Bangladeshi courier services for their tracking systems
- Built with ❤️ for the Bangladeshi developer community
Disclaimer
This package is not officially affiliated with any of the courier services. It's an independent tool created to help developers integrate parcel tracking functionality into their applications.
The package uses publicly available tracking APIs and websites to fetch parcel information. Please use responsibly and respect the terms of service of each courier provider.
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 bangladeshi_parcel_tracker-1.3.0.tar.gz.
File metadata
- Download URL: bangladeshi_parcel_tracker-1.3.0.tar.gz
- Upload date:
- Size: 21.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18724b01aab047d505528fbf331b78d4be95058c8a4d421ba21fa434b9250e17
|
|
| MD5 |
426930dde6da4f8500dff9b0e977d8b0
|
|
| BLAKE2b-256 |
3846ecbf0619b1bbf94fa20133fb7fda32f297e622b916b9413e02009f4890af
|
Provenance
The following attestation bundles were made for bangladeshi_parcel_tracker-1.3.0.tar.gz:
Publisher:
pypi.yml on mdminhazulhaque/bangladeshi-parcel-tracker
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bangladeshi_parcel_tracker-1.3.0.tar.gz -
Subject digest:
18724b01aab047d505528fbf331b78d4be95058c8a4d421ba21fa434b9250e17 - Sigstore transparency entry: 352945096
- Sigstore integration time:
-
Permalink:
mdminhazulhaque/bangladeshi-parcel-tracker@275bad681f02c15eff88cfdb4dc1ef64a10e9b84 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/mdminhazulhaque
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@275bad681f02c15eff88cfdb4dc1ef64a10e9b84 -
Trigger Event:
push
-
Statement type:
File details
Details for the file bangladeshi_parcel_tracker-1.3.0-py3-none-any.whl.
File metadata
- Download URL: bangladeshi_parcel_tracker-1.3.0-py3-none-any.whl
- Upload date:
- Size: 27.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29f6b648d49b2092b317fcadf87d83c589e6bf44eb77686e58ff90367155b90a
|
|
| MD5 |
36aed33cb7c76e369a297ab43344295d
|
|
| BLAKE2b-256 |
8cf47124b1cc28d4f55a286739f04241899bfe754d32df3fac8c7ea48863d75a
|
Provenance
The following attestation bundles were made for bangladeshi_parcel_tracker-1.3.0-py3-none-any.whl:
Publisher:
pypi.yml on mdminhazulhaque/bangladeshi-parcel-tracker
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bangladeshi_parcel_tracker-1.3.0-py3-none-any.whl -
Subject digest:
29f6b648d49b2092b317fcadf87d83c589e6bf44eb77686e58ff90367155b90a - Sigstore transparency entry: 352945135
- Sigstore integration time:
-
Permalink:
mdminhazulhaque/bangladeshi-parcel-tracker@275bad681f02c15eff88cfdb4dc1ef64a10e9b84 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/mdminhazulhaque
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@275bad681f02c15eff88cfdb4dc1ef64a10e9b84 -
Trigger Event:
push
-
Statement type: