Django Bluexpress Integration
Project description
Linets Bluexpress
Starting 🚀
These instructions will allow you to install the library in your django project.
Current features 📋
- Generate order in Bluexpress.
- Generate default data for create order in Bluexpress.
Pre-requisitos 📋
- Python >= 3.7
- Django >= 3
- zeep >= 4
Installation 🔧
- To get the latest stable release from PyPi:
pip install django-bluexpress
or
- From a build
git clone https://gitlab.com/linets/ecommerce/oms/integrations/oms-bluexpress
cd {{project}} && git checkout develop
python setup.py sdist
and, install in your project django
pip install {{path}}/oms-bluexpress/dist/{{tar.gz file}}
- Settings in django project
DJANGO_BLUEXPRESS = {
'BLUEXPRESS': {
'BASE_URL_REST': '<BLUEXPRESS_BASE_URL_REST>',
'ISSUE_WSDL': '<BLUEXPRESS_ISSUE_WSDL>',
'TOKEN_ID': '<BLUEXPRESS_TOKEN_ID>',
'USER_COD': '<BLUEXPRESS_USER_COD>',
'COMPANY_CODE': '<BLUEXPRESS_COMPANY_CODE>',
'SHIPPING_TYPE': '<BLUEXPRESS_SHIPPING_TYPE>',
'PAYMENT_TYPE': '<BLUEXPRESS_PAYMENT_TYPE>',
'PRODUCT_CODE': '<BLUEXPRESS_PRODUCT_CODE>',
'CURRENCY_CODE': '<BLUEXPRESS_CURRENCY_CODE>',
'SERVICE_TYPE_CODE': '<BLUEXPRESS_SERVICE_TYPE_CODE>',
'PRODUCT_FAMILY_CODE': '<BLUEXPRESS_PRODUCT_FAMILY_CODE>',
'PRINT_FORMAT_CODE': '<BLUEXPRESS_PRINT_FORMAT_CODE>',
},
'SENDER': {
'PERSON_CODE': '<BLUEXPRESS_PERSON_CODE>',
'ACCOUNT_CLIENT': '<BLUEXPRESS_ACCOUNT_CLIENT>',
'RUT': '<BLUEXPRESS_RUT>',
'DV': '<BLUEXPRESS_DV>',
'NAME': '<BLUEXPRESS_NAME>',
'STREET': '<BLUEXPRESS_STREET>',
'NUMBER': '<BLUEXPRESS_NUMBER>',
'FLOOR': '<BLUEXPRESS_FLOOR>',
'DPTO': '<BLUEXPRESS_DPTO>',
'PHONE_PREFIX': '<BLUEXPRESS_PHONE_PREFIX>',
'PHONE_NUMBER': '<BLUEXPRESS_PHONE_NUMBER>',
'PHONE_ANNEXED': '<BLUEXPRESS_PHONE_ANNEXED>',
'COUNTRY_CODE': '<BLUEXPRESS_COUNTRY_CODE>',
'REGION_CODE': '<BLUEXPRESS_REGION_CODE>',
'COMMUNE_CODE': '<BLUEXPRESS_COMMUNE_CODE>',
'LOCATION_CODE': '<BLUEXPRESS_LOCATION_CODE>'
},
'DESTINATARY': {
'PHONE_PREFIX': '<BLUEXPRESS_PHONE_PREFIX>',
'COUNTRY_CODE': '<BLUEXPRESS_COUNTRY_CODE>',
},
}
Usage 🔧
-
Create instance to be sent
import json from types import SimpleNamespace dict_ = { 'reference': '99999', 'lumps': 1, 'created_at': '12/12/21', 'shipping_date': '12/12/21', 'expiration_date': '26/12/21' 'tracking_code': '6075620-1', 'transport_guide_number': '1121632479536-01-1', 'purchase_number': 'CLV0048146676851-1', 'agency_id': '123', # if you need use pickup 'customer': { 'first_name': 'Marcos', 'last_name': 'Sac', 'full_name': 'Marcos Sac', 'phone': '932932932', 'email': 'test@gmail.com', 'rut': '16936195-9' }, 'address': { 'street': 'ALEJANDRO VENEGAS CADIZ', 'number': '513', 'unit': 'DEPTO 6A', 'full_address': 'ALEJANDRO VENEGAS CADIZ 513 DEPTO 6A' }, 'commune': { 'name': 'Aisen', 'code': '', 'zone_code': '11201', 'zone_post': 'WPA', }, 'location': { 'code': 'MONTANDON', 'name': 'MNN', }, 'region': { 'name': 'Aysén del General Carlos Ibáñez del Campo', 'code': '11', 'iso_code': 'CL-XI', } } instance = json.loads(json.dumps(dict_), object_hook=lambda attr: SimpleNamespace(**attr))
-
Generate default data for create a order in Bluexpress:
from bluexpress.handler import BluexpressHandler
handler = BluexpressHandler()
default_data = handler.get_default_payload(instance)
Output:
- Create a order in Bluexpress:
from bluexpress.handler import BluexpressHandler
handler = BluexpressHandler()
response = handler.create_shipping(default_data)
Output:
- Get events:
from bluexpress.handler import BluexpressHandler
handler = BluexpressHandler()
raw_data = {
'carrier_tracking_number': int.
'tracking_data': xml string.
}
response = handler.get_events(raw_data)
Output:
[{
'city': string
'state': string
'description': string
'date': string
}, ...]
- Get status and if "is_delivered":
from bluexpress.handler import BluexpressHandler
handler = BluexpressHandler()
raw_data = {
'carrier_tracking_number': int.
'tracking_data': xml string.
}
response = handler.get_status(raw_data)
Output:
('Entregado', True)
- Get shipping label:
from bluexpress.handler import BluexpressHandler
handler = BluexpressHandler()
response = handler.get_shipping_label(tracking_number)
Output:
{
"status": true,
"data": [
{
"base64": "base64 string"
}
]
}
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
File details
Details for the file corona-bluexpress-1.5.9.tar.gz
.
File metadata
- Download URL: corona-bluexpress-1.5.9.tar.gz
- Upload date:
- Size: 8.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eb00b1ba017d2b153e5ae2e903c5961afdcc2e96ee0bb705dba3d932acf83314 |
|
MD5 | 465c868d1342a0aad363a9c272bd422d |
|
BLAKE2b-256 | 2011b107467f9a325939e9d8396225c615bd2a70aa9c796314a69dd3c8e16a63 |