Subversion Repositories SmartDukaan

Rev

Rev 7137 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
7137 amar.kumar 1
#!/usr/bin/python
2
 
3
import optparse
4
import time
5
import datetime
6
import sys
7
from elixir import session
8
from random import randrange
9
from shop2020.clients.LogisticsClient import LogisticsClient
10
from shop2020.clients.CatalogClient import CatalogClient
11
from shop2020.clients.InventoryClient import InventoryClient
12
from shop2020.model.v1.order.impl.DataService import Attribute
13
from shop2020.thriftpy.logistics.ttypes import DeliveryType, PickUpType
14
 
15
if __name__ == '__main__' and __package__ is None:
16
    import os
17
    sys.path.insert(0, os.getcwd())
18
 
19
from shop2020.thriftpy.model.v1.order.ttypes import OrderStatus, TransactionServiceException, OrderType
20
from shop2020.model.v1.order.impl import DataService
21
from shop2020.model.v1.order.impl.DataService import Order, LineItem, Transaction
22
from shop2020.model.v1.order.impl.DataAccessors import get_order, close_session
23
from shop2020.model.v1.order.impl.DataAccessors import delhi_pincodes
24
 
25
def cancel(order):
26
    '''
27
    Cancel
28
    '''
29
    print("Your session has been closed")
30
    return
31
 
32
def process_order(order, bulkorderitemid):
33
    '''
34
    Process Order
35
    '''
36
 
37
    bulk_order = Order()
38
 
39
    bulk_order.transaction = order.transaction
40
 
41
    bulk_order.customer_id = order.customer_id
42
    bulk_order.customer_email = order.customer_email
43
    bulk_order.customer_name = order.customer_name
44
    bulk_order.customer_pincode = order.customer_pincode
45
    bulk_order.customer_address1 = order.customer_address1
46
    bulk_order.customer_address2 = order.customer_address2
47
    bulk_order.customer_city = order.customer_city
48
    bulk_order.customer_state = order.customer_state
49
    bulk_order.customer_mobilenumber = order.customer_mobilenumber
50
    bulk_order.total_weight = order.total_weight
51
    bulk_order.status = OrderStatus.ACCEPTED
52
    bulk_order.statusDescription = "In Process";
53
    bulk_order.created_timestamp = order.created_timestamp
54
    bulk_order.accepted_timestamp = datetime.datetime.now()
55
    bulk_order.cod = order.cod
56
    bulk_order.orderType = OrderType.B2Cbulk
57
    bulk_order.pickupStoreId = 0
58
    bulk_order.otg = 0
59
    bulk_order.insurer = 0
60
    bulk_order.insuranceAmount = 0
61
 
62
    logistics_client = LogisticsClient().get_client()
63
    logistics_info = logistics_client.getLogisticsInfo(order.customer_pincode, 1, DeliveryType.PREPAID, PickUpType.SELF)
64
    bulk_order.logistics_provider_id = logistics_info.providerId;
65
    bulk_order.tracking_id = logistics_info.airway_billno
66
    bulk_order.airwaybill_no = logistics_info.airway_billno
67
 
68
    bulk_order.expected_delivery_time = order.expected_delivery_time
69
    bulk_order.promised_delivery_time = order.promised_delivery_time
70
    bulk_order.expected_shipping_time = order.expected_shipping_time
71
    bulk_order.promised_shipping_time = order.promised_shipping_time
72
 
73
    catalog_client = CatalogClient().get_client()
74
    item = catalog_client.getItem(bulkorderitemid)
75
 
76
    litem = LineItem()
77
    litem.item_id = item.id
78
    litem.productGroup = item.productGroup
79
    litem.brand = item.brand
80
    litem.model_number = item.modelNumber
81
    litem.model_name = item.modelName
82
    litem.color = item.color
83
    litem.extra_info = "Freebie Order for Order ID " + str(order.id)
84
    litem.quantity = 1
85
    litem.unit_price = 0.01
86
    litem.unit_weight = item.weight
87
    litem.total_price = 0.01
88
    litem.total_weight = item.weight
