Skip to main content

Django Owo Integration

Project description

django-owo

Starting

These instructions will allow you to install the library in your python project.

Current features

  • Get default payload.
  • Create shipping.

Pre-requisitos

  • Python >= 3.7
  • Django >= 3
  • requests >= 2

Installation

  1. To get the latest stable release from PyPi:
pip install django-owo

or

  1. From a build
git clone https://gitlab.com/linets/ecommerce/oms/integrations/django-owo
cd {{project}}
python setup.py sdist

and, install in your project django

pip install {{path}}/django-owo/dist/{{tar.gz file}}
  1. Settings in django project
DJANGO_OWO = {
    'OWO': {
        'BASE_URL': '<OWO_BASE_URL>',
        'TOKEN': '<OWO_TOKEN>',
        'EMAIL': '<OWO_EMAIL>',
        'PASSWORD': '<OWO_PASSWORD>',
    },
    'SENDER': {
        'COMMERCE_ID': '<OWO_COMMERCE_ID>',
        'BRANCH_OFFICE_ID': '<OWO_BRANCH_OFFICE_ID>',
    }
}

Usage

  1. Create instance to be sent

    import json
    from types import SimpleNamespace
    
    dict_ = {
        'reference': '99999',
        'delivery_date': '2018-12-06 13:00:00'
        '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',
        'items': [
            {
                'code': 'SKU1234',
                'name': 'POLOS',
                'price': '2500',
                'qty': '2'
            },
            {
                'code': 'SKU12345',
                'name': 'SHORT',
                'price': '1500',
                'qty': '1'
            }
        ]
        '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))
    
  2. Get default payload:

from owo.handler import OwoHandler

handler = OwoHandler()
default_data = handler.get_default_payload(<instance>)
  1. Create shipping:
from owo.handler import OwoHandler

handler = OwoHandler()
default_data = handler.create_shipping(<default_data>)
  1. Get events:
from owo.handler import OwoHandler

handler = OwoHandler()

raw_data = {
    'tracking_number': 999999,
    'status': 'Entregado',
    'events': [{
        'city': 'Santiago'
        'state': 'RM',
        'description': 'Llego al almacén',
        'date': '12/12/2021'
    }]
}
response = handler.get_events(raw_data)

Output:
[{
    'city': 'Santiago'
    'state': 'RM',
    'description': 'Llego al almacén',
    'date': '12/12/2021'
}]
  1. Get status and if "is_delivered":
from owo.handler import OwoHandler

handler = OwoHandler()

raw_data = {
    'tracking_number': 999999,
    'status': 'Entregado',
    'events': [{
        'city': 'Santiago'
        'state': 'RM',
        'description': 'Llego al almacén',
        'date': '12/12/2021'
    }]
}
response = handler.get_status(raw_data)

Output:
('Entregado', True)
  1. Get shipping label:
from owo.handler import OwoHandler

handler = OwoHandler()
response = handler.get_shipping_label(tracking_number)

Output:
header: {'Content-Type' : 'application/pdf'}
body: bytes

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

django-owo-1.0.4.tar.gz (6.2 kB view details)

Uploaded Source

File details

Details for the file django-owo-1.0.4.tar.gz.

File metadata

  • Download URL: django-owo-1.0.4.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.15

File hashes

Hashes for django-owo-1.0.4.tar.gz
Algorithm Hash digest
SHA256 54c9330179b0a980ec932a8d7d9e159c65896099106a678fa1160904ae16d35d
MD5 ab7933893d6756913ac83a87357c3a51
BLAKE2b-256 890054dde72607c17466986873ca6e9d4984ab14d175f4deef5efade7cad4ef3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page