89
    litem.vatRate = 5.0
90
 
91
    bulk_order.lineitems.append(litem)
92
 
93
    bulk_order.total_amount = 0.01
94
 
95
    inventory_client = InventoryClient().get_client()
96
    item_availability = inventory_client.getItemAvailabilityAtLocation(bulk_order.lineitems[0].item_id,1)
97
    print "0=" + str(item_availability[0]) + " 1=" +str(item_availability[1]) + " 2=" + str(item_availability[2]) 
98
    bulk_order.warehouse_id = item_availability[2]
7410 amar.kumar 99
    bulk_order.fulfilmentWarehouseId = item_availability[0]
7137 amar.kumar 100
 
101
    session.commit()
102
 
103
    print "New Bulk OrderId : " + str(bulk_order.id)
104
 
105
    return 
106
 
107
 
108
ACTIONS = {0: cancel,
109
           1: process_order
110
           }
111
 
112
def get_py_datetime(time_string):
113
    time_format = "%Y-%m-%d %H%M"
114
    mytime = time.strptime(time_string, time_format)
115
    return datetime.datetime(*mytime[:6])
116
 
117
def main():
118
    parser = optparse.OptionParser()
119
    parser.add_option("-H", "--host", dest="hostname",
120
                      default="localhost",
121
                      type="string", help="The HOST where the DB server is running",
122
                      metavar="HOST")
123
    parser.add_option("-O", "--order", dest="orderId",
124
                      default =0,
125
                      type="int", help="OrderId for whom bulk order is to be created",
126
                      metavar="NUM")
127
    parser.add_option("-B", "--bulkorderitemid", dest="bulkorderitemid",
128
                      default =0,
129
                      type="int", help="ItemId which is to be given as freebie",
130
                      metavar="NUM")
131
    (options, args) = parser.parse_args()
132
    if len(args) != 0:
133
        parser.error("You've supplied extra arguments. Are you sure you want to run this program?")
134
 
135
    if options.orderId == 0:
136
        print "Usage : -O OrderId -H Hostname -B BulkorderId"
137
        return
138
    DataService.initialize(db_hostname=options.hostname, echoOn=False)
139
 
140
    orderId = options.orderId
141
    bulkorderitemid = options.bulkorderitemid
142
    try:
143
        order = get_order(orderId)
144
        print("Please check the details of the order below and ensure that it's the same order which you want to modify:")
145
        print("Order Id:\t\t" + str(order.id))
146
        print("Customer Name:\t\t" + order.customer_name)
147
        print("Pincode:\t\t" + order.customer_pincode)
148
        print("Amount:\t\t\t" + str(order.total_amount))
149
        print("Created On:\t\t" + str(order.created_timestamp))
150
        print("Current Status:\t\t" + str(order.status))
151
        print("Status Description:\t\t" + order.statusDescription)
152
        print("Logistics provider id:\t\t" + str(order.logistics_provider_id))
153
        print("Airway bill number:\t\t" + order.airwaybill_no)
154
        print("Ordered Items description:")
155
        for lineitem in order.lineitems:
156
            print("Item Id:" + str(lineitem.item_id) + "\tBrand: " + str(lineitem.brand) + "\tModel: " + str(lineitem.model_number) + "\tColor: " + str(lineitem.color))
157
        print
158
        print
159
        print("You can perform following operations:")
160
        for (key, val) in ACTIONS.iteritems():
161
            print("[" + str(key) + "]" + val.__doc__ )
162
 
163
        raw_action = raw_input("What do you want to do? ")
164
        if raw_action is None or raw_action == "":
165
            print("Your session has been closed.")
166
            return
167
        try:
168
            action = int(raw_action)
169
        except ValueError:
170
            print("Invalid input.")
171
            return
172
        if action > max(ACTIONS.keys()):
173
            print("Invalid input.")
174
            return
175
        ACTIONS[action](order,bulkorderitemid)
176
    except TransactionServiceException as tsex:
177
        print tsex.message
178
    finally:
179
        close_session()
180
 
181
if __name__ == '__main__':
182
    main()