Subversion Repositories SmartDukaan

Rev

Rev 21367 | Rev 22043 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
104 ashish 1
'''
2
Created on 29-Mar-2010
3
 
4
@author: ashish
5
'''
6056 amit.gupta 6
from elixir import session
11902 amit.gupta 7
from shop2020.model.v1.order.impl import DataService, RedExpressUpdateService, \
7363 rajveer 8
    RechargeService
6000 mandeep.dh 9
from shop2020.model.v1.order.impl.Convertors import to_t_transaction, to_t_alert, \
10
    to_t_order, to_t_lineitem, to_t_payment_settlement, to_t_verification_agent, \
11902 amit.gupta 11
    to_t_attribute, to_t_rechargeTransaction, to_t_frc, to_t_hotspot, \
12
    to_t_sourcedetail, to_t_amazonorder, to_t_storeOrderDetail, \
13
    to_t_storeOrderCollection, to_t_hotspotServiceMatrix, to_t_ebayOrder, \
14134 amit.gupta 14
    to_t_amazonFbaSalesSnapshot, to_t_snapdealOrder, to_t_flipkartOrder, \
19836 amit.gupta 15
    to_t_amazonFbaOrderReturn, to_t_flipkartAdvantageOrder, to_t_hsOrder, \
16
    to_t_Creditor, to_t_CreditHistory, to_t_UserSanction, to_t_LoanHistory, \
17
    to_t_PaginatedCreditHistory, to_t_PaginatedLoanHistory, \
18
    to_t_PaginatedUserSanction, to_t_returnOrderInfo, to_t_returnTransaction, \
21090 kshitij.so 19
    to_t_rPickupRequest, to_t_OutstandingPayments, to_t_ShipmentLogisticsCostDetail, to_t_pmsa
6000 mandeep.dh 20
from shop2020.model.v1.order.impl.DataAccessors import create_transaction, \
21
    get_transactions_for_customer, get_transaction_status, get_line_items_for_order, \
22
    get_transaction, get_transactions_for_shopping_cart_id, \
23
    change_transaction_status, get_orders_for_customer, get_orders_for_transaction, \
24
    get_order, get_returnable_orders_for_customer, \
25
    get_cancellable_orders_for_customer, get_orders_by_billing_date, get_all_orders, \
26
    change_order_status, get_alerts, add_alert, add_billing_details, close_session, \
27
    accept_order, mark_orders_as_picked_up, mark_orders_as_delivered, \
28
    mark_orders_as_rto, order_outofstock, batch_orders, update_non_delivery_reason, \
29
    enqueue_transaction_info_email, get_undelivered_orders, get_order_for_customer, \
30
    get_valid_order_count, get_cust_count_with_successful_txn, \
31
    get_valid_orders_amount_range, get_valid_orders, toggle_doa_flag, \
32
    request_pickup_number, authorize_pickup, receive_return, validate_doa, \
33
    reship_order, refund_order, get_return_orders, process_return, get_return_order, \
34
    mark_doas_as_picked_up, verify_order, is_alive, get_orders_by_shipping_date, \
35
    update_weight, change_warehouse, change_product, add_delay_reason, \
36
    reconcile_cod_collection, get_transactions_requiring_extra_processing, \
37
    mark_transaction_as_processed, get_item_wise_risky_orders_count, \
38
    accept_order_for_item, get_orders_in_batch, get_order_count, \
39
    get_ebs_settlement_summaries, mark_order_cancellation_request_received, \
40
    mark_order_cancellation_request_denied, refund_transaction, \
41
    mark_order_cancellation_request_confirmed, \
42
    mark_transaction_as_payment_flag_removed, accept_orders_for_item_id, \
43
    mark_orders_as_po_raised, mark_orders_as_reversal_initiated, \
44
    mark_orders_as_not_available, update_shipment_address, mark_orders_as_timeout, \
45
    get_order_for_awb, mark_orders_as_shipped_from_warehouse, mark_alerts_as_seen, \
46
    mark_order_doa_request_received, mark_order_doa_request_authorized, \
47
    mark_order_return_request_received, mark_order_return_request_authorized, \
48
    add_invoice_number, get_reshipped_order_ids, validate_return_product, \
49
    get_orders_for_provider_for_status, save_ebs_settlement_summary, \
50
    get_ebs_settlement_date, save_payment_settlements, mark_ebs_settlement_uploaded, \
51
    get_billed_orders_for_vendor, get_settlement_for_Prepaid, \
52
    get_settlements_by_date, get_slipped_sipping_date_orders, \
53
    mark_order_as_lost_in_transit, get_cancelled_orders, mark_order_as_delivered, \
54
    mark_return_orders_as_picked_up, update_orders_as_PORaised, \
55
    get_order_distribution_by_status, get_orders_not_met_expected_delivery_date, \
56
    mark_orders_as_local_connected, mark_orders_as_destinationCityReached, \
57
    mark_orders_as_firstDeliveryAttempted, get_non_delivered_orders_by_courier, \
58
    get_orders_not_local_connected, get_doas_not_picked_up, \
59
    get_return_orders_not_picked_up, get_orders_not_picked_up, get_rto_orders, \
60
    get_order_list, get_order_ids_for_status, update_orders_as_paid_to_vendor, \
61
    update_COD_agent, get_refunded_orders_marked_paid, get_settlement_for_Cod, \
62
    get_order_list_for_vendor, update_order_only_as_paid_to_vendor, \
63
    get_all_verification_agents, get_all_attributes_for_order_id, \
64
    set_order_attribute_for_transaction, get_billed_orders, get_all_return_orders, \
65
    mark_order_as_received_at_store, get_receive_pending_orders, \
66
    get_received_at_store_orders, mark_orders_as_returned_from_store, \
6056 amit.gupta 67
    set_order_attributes, get_orders_collection_at_store, get_order_attribute_value, \
68
    change_jacket_number, mark_order_as_rto_in_transit, get_recharge_order, \
69
    get_recharge_orders, update_recharge_order_status, activate_recharge_txn, \
70
    get_user_wallet, get_user_wallet_history, get_service_providers, \
6396 amit.gupta 71
    get_service_provider_for_device, get_recharge_orders_for_transaction, \
20931 kshitij.so 72
    get_recharge_orders_for_device, \
6396 amit.gupta 73
    get_recharge_orders_for_status, get_plans_for_operator, get_recharge_statistics, \
74
    validate_recharge, get_recharge_denominations, update_availability_status, \
6821 amar.kumar 75
    get_misc_charges, get_available_emi_schemes, refund_recharge_order, \
7073 anupam.sin 76
    create_recharge_transaction, get_physical_orders, get_document, retrieve_invoice, \
7125 amit.gupta 77
    change_shipping_address, get_recharge_transactions, get_recharge_transaction, \
7151 amit.gupta 78
    get_frcs, get_hotspot_store, get_circle, retrieve_hotspot_recharge_invoice, \
7190 amar.kumar 79
    get_recharge_trans, split_freebie_order, get_recharge_transactions_by_number, \
11902 amit.gupta 80
    update_hotspot_store_password, get_source_detail, get_all_circles, delete_frcs, \
81
    topup_company_wallet, get_wallet_balance_for_company, add_amazon_order, \
82
    update_amazon_order_status, get_amazon_order, get_amazon_orders_shipped, \
83
    get_amazon_orders_cancelled, get_orders_for_store, \
84
    get_store_order_advance_invoice, add_frc, add_series, get_store_order_detail, \
85
    save_store_order_detail, get_all_edc_banks, save_refund_amounts_for_store_order, \
86
    get_collections_for_store, get_amazon_orders_to_acknowledge, \
87
    change_amazon_order_status, update_timestamp_for_amazon_order, \
88
    update_source_detail_timestamp, get_amazon_order_by_amazonorderid, \
89
    get_orders_by_mobile_number, get_orders_by_amazon_id, change_courier_provider, \
90
    convert_store_to_normal, update_freebie_item, update_order_AWB, \
20641 amit.gupta 91
    get_hotspot_service_matrices, get_orders_by_vendor, \
92
    get_orders_count_created_after_timestamp_for_source, \
11902 amit.gupta 93
    get_min_created_timestamp_undelivered_orders_for_source, \
20641 amit.gupta 94
    get_recharge_order_status, get_recharge_transaction_status, \
95
    accept_package_orders, get_group_orders_by_logistics_txn_id, \
96
    add_billing_details_for_groupped_orders, get_invoice_format_logistics_txn_id, \
97
    split_bulk_order, move_orders_to_correct_warehouse, \
98
    verify_orders_for_transaction, get_creditor_info, update_creditor_info, \
99
    get_user_sanction_details, update_user_sanction, get_credit_history_records, \
100
    process_credit_transaction, get_loan_payable_for_user_to_creditor, \
101
    get_loan_history_records, process_loan_transaction, \
102
    get_credit_history_records_paginated, get_loan_history_records_paginated, \
103
    get_user_sanction_details_paginated, get_orders_in_batch_as_promised_shipping, \
19836 amit.gupta 104
    set_order_attribute_for_master_order_id, update_master_order_awb, \
105
    add_or_update_shipment_logistics_cost_details, get_return_order_info, \
106
    get_return_orders_info_map, update_return_order_info, \
107
    bulk_update_return_order_info, get_return_orders_as_per_warehouse, \
108
    create_return_transaction, get_return_transactions_for_customer, \
109
    get_return_transaction, change_return_transaction_status, \
110
    create_return_pickup_request, update_return_pickup_request, \
111
    get_return_orders_for_return_transaction, receive_return_pickup, \
112
    validate_return_pickup, process_return_pickup, mark_return_transaction_complete, \
113
    refund_return_transaction_payment, get_eligible_orders_for_return, \
114
    get_eligible_return_orders_for_pickup, validate_return_transaction, \
115
    get_return_pickup_request, mark_return_not_required_orders_as_processed, \
19973 amit.gupta 116
    get_all_return_orders_for_return_pickup_request, unaccept_order, \
19980 amit.gupta 117
    get_outstanding_payments, mark_payment_settled, get_seller_info, \
20122 kshitij.so 118
    get_warehouse_address, get_buyer_by_warehouse, add_shipment_delay, \
20873 kshitij.so 119
    refund_return_order, get_cost_detail_for_logistics_txn_id, add_shipment_logistic_detail, \
21090 kshitij.so 120
    create_payment, calculate_payment_amount, add_amount_in_wallet, get_billed_orders_for_manifest_gen, register_rsa, \
21101 kshitij.so 121
    add_sales_associate, search_pmsa, get_pmsa_user, update_pmsa_user, get_pending_pmsa, get_pmsa_users, get_stats_for_associates, \
122
    credit_user_wallet
14134 amit.gupta 123
from shop2020.model.v1.order.impl.DataService import DtrBatchCreditTracker
20641 amit.gupta 124
from shop2020.model.v1.order.impl.ObsoleteDataAccessors import create_ebay_order, \
125
    get_ebay_order_by_orderId, get_ebay_order_by_sales_rec_number, get_ebay_order, \
126
    update_ebay_order, ebay_order_exists, update_order_for_ebay, split_ebay_order, \
127
    add_or_update_amazon_fba_sales_snapshot, get_amazon_fba_sales_snapshot_for_days, \
128
    get_amazon_fba_sales_latest_snapshot_for_item, create_snapdeal_order, \
129
    get_snapdeal_order, snapdeal_order_exists, update_latest_fba_prices_for_item, \
130
    flipkart_order_exists, create_flipkart_order, get_flipkart_order, \
131
    get_flipkart_order_by_subOrderId, update_flipkart_order_dates_and_awb, \
132
    update_snapdeal_orders_status, update_flipkart_orders_status, \
133
    bulk_add_or_update_amazon_fba_sales_snapshot, get_created_orders_for_flipkart, \
134
    change_easyship_mfn_order_txn_status, update_amazon_fba_order_returns, \
135
    get_all_amazon_fba_order_returns, get_total_sale_returns_fba_skus_curent_time, \
136
    get_amazon_fba_sales_latest_snapshot_for_item_location_wise, \
137
    get_verification_pending_orders_fk, get_fa_order_by_fk_order_id, \
138
    get_all_fa_orders_list, add_update_fa_orders_bulk, flipkart_fa_order_exists, \
139
    create_homeshop_order, get_homeshop_order, homeshop_order_exists
6000 mandeep.dh 140
from shop2020.model.v1.order.impl.model.DTHRechargeOrder import DTHRechargeOrder
6056 amit.gupta 141
from shop2020.model.v1.order.impl.model.DigitalTransaction import \
142
    DigitalTransaction
6000 mandeep.dh 143
from shop2020.model.v1.order.impl.model.MobileRechargeOrder import \
144
    MobileRechargeOrder
14134 amit.gupta 145
from shop2020.model.v1.order.impl.model.UserWalletHistory import \
146
    UserWalletHistory
11902 amit.gupta 147
from shop2020.model.v1.user.impl.Converters import to_t_address
6000 mandeep.dh 148
from shop2020.thriftpy.model.v1.order.ttypes import TransactionServiceException, \
20927 kshitij.so 149
    RechargeType, AmazonOrdersToAcknowledge, WalletReferenceType
6000 mandeep.dh 150
from shop2020.utils.Utils import to_py_date, get_fdate_tdate, to_java_date
20122 kshitij.so 151
import datetime
152
import json
20954 kshitij.so 153
from shop2020.model.v1.order.script.RechargeUnknownReport import order_list
1405 ankur.sing 154
 
5527 anupam.sin 155
 
20122 kshitij.so 156
 
104 ashish 157
class OrderServiceHandler:
158
 
3187 rajveer 159
    def __init__(self, dbname='transaction', db_hostname='localhost'):
483 rajveer 160
        """
104 ashish 161
        Constructor
483 rajveer 162
        """
3187 rajveer 163
        DataService.initialize(dbname, db_hostname)
104 ashish 164
 
165
    def createTransaction(self, transaction):
166
        """
167
        Parameters:
168
         - transaction
169
        """
766 rajveer 170
        try:
171
            return create_transaction(transaction)
172
        finally:
173
            close_session()
174
 
104 ashish 175
    def getTransaction(self, id):
176
        """
177
            Get transaction methods.
178
 
179
        Parameters:
180
         - id
181
        """
766 rajveer 182
        try:
183
            transaction = get_transaction(id)
184
            return to_t_transaction(transaction)
185
        finally:
186
            close_session()
187
 
483 rajveer 188
    def getTransactionsForCustomer(self, customerId, from_date, to_date, status):
104 ashish 189
        """
190
        Parameters:
483 rajveer 191
         - customerId
104 ashish 192
         - from_date
193
         - to_date
483 rajveer 194
         - status
104 ashish 195
        """
766 rajveer 196
        try:
197
            current_from_date, current_to_date = get_fdate_tdate(from_date, to_date)
198
 
199
            transactions = get_transactions_for_customer(customerId, current_from_date, current_to_date, status)
200
            t_transaction = []
201
            for transaction in transactions:
202
                t_transaction.append(to_t_transaction(transaction))
203
            return t_transaction
204
        finally:
205
            close_session()
483 rajveer 206
 
207
    def getTransactionsForShoppingCartId(self, shoppingCartId):
208
        """
209
        Parameters:
210
            - shoppingCartId
211
        """
766 rajveer 212
        try:
213
            transactions = get_transactions_for_shopping_cart_id(shoppingCartId)
214
            t_transaction = []
215
            for transaction in transactions:
216
                t_transaction.append(to_t_transaction(transaction))
217
            return t_transaction
218
        finally:
219
            close_session()
104 ashish 220
 
483 rajveer 221
    def getTransactionStatus(self, transactionId):
104 ashish 222
        """
223
        Parameters:
483 rajveer 224
         - transactionId
225
        """
766 rajveer 226
        try:
227
            return get_transaction_status(transactionId)
228
        finally:
229
            close_session()
230
 
7293 anupam.sin 231
    def changeTransactionStatus(self, transactionId, status, description, pickUp, orderType, source):
483 rajveer 232
        """
233
        Parameters:
234
         - transactionId
104 ashish 235
         - status
483 rajveer 236
         - description
5387 rajveer 237
         - selfPickup
483 rajveer 238
        """
766 rajveer 239
        try:
7293 anupam.sin 240
            return change_transaction_status(transactionId, status, description, pickUp, orderType, source)
766 rajveer 241
        finally:
242
            close_session()
243
 
1528 ankur.sing 244
    def getOrdersForTransaction(self, transactionId, customerId):
483 rajveer 245
        """
1528 ankur.sing 246
        Returns list of orders for given transaction Id. Also filters based on customer Id so that
247
        only user who owns the transaction can view its order details.
248
 
483 rajveer 249
        Parameters:
250
         - transactionId
1528 ankur.sing 251
         - customerId
483 rajveer 252
        """
766 rajveer 253
        try:
1528 ankur.sing 254
            orders = get_orders_for_transaction(transactionId, customerId)
766 rajveer 255
            return [to_t_order(order) for order in orders]    
256
        finally:
257
            close_session()
258
 
4801 anupam.sin 259
    def getAllOrders(self, statuses, from_date, to_date, warehouse_id):
483 rajveer 260
        """
261
        Parameters:
262
         - status
104 ashish 263
         - from_date
264
         - to_date
483 rajveer 265
         - warehouse_id
104 ashish 266
        """
766 rajveer 267
        try:
268
            current_from_date, current_to_date = get_fdate_tdate(from_date, to_date)        
4801 anupam.sin 269
            orders = get_all_orders(statuses, current_from_date, current_to_date, warehouse_id)
766 rajveer 270
            return [to_t_order(order) for order in orders]
271
        finally:
272
            close_session()
4133 chandransh 273
 
8303 amar.kumar 274
    def getOrdersInBatch(self, statuses, offset, limit, warehouse_id, source):
4133 chandransh 275
        """
276
        Returns at most 'limit' orders with the given statuses for the given warehouse starting from the given offset.
277
        Pass the status as null and the limit as 0 to ignore them.
278
 
279
        Parameters:
280
         - statuses
281
         - offset
282
         - limit
283
         - warehouse_id
284
        """
285
        try:
8303 amar.kumar 286
            orders = get_orders_in_batch(statuses, offset, limit, warehouse_id, source)
4133 chandransh 287
            return [to_t_order(order) for order in orders]
288
        finally:
289
            close_session()
290
 
8303 amar.kumar 291
    def getOrderCount(self, statuses, warehouseId, source):
4133 chandransh 292
        """
293
        Returns the count of orders with the given statuses assigned to the given warehouse.
294
 
295
        Parameters:
296
         - statuses
297
         - warehouseId
298
        """
299
        try:
8303 amar.kumar 300
            return get_order_count(statuses, warehouseId, source)
4133 chandransh 301
        finally:
302
            close_session()
303
 
995 varun.gupt 304
    def getOrdersByBillingDate(self, status, start_billing_date, end_billing_date, warehouse_id):
305
        """
306
        Parameters:
307
         - status
308
         - start_billing_date
309
         - end_billing_date
310
         - warehouse_id
311
        """
312
        try:
313
            current_start_billing_date, current_end_billing_date = get_fdate_tdate(start_billing_date, end_billing_date)
314
            orders = get_orders_by_billing_date(status, current_start_billing_date, current_end_billing_date, warehouse_id)
315
            return [to_t_order(order) for order in orders]
316
        finally:
317
            close_session()
1382 varun.gupt 318
 
3451 chandransh 319
    def getOrdersByShippingDate(self, fromShippingDate, toShippingDate, providerId, warehouseId, cod):
3427 chandransh 320
        """
321
        Returns orders for a particular provider and warehouse which were shipped between the given dates.
3451 chandransh 322
        Returned orders comprise of COD orders if cod parameter is true. It comprises of prepaid orders otherwise.
323
        Pass providerId and warehouseId as -1 to ignore both these parameters.
3427 chandransh 324
 
325
        Parameters:
326
         - fromShippingDate
327
         - toShippingDate
328
         - providerId
329
         - warehouseId
3451 chandransh 330
         - cod
3427 chandransh 331
        """
332
        try:
333
            from_shipping_date, to_shipping_date = get_fdate_tdate(fromShippingDate, toShippingDate)
3451 chandransh 334
            orders = get_orders_by_shipping_date(from_shipping_date, to_shipping_date, providerId, warehouseId, cod)
3427 chandransh 335
            return [to_t_order(order) for order in orders]
336
        finally:
337
            close_session()
338
 
1382 varun.gupt 339
    def getReturnableOrdersForCustomer(self, customerId, limit = None):
340
        """
341
        Parameters:
342
         - customerId
343
         - limit
344
        """
345
        try:
346
            return get_returnable_orders_for_customer(customerId, limit)
347
        finally:
348
            close_session()
995 varun.gupt 349
 
1382 varun.gupt 350
    def getCancellableOrdersForCustomer(self, customerId, limit = None):
351
        """
352
        Parameters:
353
         - customerId
354
         - limit
355
        """
356
        try:
357
            return get_cancellable_orders_for_customer(customerId, limit)
358
        finally:
359
            close_session()
360
 
483 rajveer 361
    def changeOrderStatus(self, orderId, status, description):
362
        """
363
        Parameters:
364
         - orderId
365
         - status
366
         - description
367
         - 
368
        """
766 rajveer 369
        try:
370
            return change_order_status(self, orderId, status, description)
371
        finally:
372
            close_session()
921 rajveer 373
 
3064 chandransh 374
    def verifyOrder(self, orderId):
375
        """
376
        Marks the given order as SUBMITTED_FOR_PROCESSING and updates the verified
377
        timestamp. It is intended to be used for COD orders but can be harmlessly
378
        used for all other orders as well.
379
        Throws an exception if no such order exists.
380
 
381
        Parameters:
382
         - orderId
383
        """
384
        try:
7391 rajveer 385
            return verify_order(orderId)
3064 chandransh 386
        finally:
387
            close_session()
388
 
921 rajveer 389
    def acceptOrder(self, orderId):
390
        """
3064 chandransh 391
        Marks the given order as ACCEPTED and updates the accepted timestamp. If the
392
        given order is not a COD order, it also captures the payment if the same has
393
        not been captured.
394
        Throws an exception if no such order exists.
395
 
921 rajveer 396
        Parameters:
397
         - orderId
398
        """
399
        try:
4285 rajveer 400
            return accept_order(orderId)
921 rajveer 401
        finally:
402
            close_session()
19832 amit.gupta 403
 
404
    def unacceptOrder(self, orderId):
405
        """
406
        Rollsback to Processing State
407
 
408
        Parameters:
409
         - orderId
410
        """
411
        try:
19836 amit.gupta 412
            return unaccept_order(orderId)
19832 amit.gupta 413
        finally:
414
            close_session()
921 rajveer 415
 
3014 chandransh 416
    def getOrdersForCustomer(self, customerId, from_date, to_date, statuses):
104 ashish 417
        """
3014 chandransh 418
        Returns list of orders for the given customer created between the given dates and having the given statuses.
419
        Pass and empty list to ignore filtering on statuses.
420
 
104 ashish 421
        Parameters:
422
         - customerId
423
         - from_date
424
         - to_date
3014 chandransh 425
         - statuses
104 ashish 426
        """
766 rajveer 427
        try:
428
            current_from_date, current_to_date = get_fdate_tdate(from_date, to_date)
429
 
3014 chandransh 430
            orders = get_orders_for_customer(customerId, current_from_date, current_to_date, statuses)
766 rajveer 431
            return [to_t_order(order) for order in orders]
432
        finally:
433
            close_session()
1528 ankur.sing 434
 
435
    def getOrderForCustomer(self, orderId, customerId):
436
        """
437
        Returns an order for the order Id. Also checks if the order belongs to the customer whose Id is passed.
438
        Throws exception if either order Id is invalid or order does not below to the customer whose Id is passed.
439
 
440
        Parameters:
441
         - customerId
442
         - orderId
443
        """
444
        try:
445
            return to_t_order(get_order_for_customer(orderId, customerId))
446
        finally:
447
            close_session()
766 rajveer 448
 
483 rajveer 449
    def getOrder(self, id):
450
        """
451
        Parameters:
452
         - id
453
        """
766 rajveer 454
        try:
455
            return to_t_order(get_order(id))
456
        finally:
457
            close_session()
4999 phani.kuma 458
 
459
    def getOrderList(self, order_ids):
460
        """
461
        Parameters:
462
         - order_ids
463
        """
464
        try:
465
            orders = get_order_list(order_ids)
466
            return [to_t_order(order) for order in orders]
467
        finally:
468
            close_session()
469
 
5386 phani.kuma 470
    def getOrderListForVendor(self, order_ids, vendorId):
471
        """
472
        Parameters:
473
         - order_ids
474
         - vendorId
475
        """
476
        try:
477
            orders = get_order_list_for_vendor(order_ids, vendorId)
478
            return [to_t_order(order) for order in orders]
479
        finally:
480
            close_session()
481
 
483 rajveer 482
    def getLineItemsForOrder(self, orderId):
483
        """
484
        Parameters:
485
         - orderId
486
        """
766 rajveer 487
        try:
488
            lineitems = get_line_items_for_order(orderId)
489
            t_lineitems = []
490
            for lineitem in lineitems:
491
                t_lineitems.append(to_t_lineitem(lineitem))
492
            return t_lineitems
493
        finally:
494
            close_session()
1149 chandransh 495
 
7190 amar.kumar 496
    def addBillingDetails(self, orderId, invoice_number, serialNumber, itemNumber, freebieWarehouseId, billedBy, jacketNumber, billingType, vendorId, authorize):
494 rajveer 497
        """
4658 mandeep.dh 498
        Adds jacket number and serial no. to the order. Doesn't update the serial no. if a -1 is supplied.
2783 chandransh 499
        Also marks the order as billed and sets the billing timestamp.
500
        Return false if it doesn't find the order with the given ID.
1149 chandransh 501
 
502
        Parameters:
503
         - orderId
504
         - jacketNumber
4658 mandeep.dh 505
         - serialNumber
2783 chandransh 506
         - itemNumber
7190 amar.kumar 507
         - freebieWarehouseId
2783 chandransh 508
         - billedBy
1149 chandransh 509
        """
510
        try:
7190 amar.kumar 511
            return add_billing_details(orderId, invoice_number, serialNumber, itemNumber, freebieWarehouseId, billedBy, jacketNumber, billingType, vendorId, authorize)
1149 chandransh 512
        finally:
513
            close_session()
1220 chandransh 514
 
6751 amar.kumar 515
    def addInvoiceNumber(self, orderId, invoiceNumber, color, serialNumber, itemNumber):
4579 rajveer 516
        """
517
        Add the invoice number to the order.
518
 
519
        Parameters:
520
         - orderId
521
         - invoice_number
522
        """
523
        try:
6751 amar.kumar 524
            add_invoice_number(orderId, invoiceNumber, color, serialNumber, itemNumber)
4579 rajveer 525
        finally:
526
            close_session()
527
 
1220 chandransh 528
    def batchOrders(self, warehouseId):
529
        """
530
        Create a batch of all the pending orders for the given warehouse.
531
        The returned list is orderd by created_timestamp.
532
        If there are no pending orders, an empty list is returned.
1208 chandransh 533
 
1220 chandransh 534
        Parameters:
535
         - warehouseId
536
        """
537
        try:
538
            pending_orders = batch_orders(warehouseId)
539
            return [to_t_order(order) for order in pending_orders]
540
        finally:
541
            close_session()
542
 
1208 chandransh 543
    def markOrderAsOutOfStock(self, orderId):
544
        """
545
        Mark the given order as out of stock. Throws an exception if the order with the given Id couldn't be found.
546
 
547
 
548
        Parameters:
549
         - orderId
550
        """
551
        try:
552
            return order_outofstock(orderId)
553
        finally:
554
            close_session()
555
 
4910 phani.kuma 556
    def markOrdersAsShippedFromWarehouse(self, warehouseId, providerId, cod, orderIds):
759 chandransh 557
        """
3064 chandransh 558
        Depending on the third parameter, marks either all prepaid or all cod orders BILLED by the
4910 phani.kuma 559
        given warehouse and were picked up by the given provider as SHIPPED_FROM_WH.
759 chandransh 560
 
561
        Parameters:
562
         - warehouseId
563
         - providerId
3064 chandransh 564
         - cod
759 chandransh 565
        """
766 rajveer 566
        try:
4910 phani.kuma 567
            return mark_orders_as_shipped_from_warehouse(warehouseId, providerId, cod, orderIds)
766 rajveer 568
        finally:
569
            close_session()
1113 chandransh 570
 
5713 rajveer 571
    def markOrdersAsReturnedFromStore(self, providerId, orderIds, awbs):
5676 rajveer 572
        """
573
        Parameters:
574
         - providerId
575
         - orderIds
5713 rajveer 576
         - awbs
5676 rajveer 577
        """
578
        try:
5713 rajveer 579
            return mark_orders_as_returned_from_store(providerId, orderIds, awbs)
5676 rajveer 580
        finally:
581
            close_session()
582
 
583
    def setOrderAttributes(self, orderId, attributes):
584
        """
585
        sets attributes for an order
586
 
587
        Parameters:
588
         - orderId
589
         - attributes
590
        """
591
        try:
592
            return set_order_attributes(orderId, attributes)
593
        finally:
594
            close_session()
595
 
596
 
4910 phani.kuma 597
    def markOrdersAsPickedUp(self, providerId, pickupDetails):
4410 rajveer 598
        """
4910 phani.kuma 599
        Marks all SHIPPED_FROM_WH orders of the previous day for a provider as SHIPPED_TO_LOGISTICS.
600
        Raises an exception if we encounter report for an AWB number that we did not ship.
4410 rajveer 601
 
602
        Parameters:
603
         - providerId
4910 phani.kuma 604
         - pickupDetails
4410 rajveer 605
        """
606
        try:
4910 phani.kuma 607
            mark_orders_as_picked_up(providerId, pickupDetails)
4410 rajveer 608
        finally:
609
            close_session()
610
 
4910 phani.kuma 611
    def getOrdersNotPickedUp(self, providerId):
1113 chandransh 612
        """
613
        Returns a list of orders that were shipped from warehouse but did not appear in the pick-up report.
614
 
615
        Parameters:
616
         - providerId
617
        """
618
        try:
4910 phani.kuma 619
            orders_not_picked_up = get_orders_not_picked_up(providerId)
1113 chandransh 620
            return [to_t_order(order) for order in orders_not_picked_up]
621
        finally:
622
            close_session()
1132 chandransh 623
 
624
    def markOrdersAsDelivered(self, providerId, deliveredOrders):
625
        """
626
        Marks all orders with AWBs in the given map as delivered. Also sets the delivery timestamp and
627
        the name of the receiver.
628
        Raises an exception if we encounter report for an AWB number that we did not ship.
629
 
630
        Parameters:
631
         - providerId
632
         - deliveredOrders
633
        """
634
        try:
635
            mark_orders_as_delivered(providerId, deliveredOrders)
636
        finally:
637
            close_session()
1135 chandransh 638
 
4712 rajveer 639
    def markOrderAsDelivered(self, orderId, deliveryTimestamp, receiver):
640
        """
641
        Attributes:
642
         - orderId
643
         - deliveryTimestamp
644
         - receiver
645
        """
646
        try:
647
            mark_order_as_delivered(orderId, to_py_date(deliveryTimestamp), receiver)
648
        finally:
649
            close_session()
650
 
651
 
5555 rajveer 652
    def markOrderAsReceivedAtStore(self, orderId, deliveryTimestamp):
653
        """
654
        Attributes:
655
         - orderId
656
         - deliveryTimestamp
657
        """
658
        try:
659
            mark_order_as_received_at_store(orderId, to_py_date(deliveryTimestamp))
660
        finally:
661
            close_session()
662
 
663
    def getReceivePendingOrders(self, storeId):
664
        """
665
        Attributes:
666
         - storeId
667
        """
668
        try:
669
            orders = get_receive_pending_orders(storeId)
670
            return [to_t_order(order) for order in orders]
671
        finally:
672
            close_session()
673
 
674
    def getReceivedAtStoreOrders(self, storeId):
675
        """
676
        Attributes:
677
         - storeId
678
        """
679
        try:
680
            orders = get_received_at_store_orders(storeId)
681
            return [to_t_order(order) for order in orders]
682
        finally:
683
            close_session()
5713 rajveer 684
 
685
    def getOrdersCollectionAtStore(self, storeId, fromDate, toDate, onlyCod):
686
        """
687
        Parameters:
688
         - storeId
689
         - fromDate
690
         - toDate
691
         - onlyCod
692
        """
693
        try:
694
            orders = get_orders_collection_at_store(storeId, to_py_date(fromDate), to_py_date(toDate), onlyCod)
695
            return [to_t_order(order) for order in orders]
696
        finally:
697
            close_session()
698
 
4910 phani.kuma 699
    def markAsRTOrders(self, providerId, returnedOrders):
1135 chandransh 700
        """
4910 phani.kuma 701
        Mark all orders with AWBs in the given map as RTO. Also sets the delivery timestamp.
1135 chandransh 702
        Raises an exception if we encounter report for an AWB number that we did not ship.
703
 
704
        Parameters:
705
         - providerId
706
         - returnedOrders
707
        """
708
        try:
4910 phani.kuma 709
            mark_orders_as_rto(providerId, returnedOrders)
1135 chandransh 710
        finally:
711
            close_session()
1246 chandransh 712
 
4910 phani.kuma 713
    def getRTOrders(self, providerId):
714
        """
715
        Returns a list of orders that were returned by courier.
716
 
717
        Parameters:
718
         - providerId
719
        """
720
        try:
721
            rto_orders = get_rto_orders(providerId)
722
            return [to_t_order(order) for order in rto_orders]
723
        finally:
724
            close_session()
725
 
1246 chandransh 726
    def updateNonDeliveryReason(self, providerId, undeliveredOrders):
727
        """
728
        Update the status description of orders whose AWB numbers are keys of the Map.
729
 
730
        Parameters:
731
         - providerId
732
         - undelivered_orders
733
        """
734
        try:
4910 phani.kuma 735
            update_non_delivery_reason(providerId, undeliveredOrders)
736
        finally:
737
            close_session()
738
 
739
    def getNonDeliveredOrdersbyCourier(self, providerId):
740
        """
741
        Returns a list of orders that were picked up or shipped four days ago but did not get delivered.
742
 
743
        Parameters:
744
         - providerId
745
        """
746
        try:
747
            orders_not_delivered = get_non_delivered_orders_by_courier(providerId)
4581 phani.kuma 748
            return [to_t_order(order) for order in orders_not_delivered]
1246 chandransh 749
        finally:
750
            close_session()
1405 ankur.sing 751
 
4910 phani.kuma 752
    def markOrdersAsLocalConnected(self, providerId, local_connected_orders):
753
        """
754
        Mark all orders with AWBs in the given map as local connected. Also sets the local connected timestamp.
755
 
756
        Parameters:
757
         - providerId
758
         - local_connected_orders
759
        """
760
        try:
761
            mark_orders_as_local_connected(providerId, local_connected_orders)
762
        finally:
763
            close_session()
764
 
765
    def getOrdersNotLocalConnected(self, providerId):
766
        """
767
        Returns a list of orders that were picked up or shipped but pending local connection.
768
 
769
        Parameters:
770
         - providerId
771
        """
772
        try:
773
            orders_pending_local_connection = get_orders_not_local_connected(providerId)
774
            return [to_t_order(order) for order in orders_pending_local_connection]
775
        finally:
776
            close_session()
777
 
778
    def markOrdersAsDestinationCityReached(self, providerId, destination_city_reached_orders):
779
        """
780
        Mark all orders with AWBs in the given map as reached destination city. Also sets the reached destination timestamp.
781
 
782
        Parameters:
783
         - providerId
784
         - destination_city_reached_orders
785
        """
786
        try:
787
            mark_orders_as_destinationCityReached(providerId, destination_city_reached_orders)
788
        finally:
789
            close_session()
790
 
791
    def markOrdersAsFirstDeliveryAttempted(self, providerId, first_atdl_orders):
792
        """
793
        Mark all orders with AWBs in the given map as first delivery attempt made. Also sets the first delivery attempted timestamp.
794
 
795
        Parameters:
796
         - providerId
797
         - first_atdl_orders
798
        """
799
        try:
800
            mark_orders_as_firstDeliveryAttempted(providerId, first_atdl_orders)
801
        finally:
802
            close_session()
803
 
4783 phani.kuma 804
    def getUndeliveredOrdersExpectedDeliveryDateNotMet(self):
805
        """
806
        Returns the list of orders whose expected delivery date has passed but have not been
807
        delivered yet.
808
        Returns an empty list if no such orders exist.
809
        """
810
        try:
811
            orders_not_delivered = get_orders_not_met_expected_delivery_date()
812
            return [to_t_order(order) for order in orders_not_delivered]
813
        finally:
814
            close_session()
815
 
1405 ankur.sing 816
    def getUndeliveredOrders(self, providerId, warehouseId):
817
        """
818
        Returns the list of orders whose delivery time has passed but have not been
819
        delivered yet for the given provider and warehouse. To get a complete list of
820
        undelivered orders, pass them as -1.
821
        Returns an empty list if no such orders exist.
822
 
823
        Parameters:
824
         - providerId
825
         - warehouseId
826
        """
827
        try:
828
            undelivered_orders = get_undelivered_orders(providerId, warehouseId)
829
            return [to_t_order(order) for order in undelivered_orders]
830
        finally:
831
            close_session()
1351 varun.gupt 832
 
1398 varun.gupt 833
    def enqueueTransactionInfoEmail(self, transactionId):
1351 varun.gupt 834
        """
1398 varun.gupt 835
        Save the email containing order details to be sent to customer later by batch job
1351 varun.gupt 836
 
837
        Parameters:
838
         - transactionId
839
        """
840
        try:
1398 varun.gupt 841
            return enqueue_transaction_info_email(transactionId)
1351 varun.gupt 842
        finally:
843
            close_session()
844
 
4444 rajveer 845
    def getAlerts(self, type, warehouseId, status, timestamp):
483 rajveer 846
        """
847
        Parameters:
4394 rajveer 848
         - type
4444 rajveer 849
         - warehouseId
4394 rajveer 850
         - status
851
         - timestamp
483 rajveer 852
        """
766 rajveer 853
        try:
4444 rajveer 854
            alerts = get_alerts(type, warehouseId, status, timestamp)
766 rajveer 855
 
856
            t_alerts = []
857
            for alert in alerts:
858
                t_alerts.append(to_t_alert(alert)) 
859
 
860
            return t_alerts
861
        finally:
862
            close_session()
4394 rajveer 863
 
4447 rajveer 864
    def addAlert(self, type, warehouseId, description):
483 rajveer 865
        """
866
        Parameters:
867
         - type
4394 rajveer 868
         - description
4447 rajveer 869
         - warehouseId
483 rajveer 870
        """
766 rajveer 871
        try:
4447 rajveer 872
            add_alert(type, warehouseId, description)
766 rajveer 873
        finally:
874
            close_session()
1596 ankur.sing 875
 
4444 rajveer 876
    def markAlertsAsSeen(self, warehouseId):
877
        """
878
        Parameters:
879
         - warehouseId
880
        """
881
        try:
882
            mark_alerts_as_seen(warehouseId)
883
        finally:
884
            close_session()
885
        pass
886
 
1596 ankur.sing 887
    def getValidOrderCount(self, ):
888
        """
889
        Return the number of valid orders. (OrderStatus >= OrderStatus.SUBMITTED_FOR_PROCESSING)
890
        """
1731 ankur.sing 891
        try:
892
            return get_valid_order_count()
893
        finally:
894
            close_session()
1627 ankur.sing 895
 
896
    def getNoOfCustomersWithSuccessfulTransaction(self, ):
897
        """
898
        Returns the number of distinct customers who have done successful transactions
899
        """
1731 ankur.sing 900
        try:
901
            return get_cust_count_with_successful_txn()
902
        finally:
903
            close_session()
1627 ankur.sing 904
 
1731 ankur.sing 905
 
906
    def getValidOrdersAmountRange(self, ):
1627 ankur.sing 907
        """
1731 ankur.sing 908
        Returns the minimum and maximum amounts of a valid order. (OrderStatus >= OrderStatus.SUBMITTED_FOR_PROCESSING)
909
        List contains two values, first minimum amount and second maximum amount.
1627 ankur.sing 910
        """
1731 ankur.sing 911
        try:
912
            return get_valid_orders_amount_range()
913
        finally:
914
            close_session()
1627 ankur.sing 915
 
5874 rajveer 916
    def getValidOrders(self, limit, onlyStore):
1886 ankur.sing 917
        """
918
        Returns list of Orders in descending order by Order creation date. List is restricted to limit Orders.
919
        If limit is passed as 0, then all valid Orders are returned.
920
 
921
        Parameters:
922
         - limit
5874 rajveer 923
         - onlyStore
1886 ankur.sing 924
        """
925
        try:
5874 rajveer 926
            return [to_t_order(order) for order in get_valid_orders(limit, onlyStore)]
1886 ankur.sing 927
        finally:
928
            close_session()
104 ashish 929
 
2536 chandransh 930
    def toggleDOAFlag(self, orderId):
104 ashish 931
        """
2536 chandransh 932
        Toggle the DOA flag of an order. This should be used to flag an order for follow-up and unflag it when the follow-up is complete.
933
        Returns the final flag status.
934
        Throws an exception if the order with the given id couldn't be found or if the order status is not DELVIERY_SUCCESS.
483 rajveer 935
 
132 ashish 936
        Parameters:
2536 chandransh 937
         - orderId
132 ashish 938
        """
2536 chandransh 939
        try:
940
            return toggle_doa_flag(orderId)
941
        finally:
942
            close_session()
483 rajveer 943
 
4454 rajveer 944
    def markOrderDoaRequestReceived(self, orderId):
945
        """
946
        Once user raise the request for a DOA, order status will be changed from DELVIERY_SUCCESS to DOA_REQUEST_RECEIVED
947
 
948
        Parameters:
949
         - orderId
950
        """
951
        try:
952
            return mark_order_doa_request_received(orderId)
953
        finally:
954
            close_session()
955
 
7645 anupam.sin 956
    def markOrderDoaRequestAuthorized(self, orderId, isAuthorized,  fromStore, isReship):
4454 rajveer 957
        """
958
        CRM person can authorize or deny the request reised by customer. If he authorizes order will change from DOA_REQUEST_RECEIVED
959
        to DOA_REQUEST_AUTHORIZED. If he denies, status will be changed back to DELVIERY_SUCCESS.
960
 
961
        Parameters:
962
         - orderId
963
         - isAuthorized
964
        """
965
        try:
7645 anupam.sin 966
            return mark_order_doa_request_authorized(orderId, isAuthorized, fromStore, isReship)
4454 rajveer 967
        finally:
968
            close_session()
969
 
4488 rajveer 970
    def markOrderReturnRequestReceived(self, orderId):
971
        """
972
        Once user raise the request for a DOA, order status will be changed from DELVIERY_SUCCESS to RET_REQUEST_RECEIVED
973
 
974
        Parameters:
975
         - orderId
976
        """
977
        try:
978
            return mark_order_return_request_received(orderId)
979
        finally:
980
            close_session()
981
 
7645 anupam.sin 982
    def markOrderReturnRequestAuthorized(self, orderId, isAuthorized, fromStore, isReship):
4488 rajveer 983
        """
984
        CRM person can authorize or deny the request reised by customer. If he authorizes order will change from RET_REQUEST_RECEIVED
985
        to RET_REQUEST_AUTHORIZED. If he denies, status will be changed back to DELVIERY_SUCCESS.
986
 
987
        Parameters:
988
         - orderId
989
         - isAuthorized
990
        """
991
        try:
7645 anupam.sin 992
            return mark_order_return_request_authorized(orderId, isAuthorized, fromStore, isReship)
4488 rajveer 993
        finally:
994
            close_session()
995
 
4579 rajveer 996
    def requestPickupNumber(self, orderId, providerId):
104 ashish 997
        """
2536 chandransh 998
        Sends out an email to the account manager of the original courier provider used to ship the order.
4452 rajveer 999
        If the order status was DELIVERY_SUCCESS, it is changed to be DOA_PICKUP_REQUEST_RAISED.
1000
        If the order status was DOA_PICKUP_REQUEST_RAISED, it is left unchanged.
2536 chandransh 1001
        For any other status, it returns false.
1002
        Throws an exception if the order with the given id couldn't be found.
104 ashish 1003
 
1004
        Parameters:
2536 chandransh 1005
         - orderId
104 ashish 1006
        """
2536 chandransh 1007
        try:
4579 rajveer 1008
            return request_pickup_number(orderId, providerId)
2536 chandransh 1009
        finally:
1010
            close_session()
483 rajveer 1011
 
4602 rajveer 1012
    def authorizePickup(self, orderId, pickupNumber, providerId):
304 ashish 1013
        """
4452 rajveer 1014
        If the order status is DOA_PICKUP_REQUEST_RAISED, it does the following
2536 chandransh 1015
            1. Sends out an email to the customer with the dispatch advice that he has to print as an attachment.
1016
            2. Changes order status to be DOA_PICKUP_AUTHORIZED.
1017
            3. Returns true
1018
        If the order is any other status, it returns false.
1019
        Throws an exception if the order with the given id couldn't be found.
304 ashish 1020
 
1021
        Parameters:
2536 chandransh 1022
         - orderId
1023
         - pickupNumber
304 ashish 1024
        """
2536 chandransh 1025
        try:
4602 rajveer 1026
            return authorize_pickup(orderId, pickupNumber, providerId)
2536 chandransh 1027
        finally:
1028
            close_session()    
2764 chandransh 1029
 
1030
    def markDoasAsPickedUp(self, providerId, pickupDetails):
1031
        """
1032
        Marks all DOA_PICKUP_AUTHORIZED orders of the previous day for a provider as DOA_RETURN_IN_TRANSIT.
1033
 
1034
        Parameters:
1035
         - providerId
1036
         - pickupDetails
1037
        """
1038
        try:
4910 phani.kuma 1039
            mark_doas_as_picked_up(providerId, pickupDetails)
1040
        finally:
1041
            close_session()
1042
 
1043
    def getDoasNotPickedUp(self, providerId):
1044
        """
1045
        Returns a list of orders that were authorized for pickup but did not appear in the pick-up report.
1046
 
1047
        Parameters:
1048
         - providerId
1049
        """
1050
        try:
1051
            orders_not_picked_up = get_doas_not_picked_up(providerId)
2764 chandransh 1052
            return [to_t_order(order) for order in orders_not_picked_up]
1053
        finally:
1054
            close_session()
4910 phani.kuma 1055
 
4741 phani.kuma 1056
    def markReturnOrdersAsPickedUp(self, providerId, pickupDetails):
1057
        """
1058
        Marks all RET_PICKUP_CONFIRMED orders of the previous day for a provider as RET_RETURN_IN_TRANSIT.
1059
 
1060
        Parameters:
1061
         - providerId
1062
         - pickupDetails
1063
        """
1064
        try:
4910 phani.kuma 1065
            mark_return_orders_as_picked_up(providerId, pickupDetails)
1066
        finally:
1067
            close_session()
1068
 
1069
    def getReturnOrdersNotPickedUp(self, providerId):
1070
        """
1071
        Returns a list of orders that were authorized for pickup but did not appear in the pick-up report.
1072
 
1073
        Parameters:
1074
         - providerId
1075
        """
1076
        try:
1077
            orders_not_picked_up = get_return_orders_not_picked_up(providerId)
4741 phani.kuma 1078
            return [to_t_order(order) for order in orders_not_picked_up]
1079
        finally:
1080
            close_session()
4910 phani.kuma 1081
 
13276 manish.sha 1082
    def receiveReturn(self, orderId, receiveCondition, receiveFreebie, serialNumbers):
2591 chandransh 1083
        """
4452 rajveer 1084
        If the order status is DOA_PICKUP_CONFIRMED or DOA_RETURN_IN_TRANSIT, marks the order status as DOA_RECEIVED_PRESTINE and returns true.
2591 chandransh 1085
        If the order is in any other state, it returns false.
1086
        Throws an exception if the order with the given id couldn't be found.
1087
 
1088
        Parameters:
1089
         - orderId
1090
        """
1091
        try:
13276 manish.sha 1092
            return receive_return(orderId, receiveCondition, receiveFreebie, serialNumbers)
2591 chandransh 1093
        finally:
1094
            close_session()
1095
 
1096
    def validateDoa(self, orderId, isValid):
1097
        """
4452 rajveer 1098
        Used to validate the DOA certificate for an order in the DOA_RECEIVED_PRESTINE state. If the certificate is valid,
2609 chandransh 1099
        the order state is changed to DOA_CERT_PENDING.
2591 chandransh 1100
        If the certificate is invalid, the order state is changed to DOA_CERT_INVALID.
1101
        If the order is in any other state, it returns false.
1102
        Throws an exception if the order with the given id couldn't be found.
1103
 
1104
        Parameters:
1105
         - orderId
1106
         - isValid
1107
        """
1108
        try:
1109
            return validate_doa(orderId, isValid)
1110
        finally:
1111
            close_session()
2628 chandransh 1112
 
4495 rajveer 1113
    def validateReturnProduct(self, orderId, isUsable):
1114
        """
1115
        Parameters:
1116
         - orderId
1117
         - isUsable
1118
        """
1119
        try:
1120
            return validate_return_product(orderId, isUsable)
1121
        finally:
1122
            close_session()
1123
 
2628 chandransh 1124
    def reshipOrder(self, orderId):
1125
        """
4484 rajveer 1126
        If the order is in RTO_RECEIVED_PRESTINE or DOA_CERT_INVALID state, it does the following:
2628 chandransh 1127
            1. Creates a new order for processing in the BILLED state. All billing information is saved.
4484 rajveer 1128
            2. Marks the current order as one of the final states RTO_RESHIPPED and DOA_INVALID_RESHIPPED depending on what state the order started in.
2628 chandransh 1129
 
1130
        If the order is in DOA_CERT_VALID state, it does the following:
1131
            1. Creates a new order for processing in the SUBMITTED_FOR_PROCESSING state.
1132
            2. Creates a return order for the warehouse executive to return the DOA material.
4452 rajveer 1133
            3. Marks the current order as the final DOA_VALID_RESHIPPED state.
2628 chandransh 1134
 
1135
        Returns the id of the newly created order.
1136
 
1137
        Throws an exception if the order with the given id couldn't be found.
1138
 
1139
        Parameters:
1140
         - orderId
1141
        """
1142
        try:
1143
            return reship_order(orderId)
1144
        finally:
1145
            close_session()
1146
 
3226 chandransh 1147
    def refundOrder(self, orderId, refundedBy, reason):
2628 chandransh 1148
        """
4484 rajveer 1149
        If the order is in RTO_RECEIVED_PRESTINE, DOA_CERT_VALID or DOA_CERT_INVALID state, it does the following:
2628 chandransh 1150
            1. Creates a refund request for batch processing.
1151
            2. Creates a return order for the warehouse executive to return the shipped material.
4484 rajveer 1152
            3. Marks the current order as RTO_REFUNDED, DOA_VALID_REFUNDED or DOA_INVALID_REFUNDED final states.
2628 chandransh 1153
 
1154
        If the order is in SUBMITTED_FOR_PROCESSING or INVENTORY_LOW state, it does the following:
1155
            1. Creates a refund request for batch processing.
3226 chandransh 1156
            2. Cancels the reservation of the item in the warehouse.
1157
            3. Marks the current order as the REFUNDED final state.
2628 chandransh 1158
 
3226 chandransh 1159
        For all COD orders, if the order is in INIT, SUBMITTED_FOR_PROCESSING or INVENTORY_LOW state, it does the following:
1160
            1. Cancels the reservation of the item in the warehouse.
1161
            2. Marks the current order as CANCELED.
1162
 
1163
        In all cases, it updates the reason for cancellation or refund and the person who performed the action.
1164
 
2628 chandransh 1165
        Returns True if it is successful, False otherwise.
1166
 
1167
        Throws an exception if the order with the given id couldn't be found.
1168
 
1169
        Parameters:
1170
         - orderId
3226 chandransh 1171
         - refundedBy
1172
         - reason
2628 chandransh 1173
        """
1174
        try:
3226 chandransh 1175
            return refund_order(orderId, refundedBy, reason)
2628 chandransh 1176
        finally:
1177
            close_session()
1178
 
2697 chandransh 1179
    def getReturnOrders(self, warehouseId, fromDate, toDate):
1180
        """
1181
        Get all return orders created between the from and to dates for the given warehouse.
1182
        Ignores the warehouse if it is passed as -1.
1183
 
1184
        Parameters:
1185
         - warehouseId
1186
         - fromDate
1187
         - toDate
1188
        """
1189
        try:
1190
            from_date, to_date = get_fdate_tdate(fromDate, toDate)
1191
            return get_return_orders(warehouseId, from_date, to_date)
1192
        finally:
1193
            close_session()
1194
 
5481 phani.kuma 1195
    def getAllReturnOrders(self, onlyNotProcessed, fromDate, toDate):
1196
        """
1197
        Get all return orders created between the from and to dates for the given warehouse.
1198
        Ignores the warehouse if it is passed as -1.
1199
 
1200
        Parameters:
1201
         - warehouseId
1202
         - fromDate
1203
         - toDate
1204
        """
1205
        try:
1206
            from_date, to_date = get_fdate_tdate(fromDate, toDate)
1207
            return get_all_return_orders(onlyNotProcessed, from_date, to_date)
1208
        finally:
1209
            close_session()
1210
 
2700 chandransh 1211
    def getReturnOrder(self, id):
1212
        """
1213
        Returns the ReturnOrder corresponding to the given id.
1214
        Throws an exception if the return order with the given id couldn't be found.
1215
 
1216
        Parameters:
1217
         - id
1218
        """
1219
        try:
1220
            return get_return_order(id)
1221
        finally:
1222
            close_session()
1223
 
2697 chandransh 1224
    def processReturn(self, returnOrderId):
1225
        """
1226
        Marks the return order with the given id as processed. Raises an exception if no such return order exists.
1227
 
1228
        Parameters:
1229
         - returnOrderId
1230
        """
1231
        try:
1232
            process_return(returnOrderId)
1233
        finally:
1234
            close_session()
4757 mandeep.dh 1235
 
1236
    def updateOrdersAsPORaised(self, itemIdQuantityMap, purchaseOrderId, warehouseId):
2819 chandransh 1237
        """
4757 mandeep.dh 1238
        Updates orders as PO raised. Also updates purchase order id in orders. Pass a map of items mapped to
1239
        the quantities for which the PO is raised.
1240
 
2819 chandransh 1241
        Parameters:
4757 mandeep.dh 1242
         - itemIdQuantityMap
1243
         - purchaseOrderId
2819 chandransh 1244
         - warehouseId
1245
        """
1246
        try:
4757 mandeep.dh 1247
            update_orders_as_PORaised(itemIdQuantityMap, purchaseOrderId, warehouseId)
2819 chandransh 1248
        finally:
1249
            close_session()
4757 mandeep.dh 1250
 
3451 chandransh 1251
    def updateWeight(self, orderId, weight):
1252
        """
1253
        Set the weight of the given order to the provided value. Will attempt to update the weight of the item in the catalog as well.
1254
 
1255
        Parameters:
1256
         - orderId
1257
         - weight
1258
        """
1259
        try:
1260
            order = update_weight(orderId, weight)
1261
            return to_t_order(order)
1262
        finally:
1263
            close_session()
1264
 
3469 chandransh 1265
    def changeItem(self, orderId, itemId):
1266
        """
1267
        Change the item to be shipped for this order. Also adjusts the reservation in the inventory accordingly.
1268
        Currently, it also ensures that only a different color of the given item is shipped.
1269
 
1270
        Parameters:
1271
         - orderId
1272
         - itemId
1273
        """
1274
        try:
1275
            order = change_product(orderId, itemId)
1276
            return to_t_order(order)
1277
        finally:
1278
            close_session()
7560 rajveer 1279
 
1280
    def changeCourierProvider(self, orderId, providerId):
1281
        try:
1282
            order = change_courier_provider(orderId, providerId)
1283
            return to_t_order(order)
1284
        finally:
1285
            close_session()
1286
 
3469 chandransh 1287
 
1288
    def shiftToWarehouse(self, orderId, warehouseId):
1289
        """
1290
        Moves the given order to the given warehouse. Also adjusts the inventory reservations accordingly.
1291
 
1292
        Parameters:
1293
         - orderId
1294
         - warehouseId
1295
        """
1296
        try:
1297
            order = change_warehouse(orderId, warehouseId)
1298
            return to_t_order(order)
1299
        finally:
1300
            close_session()
3553 chandransh 1301
 
4647 rajveer 1302
    def addDelayReason(self, orderId, delayReason, furtherDelay, delayReasonText):
3553 chandransh 1303
        """
1304
        Adds the given delay reason to the given order.
3986 chandransh 1305
        Increases the expected delivery time of the given order by the given no. of days.
3553 chandransh 1306
        Raises an exception if no order with the given id can be found.
3469 chandransh 1307
 
3553 chandransh 1308
        Parameters:
1309
         - orderId
1310
         - delayReason
1311
        """
1312
        try:
4647 rajveer 1313
            return add_delay_reason(orderId, delayReason, furtherDelay, delayReasonText)
3553 chandransh 1314
        finally:
1315
            close_session()
1316
 
3956 chandransh 1317
    def reconcileCodCollection(self, collectedAmountMap, xferBy, xferTxnId, xferDate):
1318
        """
1319
        Marks the COD orders with given AWB nos. as having been processed.
1320
        Updates the captured amount for the corresponding payment.
1321
 
1322
        Returns a map of AWBs which were not processed and the associated reason. An AWB is not processed if:
1323
        1. There is no order corresponding to an AWB number.
1324
        2. The captured amount for a payment exceeds the total payment.
1325
        3. The order corresponding to an AWB no. is in a state prior to DELIVERY_SUCCESS.
1326
 
1327
        Parameters:
1328
         - collectedAmountMap
1329
         - xferBy
1330
         - xferTxnId
1331
         - xferDate
1332
        """
1333
        try:
1334
            return reconcile_cod_collection(collectedAmountMap, xferBy, xferTxnId, xferDate)
1335
        finally:
1336
            close_session()
4008 mandeep.dh 1337
 
1338
    def getTransactionsRequiringExtraProcessing(self, category):
1339
        """
1340
        Returns the list of transactions that require some extra processing and
1341
        which belong to a particular category. This is currently used by CRM
1342
        application.
1343
        """
1344
        try:
1345
            return get_transactions_requiring_extra_processing(category)
1346
        finally:
1347
            close_session()
1348
 
1349
    def markTransactionAsProcessed(self, transactionId, category):
1350
        """
1351
        Marks a particular transaction as processed for a particular category.
1352
        It essentially deletes the transaction if it is processed for a particular
1353
        category. This is currently used by CRM application.
1354
        """
1355
        try:
1356
            return mark_transaction_as_processed(transactionId, category)
1357
        finally:
1358
            close_session()
4018 chandransh 1359
 
1360
    def getItemWiseRiskyOrdersCount(self, ):
1361
        """
1362
        Returns a map containing the number of risky orders keyed by item id. A risky order
1363
        is defined as one whose shipping date is about to expire.
1364
        """
1365
        try:
1366
            return get_item_wise_risky_orders_count()
1367
        finally:
1368
            close_session()
3956 chandransh 1369
 
4247 rajveer 1370
    def markOrderCancellationRequestReceived(self, orderId):
1371
        """
1372
        Mark order as cancellation request received. If customer sends request of cancellation of
1373
        a particular order, this method will be called. It will just change status of the order
1374
        depending on its current status. It also records the previous status, so that we can move
1375
        back to that status if cancellation request is denied.
1376
 
1377
        Parameters:
1378
         - orderId
1379
        """
1380
        try:
1381
            return mark_order_cancellation_request_received(orderId)
1382
        finally:
1383
            close_session()
1384
 
1385
 
4662 rajveer 1386
    def markOrderAsLostInTransit(self, orderId):
1387
        """
1388
        Parameters:
1389
         - orderId
1390
        """
1391
        try:
1392
            return mark_order_as_lost_in_transit(orderId)
1393
        finally:
1394
            close_session()
1395
 
4258 rajveer 1396
    def markTransactionAsPaymentFlagRemoved(self, transactionId):
4247 rajveer 1397
        """
4258 rajveer 1398
        If we and/or payment gateway has decided to accept the payment, this method needs to be called.
1399
        Changed transaction and all orders status to payment accepted.
4247 rajveer 1400
 
1401
        Parameters:
4258 rajveer 1402
         - transactionId
4247 rajveer 1403
        """
1404
        try:
4259 anupam.sin 1405
            return mark_transaction_as_payment_flag_removed(transactionId)
4247 rajveer 1406
        finally:
1407
            close_session()
4259 anupam.sin 1408
 
1409
    def refundTransaction(self, transactionId, refundedBy, reason):
1410
        """
1411
        This method is called when a flagged payment is deemed unserviceable and the corresponding orders
1412
        need to be cancelled
1413
 
1414
        Parameters:
1415
         - transactionId
1416
        """
1417
        try:
1418
            return refund_transaction(transactionId, refundedBy, reason)
1419
        finally:
1420
            close_session()
4247 rajveer 1421
 
1422
    def markOrderCancellationRequestDenied(self, orderId):
1423
        """
1424
        If we decide to not to cancel order, we will move the order ro previous status.
1425
 
1426
        Parameters:
1427
         - orderId
1428
        """
1429
        try:
1430
            return mark_order_cancellation_request_denied(orderId)
1431
        finally:
1432
            close_session()
1433
 
1434
    def markOrderCancellationRequestConfirmed(self, orderId):
1435
        """
1436
        If we decide to to cancel order, CRM will call this method to move the status of order to
1437
        cancellation request confirmed. After this OM will be able to cancel the order.
1438
 
1439
        Parameters:
1440
         - orderId
1441
        """
1442
        try:
1443
            return mark_order_cancellation_request_confirmed(orderId)
1444
        finally:
1445
            close_session()
1446
 
4324 mandeep.dh 1447
    def updateShipmentAddress(self, orderId, addressId):
1448
        """
1449
        Updates shipment address of an order. Delivery and shipping date estimates
1450
        etc. are also updated here.
1451
 
1452
        Throws TransactionServiceException in case address change is not
1453
        possible due to certain reasons such as new pincode in address is
1454
        not serviceable etc.
1455
 
1456
        Parameters:
1457
         - orderId
1458
         - addressId
1459
        """
1460
        try:
1461
            update_shipment_address(orderId, addressId)
1462
        finally:
1463
            close_session()
1464
 
4285 rajveer 1465
    def acceptOrdersForItemId(self, itemId, inventory):
1466
        """
1467
        Marks the orders as ACCEPTED for the given itemId and inventory. It also updates the accepted timestamp. If the
1468
        given order is not a COD order, it also captures the payment if the same has not been captured.
1469
 
1470
        Parameters:
1471
         - itemId
1472
         - inventory
1473
        """
1474
        try:
1475
            return accept_orders_for_item_id(itemId, inventory)
1476
        finally:
1477
            close_session()
1478
 
4303 rajveer 1479
 
1480
 
4369 rajveer 1481
    def markOrdersAsPORaised(self, vendorId, itemId, quantity, estimate, isReminder):
4303 rajveer 1482
        """
1483
        Parameters:
1484
         - vendorId
1485
         - itemId
1486
         - quantity
1487
         - estimate
4369 rajveer 1488
         - isReminder
4303 rajveer 1489
        """
1490
        try:
4369 rajveer 1491
            return mark_orders_as_po_raised(vendorId, itemId, quantity, estimate, isReminder)
4303 rajveer 1492
        finally:
1493
            close_session()
1494
 
4369 rajveer 1495
    def markOrdersAsReversalInitiated(self, vendorId, itemId, quantity, estimate, isReminder):
4303 rajveer 1496
        """
1497
        Parameters:
1498
         - vendorId
1499
         - itemId
1500
         - quantity
1501
         - estimate
4369 rajveer 1502
         - isReminder
4303 rajveer 1503
        """
1504
        try:
4369 rajveer 1505
            return mark_orders_as_reversal_initiated(vendorId, itemId, quantity, estimate, isReminder)
4303 rajveer 1506
        finally:
1507
            close_session()
1508
 
4369 rajveer 1509
    def markOrdersAsNotAvailabke(self, vendorId, itemId, quantity, estimate, isReminder):
4303 rajveer 1510
        """
1511
        Parameters:
1512
         - vendorId
1513
         - itemId
1514
         - quantity
1515
         - estimate
4369 rajveer 1516
         - isReminder
4303 rajveer 1517
        """
1518
        try:
4369 rajveer 1519
            return mark_orders_as_not_available(vendorId, itemId, quantity, estimate, isReminder)
4303 rajveer 1520
        finally:
1521
            close_session()
1522
 
1523
 
4369 rajveer 1524
    def markOrdersAsTimeout(self, vendorId):
1525
        """
1526
        Parameters:
1527
         - vendorId
1528
        """
1529
        try:
1530
            return mark_orders_as_timeout(vendorId)
1531
        finally:
1532
            close_session()
4386 anupam.sin 1533
 
1534
    def getOrderForAwb(self, awb):
1535
        """
1536
        Parameters:
1537
         - AirwayBill Number
1538
        """
13276 manish.sha 1539
        ret_Orders =[]
1540
 
4386 anupam.sin 1541
        try:
13276 manish.sha 1542
            orderList = get_order_for_awb(awb)
1543
            for order in orderList:
1544
                ret_Orders.append(to_t_order(order))
1545
            return ret_Orders
4386 anupam.sin 1546
        finally:
1547
            close_session()
4369 rajveer 1548
 
4910 phani.kuma 1549
    def getOrdersForProviderForStatus(self, provider_id, order_status_list):
4506 phani.kuma 1550
        """
1551
        Parameters:
1552
         - provider id
1553
         - order status
1554
        """
1555
        try:
4910 phani.kuma 1556
            orders_of_provider_by_status = get_orders_for_provider_for_status(provider_id, order_status_list)
4506 phani.kuma 1557
            return [to_t_order(order) for order in orders_of_provider_by_status if order != None]
1558
        finally:
1559
            close_session()
4600 varun.gupt 1560
 
1561
    def getBilledOrdersForVendor(self, vendorId, billingDateFrom, billingDateTo):
1562
        '''
1563
        Parameters:
1564
         - vendorId
1565
         - billingDateFrom
1566
         - billingDateTo
1567
        '''
1568
        try:
1569
            return [to_t_order(order) for order in get_billed_orders_for_vendor(vendorId, to_py_date(billingDateFrom), to_py_date(billingDateTo))]
1570
        finally:
1571
            close_session()
1572
 
4607 rajveer 1573
    def getSlippedSippingDateOrders(self):
1574
        try:
1575
            return [to_t_order(order) for order in get_slipped_sipping_date_orders()]
1576
        finally:
1577
            close_session()
1578
 
4709 rajveer 1579
    def getCancelledOrders(self, cancelDateFrom, cancelDateTo):
1580
        try:
1581
            return [to_t_order(order) for order in get_cancelled_orders(to_py_date(cancelDateFrom), to_py_date(cancelDateTo))]
1582
        finally:
1583
            close_session()
1584
 
4600 varun.gupt 1585
    def getEBSSettlementSummaries(self):
1586
        try:
1587
            return get_ebs_settlement_summaries()
1588
        finally:
1589
            close_session()
4369 rajveer 1590
 
4600 varun.gupt 1591
    def saveEBSSettlementSummary(self, settlementId, settlementDate, transactionDateFrom, transactionDateTo, amount):
1592
        try:
1593
            save_ebs_settlement_summary(settlementId, to_py_date(settlementDate), to_py_date(transactionDateFrom), to_py_date(transactionDateTo), amount)
1594
        finally:
1595
            close_session()
1596
 
5386 phani.kuma 1597
    def getSettlementForPrepaid(self, referenceId, isRefund):
4600 varun.gupt 1598
        '''
1599
        Parameters:
5189 varun.gupt 1600
         - referenceId
1601
         - isRefund
4600 varun.gupt 1602
        '''
1603
        try:
5386 phani.kuma 1604
            return to_t_payment_settlement(get_settlement_for_Prepaid(referenceId, isRefund))
4600 varun.gupt 1605
        finally:
1606
            close_session()
5386 phani.kuma 1607
 
1608
    def getSettlementForCod(self, orderId, isRefund):
1609
        '''
1610
        Parameters:
1611
         - orderId
1612
         - isRefund
1613
        '''
1614
        try:
1615
            return to_t_payment_settlement(get_settlement_for_Cod(orderId, isRefund))
1616
        finally:
1617
            close_session()
1618
 
4600 varun.gupt 1619
    def getEBSSettlementDate(self, settlementId):
1620
        try:
1621
            return to_java_date(get_ebs_settlement_date(settlementId))
1622
        finally:
1623
            close_session()
1624
 
4905 varun.gupt 1625
    def savePaymentSettlements(self, settlementDate, paymentGatewayId, referenceId, serviceTax, otherCharges, netCollection):
4600 varun.gupt 1626
        try:
4905 varun.gupt 1627
            save_payment_settlements(to_py_date(settlementDate), paymentGatewayId, referenceId, serviceTax, otherCharges, netCollection)
4600 varun.gupt 1628
        finally:
1629
            close_session()
1630
 
1631
    def markEBSSettlementUploaded(self, settlementId):
1632
        try:
1633
            mark_ebs_settlement_uploaded(settlementId)
1634
        finally:
1635
            close_session()
1636
 
4715 varun.gupt 1637
    def getSettlementsByDate(self, settlementDateFrom, settlementDateTo, isRefund):
1638
        try:
1639
            settlements = get_settlements_by_date(to_py_date(settlementDateFrom), to_py_date(settlementDateTo), isRefund)
1640
            return [to_t_payment_settlement(settlement) for settlement in settlements]
1641
        finally:
1642
            close_session()
1643
 
1644
    def getReshippedOrderIds(self, orderIds):
1645
        try:
1646
            return get_reshipped_order_ids(orderIds)
1647
        finally:
1648
            close_session()
1649
 
5481 phani.kuma 1650
    def getBilledOrders(self, vendorId, onlyVendorNotPaid, billingDateFrom, billingDateTo):
4875 varun.gupt 1651
        try:
5481 phani.kuma 1652
            from_date, to_date = get_fdate_tdate(billingDateFrom, billingDateTo)
1653
            return [to_t_order(order) for order in get_billed_orders(vendorId, onlyVendorNotPaid, from_date, to_date)]
4875 varun.gupt 1654
        finally:
1655
            close_session()
1656
 
5062 varun.gupt 1657
    def getStatusDistributionOfOrders(self, startDate, endDate):
1658
        try:
5067 varun.gupt 1659
            distribution = {}
1660
 
1661
            for status, count in get_order_distribution_by_status(to_py_date(startDate), to_py_date(endDate)):
1662
                distribution[status] = count
1663
 
1664
            return distribution
5062 varun.gupt 1665
        finally:
1666
            close_session()
1667
 
5067 varun.gupt 1668
    def getOrderIdsForStatus(self, status, startDatetime, endDatetime):
1669
        try:
1670
            orders = get_order_ids_for_status(status, to_py_date(startDatetime), to_py_date(endDatetime))
1671
            return [order.id for order in orders]
1672
        finally:
1673
            close_session()
1674
 
5099 varun.gupt 1675
    def updateOrderAsPaidToVendor(self, orderId):
1676
        try:
1677
            update_orders_as_paid_to_vendor(orderId)
1678
        finally:
1679
            close_session()
1680
 
5348 anupam.sin 1681
    def updateCODAgent(self, agentEmailId, orderId):
1682
        try:
1683
            update_COD_agent(agentEmailId, orderId)
1684
        finally:
1685
            close_session()
1686
 
5386 phani.kuma 1687
    def updateOrderOnlyAsPaidToVendor(self, orderId):
1688
        try:
1689
            update_order_only_as_paid_to_vendor(orderId)
1690
        finally:
1691
            close_session()
1692
 
5208 varun.gupt 1693
    def getRefundedOrdersMarkedPaid(self):
1694
        try:
1695
            return [to_t_order(order) for order in get_refunded_orders_marked_paid()]
1696
        finally:
1697
            close_session()
5447 anupam.sin 1698
 
1699
    def getAllVerificationAgents(self, minOrderId, maxOrderId):
1700
        try:
1701
            return [to_t_verification_agent(codAgent) for codAgent in get_all_verification_agents(minOrderId, maxOrderId)]
1702
        finally:
5527 anupam.sin 1703
            close_session()
1704
 
1705
    def getAllAttributesForOrderId(self, orderId):
1706
        try:
1707
            return [to_t_attribute(attribute) for attribute in get_all_attributes_for_order_id(orderId)]
1708
        finally:
1709
            close_session()
1710
 
1711
    def setOrderAttributeForTransaction(self, transactionId, attribute):
1712
        try:
1713
            set_order_attribute_for_transaction(transactionId, attribute)                    
1714
        finally:
1715
            close_session()
5593 mandeep.dh 1716
 
1717
    def acceptOrderForItem(self, itemId, quantity, fulfilmentWarehouseId, billingWarehouseId):
1718
        """
1719
        Accepts appropriate order for an item in a given billingWarehouse. Usually
1720
        invoked while scanning IN of items.
1721
 
1722
        Parameters:
1723
         - itemId
1724
         - quantity
1725
         - fulfilmentWarehouseId
1726
         - billingWarehouseId
1727
        """
1728
        try:
1729
            accept_order_for_item(itemId, quantity, fulfilmentWarehouseId, billingWarehouseId)
1730
        finally:
1731
            close_session()
1732
 
5833 rajveer 1733
    def getOrderAttributeValue(self, orderId, attributeName):
1734
        """
1735
        Parameters:
1736
         - orderId
1737
         - attributeName
1738
        """
1739
        try:
6019 rajveer 1740
            return get_order_attribute_value(orderId, attributeName)
5833 rajveer 1741
        finally:
1742
            close_session()
1743
 
6019 rajveer 1744
    def changeJacketNumber(self, orderId, jacketNumber):
1745
        """
1746
        Parameters:
1747
         - orderId
1748
         - jacketNumber
1749
        """
1750
        try:
1751
            return change_jacket_number(orderId, jacketNumber)
1752
        finally:
1753
            close_session()
1754
 
1755
    def markOrderAsRtoInTransit(self, orderId):
1756
        """
1757
        Parameters:
1758
         - orderId
1759
        """
1760
        try:
1761
            return mark_order_as_rto_in_transit(orderId)
1762
        finally:
1763
            close_session()        
1764
 
6000 mandeep.dh 1765
    def createRechargeOrder(self, thriftRechargeOrder):
1766
        """
1767
        Parameters:
1768
         - thriftRechargeOrder
1769
        """
6031 rajveer 1770
        try:
1771
            if thriftRechargeOrder is None or thriftRechargeOrder.rechargeType is None:
1772
                raise TransactionServiceException(102, 'Order or the type is Null')
1773
 
1774
            rechargeOrder = None
1775
            if thriftRechargeOrder.rechargeType == RechargeType.MOBILE:
1776
                rechargeOrder = MobileRechargeOrder()
1777
            elif thriftRechargeOrder.rechargeType == RechargeType.DTH:
1778
                rechargeOrder = DTHRechargeOrder()
1779
 
1780
            if rechargeOrder is None:
1781
                raise TransactionServiceException(102, 'Unsupported recharge type')
6000 mandeep.dh 1782
 
6031 rajveer 1783
            transaction = DigitalTransaction()
1784
            transaction.createdOn = datetime.datetime.now()
6056 amit.gupta 1785
            transaction.userId = thriftRechargeOrder.userId
6031 rajveer 1786
            transaction.orders = [rechargeOrder]
1787
 
6000 mandeep.dh 1788
            rechargeOrder.from_thrift_object(thriftRechargeOrder)
1789
            session.commit()
6031 rajveer 1790
            return rechargeOrder.to_thrift_object()
6000 mandeep.dh 1791
        except:
1792
            raise TransactionServiceException(103, 'Invalid values passed')
1793
        finally:
1794
            self.closeSession()
1795
 
6031 rajveer 1796
    def getRechargeOrder(self, rechargeOrderId):
1797
        """
1798
        Parameters:
1799
         - rechargeOrderId
1800
        """
1801
        try:
6048 rajveer 1802
            return get_recharge_order(rechargeOrderId).to_thrift_object()
6031 rajveer 1803
        finally:
1804
            self.closeSession()
1805
 
1806
    def getRechargeOrders(self, userId):
1807
        """
1808
        Parameters:
1809
         - userId
1810
        """
1811
        try:
1812
            return [order.to_thrift_object() for order in get_recharge_orders(userId)]
1813
        finally:
1814
            self.closeSession()
21535 kshitij.so 1815
 
1816
    def getPaginatedRechargeOrders(self, userId, offset, limit):
1817
        try:
1818
            return [order.to_thrift_object() for order in get_recharge_orders(userId, offset, limit)]
1819
        finally:
1820
            self.closeSession()
6031 rajveer 1821
 
6000 mandeep.dh 1822
    def updateRechargeOrderStatus(self, rechargeOrderId, rechargeOrderStatus):
1823
        """
1824
        Parameters:
1825
         - rechargeOrderId
1826
         - rechargeOrderStatus
1827
        """
6031 rajveer 1828
        try:
1829
            return update_recharge_order_status(rechargeOrderId, rechargeOrderStatus)
1830
        finally:
1831
            self.closeSession()
1832
 
1833
    def activateRechargeTxn(self, rechargeOrderId):
6000 mandeep.dh 1834
        """
1835
        Parameters:
6031 rajveer 1836
         - rechargeOrderId
6000 mandeep.dh 1837
        """
6031 rajveer 1838
        try:
1839
            return True
1840
            activate_recharge_txn(rechargeOrderId)
1841
        finally:
1842
            self.closeSession()
6000 mandeep.dh 1843
 
6031 rajveer 1844
    def getUserWallet(self, userId):
6000 mandeep.dh 1845
        """
1846
        Parameters:
6031 rajveer 1847
         - userId
6000 mandeep.dh 1848
        """
6031 rajveer 1849
        try:
1850
            return get_user_wallet(userId).to_thrift_object()
1851
        finally:
1852
            self.closeSession()
6000 mandeep.dh 1853
 
6031 rajveer 1854
    def getUserWalletHistory(self, userId):
6000 mandeep.dh 1855
        """
1856
        Parameters:
6031 rajveer 1857
         - userId
6000 mandeep.dh 1858
        """
6031 rajveer 1859
        try:
1860
            return [wallet.to_thrift_object() for wallet in get_user_wallet_history(userId)]
1861
        finally:
1862
            self.closeSession()
6000 mandeep.dh 1863
 
6206 rajveer 1864
    def getServiceProviders(self, rechargeType, onlyActive):
6048 rajveer 1865
        """
1866
        Parameters:
1867
         - rechargeType
6206 rajveer 1868
         - onlyActive
6048 rajveer 1869
        """
6077 anupam.sin 1870
 
6048 rajveer 1871
        try:
6206 rajveer 1872
            return get_service_providers(rechargeType, onlyActive)
6048 rajveer 1873
        finally:
1874
            self.closeSession()
1875
 
6049 rajveer 1876
    def getServiceProviderForDevice(self, rechargeType, deviceNumber):
6048 rajveer 1877
        """
1878
        Parameters:
1879
         - deviceNumber
1880
        """
1881
        try:
6049 rajveer 1882
            return get_service_provider_for_device(rechargeType, deviceNumber)
6048 rajveer 1883
        finally:
1884
            self.closeSession()
6056 amit.gupta 1885
 
6591 anupam.sin 1886
    def validateRecharge(self, rechargeType, deviceNumber, userSelectedProviderId, clientAddress):
6269 rajveer 1887
        """
1888
        Parameters:
1889
         - deviceNumber
1890
        """
1891
        try:
6591 anupam.sin 1892
            return validate_recharge(rechargeType, deviceNumber, userSelectedProviderId, clientAddress)
6269 rajveer 1893
        finally:
1894
            self.closeSession()
1895
 
6056 amit.gupta 1896
    def getRechargeOrdersForTransaction(self, txId):
1897
        """
1898
        Parameters:
1899
         - transactionId
1900
        """
1901
        try:
1902
            return get_recharge_orders_for_transaction(txId).to_thrift_object()
1903
        finally:
1904
            self.closeSession()
6048 rajveer 1905
 
6094 rajveer 1906
    def getRechargeOrdersForDevice(self, deviceNumber):
1907
        """
1908
        Parameters:
1909
        - deviceNumber
1910
        """
1911
        try:
1912
            return [order.to_thrift_object() for order in get_recharge_orders_for_device(deviceNumber)]
1913
        finally:
1914
            self.closeSession()
1915
 
6154 rajveer 1916
    def getRechargeOrdersForStatus(self, status):
1917
        """
1918
        Parameters:
1919
        - status
1920
        """
1921
        try:
1922
            return [order.to_thrift_object() for order in get_recharge_orders_for_status(status)]
1923
        finally:
1924
            self.closeSession()
1925
 
6159 rajveer 1926
    def getPlansForOperator(self, operatorId):
1927
        """
1928
        Parameters:
1929
        - operatorId
1930
        """
1931
        try:
1932
            return [plan.to_thrift_object() for plan in get_plans_for_operator(operatorId)]
1933
        finally:
1934
            self.closeSession()
1935
 
1936
 
20931 kshitij.so 1937
#    def addAmountToWallet(self, userId, orderId, amount):
1938
#        """
1939
#        Parameters:
1940
#        - userId
1941
#        - orderId
1942
#        - amount
1943
#        """
1944
#        try:
1945
#            update_amount_in_wallet(userId, amount, orderId, 0)
1946
#        finally:
1947
#            self.closeSession()
6094 rajveer 1948
 
6188 rajveer 1949
    def getRechargeStatistics(self):
1950
        """
1951
        Parameters:
1952
        """
1953
        try:
1954
            return get_recharge_statistics()
1955
        finally:
1956
            self.closeSession()
1957
 
6307 anupam.sin 1958
    def getRechargeDenominations(self, operatorId, circleCode, denominationType):
6289 anupam.sin 1959
        try:
1960
            returnList = []
6307 anupam.sin 1961
            rechargeDenominations = get_recharge_denominations(operatorId, circleCode, denominationType)
6289 anupam.sin 1962
            for rechargeDenomination in rechargeDenominations:
1963
                returnList.append(rechargeDenomination.to_thrift_object())
1964
            return returnList
1965
        finally:
1966
            self.closeSession() 
6188 rajveer 1967
 
6371 rajveer 1968
    def updateAvailabilityStatus(self, operatorId, circleId, isAvailable):
1969
        try:
1970
            update_availability_status(operatorId, circleId, isAvailable)
1971
        finally:
1972
            self.closeSession() 
1973
 
6396 amit.gupta 1974
    def getAvailableEmiSchemes(self):
1975
        try:
1976
            return get_available_emi_schemes()
1977
        finally:
1978
            self.closeSession()
1979
 
6389 rajveer 1980
    def getMiscCharges(self, transactionId):
1981
        try:
1982
            return get_misc_charges(transactionId)
1983
        finally:
1984
            self.closeSession()
1985
 
6507 anupam.sin 1986
    def refundRechargeOrder (self, rechargeOrderId):
1987
        try:
1988
            return refund_recharge_order(rechargeOrderId)
1989
        finally:
1990
            self.closeSession()
6821 amar.kumar 1991
 
1992
    def getPhysicalOrders(self, start_date, end_date):
1993
        try:
6832 amar.kumar 1994
            return [to_t_order(order) for order in get_physical_orders(to_py_date(start_date), to_py_date(end_date))]
6821 amar.kumar 1995
        finally:
1996
            self.closeSession()
6507 anupam.sin 1997
 
6906 rajveer 1998
    def getDocument(self, docType, docSource):
1999
        try:
2000
            return get_document(docType, docSource)
2001
        finally:
2002
            self.closeSession()
6988 rajveer 2003
 
7075 rajveer 2004
    def retrieveInvoice(self, orderId, userId):
6988 rajveer 2005
        try:
7075 rajveer 2006
            return retrieve_invoice(orderId,userId)
6988 rajveer 2007
        finally:
2008
            self.closeSession()
6906 rajveer 2009
 
7027 rajveer 2010
    def receiveUpdatesForRedExpress(self, awbNumber):
2011
        try:
7032 rajveer 2012
            return RedExpressUpdateService.get_updates_for_user(awbNumber)
7027 rajveer 2013
        finally:
2014
            self.closeSession()
2015
 
6985 anupam.sin 2016
    def changeShippingAddress(self, orderId, line1, line2, city, state, pin):
2017
        try:
2018
            return change_shipping_address(orderId, line1, line2, city, state, pin)
2019
        finally:
2020
            self.closeSession()
2021
 
7073 anupam.sin 2022
    def createRechargeTransaction(self, t_rechargeTransaction):
2023
        try:
2024
            return to_t_rechargeTransaction(create_recharge_transaction(t_rechargeTransaction))
2025
        finally:
2026
            self.closeSession()
7084 rajveer 2027
 
2028
    def getRechargeTransactions(self, storeId):
2029
        try:
2030
            return [to_t_rechargeTransaction(txn) for txn in get_recharge_transactions(storeId)]
2031
        finally:
2032
            self.closeSession()
2033
 
7151 amit.gupta 2034
    def getRechargeTrans(self, storeId, startdate, enddate, status):
2035
        try:
2036
            return [to_t_rechargeTransaction(txn) for txn in get_recharge_trans(storeId,startdate, enddate, status)]
2037
        finally:
2038
            self.closeSession()
7084 rajveer 2039
 
7080 anupam.sin 2040
    def getRechargeTransaction(self, rechargeId):
2041
        try:
2042
            return to_t_rechargeTransaction(get_recharge_transaction(rechargeId))
2043
        finally:
2044
            self.closeSession()
2045
 
2046
    def getFRCs(self, circleId, operatorId):
2047
        try:
2048
            return [to_t_frc(frc) for frc in get_frcs(circleId, operatorId)]
2049
        finally:
2050
            self.closeSession()
2051
 
7096 anupam.sin 2052
    def getHotspotStore(self, id, hotspotid):
2053
        try:
2054
            return to_t_hotspot(get_hotspot_store(id, hotspotid))
2055
        finally:
2056
            self.closeSession()
2057
 
2058
    def getTelecomCircle(self, id, code):
2059
        try:
2060
            return get_circle(id, code).to_thrift_object()
2061
        finally:
2062
            self.closeSession()
2063
 
7109 anupam.sin 2064
    def retrieveHotspotRechargeInvoice(self, rechargeId):
2065
        try:
2066
            return retrieve_hotspot_recharge_invoice(rechargeId)
2067
        finally:
2068
            self.closeSession()
7190 amar.kumar 2069
 
2070
    def splitFreebieOrder(self, orderId, splitReason, shippingDate):
2071
        try:
2072
            return split_freebie_order(orderId, splitReason, shippingDate)
2073
        finally:
2074
            self.closeSession()
7109 anupam.sin 2075
 
7172 anupam.sin 2076
    def getRechargeTransactionsByNumber(self, number, storeId):
7169 anupam.sin 2077
        try:
7172 anupam.sin 2078
            return [to_t_rechargeTransaction(txn) for txn in get_recharge_transactions_by_number(number, storeId)]
7169 anupam.sin 2079
        finally:
2080
            self.closeSession()
2081
 
2082
    def updateHotspotStorePassword(self, storeId, password):
2083
        try:
2084
            return update_hotspot_store_password(storeId, password)
2085
        finally:
2086
            self.closeSession()
2087
 
7263 anupam.sin 2088
    def getSourceDetail(self, source):
2089
        try:
2090
            return to_t_sourcedetail(get_source_detail(source))
2091
        finally:
2092
            self.closeSession()
2093
 
7267 anupam.sin 2094
    def getAllCircles(self):
2095
        try:
2096
            return [circle.to_thrift_object() for circle in get_all_circles()]
2097
        finally:
2098
            self.closeSession()
7263 anupam.sin 2099
 
7267 anupam.sin 2100
    def deleteFrcs(self, frcIdsToDelete):
2101
        try:
2102
            return delete_frcs(frcIdsToDelete)
2103
        finally:
2104
            self.closeSession()
7285 rajveer 2105
 
2106
    def topupCompanyWallet(self, companyId, amount):
2107
        try:
2108
            return topup_company_wallet(companyId, amount)
2109
        finally:
2110
            self.closeSession()
2111
 
2112
    def getWalletBalanceForCompany(self, companyId):
2113
        try:
2114
            return get_wallet_balance_for_company(companyId)
2115
        finally:
2116
            self.closeSession()
7311 kshitij.so 2117
 
2118
    def addAmazonOrder(self,amazonOrder):
2119
        try:
2120
            add_amazon_order(amazonOrder)
2121
        except:
2122
            self.closeSession()
2123
 
7322 vikram.rag 2124
    def updateAmazonOrderStatus(self,orderId,status):
7311 kshitij.so 2125
        try:
7577 rajveer 2126
            return update_amazon_order_status(orderId,status)
7311 kshitij.so 2127
        finally:
2128
            self.closeSession()
7322 vikram.rag 2129
 
7683 vikram.rag 2130
    def getAmazonOrdersShipped(self):
7311 kshitij.so 2131
        try:
7683 vikram.rag 2132
            ordersShipped = get_amazon_orders_shipped()
7311 kshitij.so 2133
        finally:
2134
            self.closeSession()
2135
            return ordersShipped
2136
 
2137
    def getAmazonOrdersCancelled(self,interval):
2138
        ordersCancelled=None
2139
        try:
2140
            ordersCancelled = get_amazon_orders_cancelled(interval)
2141
        except:
2142
            ordersCancelled=None
2143
        finally:
2144
            self.closeSession()
2145
            return ordersCancelled
2146
 
7322 vikram.rag 2147
    def getAmazonOrder(self,orderId):
2148
        result = None
2149
        try:
7343 anupam.sin 2150
            result = to_t_amazonorder(get_amazon_order(orderId))
7322 vikram.rag 2151
        finally:
2152
            self.closeSession()
7542 vikram.rag 2153
            return result
2154
 
2155
    def getAmazonOrderByAmazonOrderId(self,amazonOrderId):
2156
        result = []
2157
        try:
2158
            for amazonOrder in get_amazon_order_by_amazonorderid(amazonOrderId): 
2159
                result.append(to_t_amazonorder(amazonOrder))
2160
        except:
2161
            return None
2162
        finally:
2163
            self.closeSession()
2164
            return result
7343 anupam.sin 2165
 
2166
    def getOrdersForStore(self, id, storeId, startDate, endDate, statuses):
2167
        try:
2168
            return [to_t_order(order) for order in get_orders_for_store(id, storeId, to_py_date(startDate), to_py_date(endDate), statuses)]
2169
        finally:
2170
            self.closeSession()
2171
 
7386 anupam.sin 2172
    def getStoreOrderAdvanceInvoice(self, orderId, storeId):
7343 anupam.sin 2173
        try:
7386 anupam.sin 2174
            return get_store_order_advance_invoice(orderId, storeId)
7343 anupam.sin 2175
        finally:
2176
            self.closeSession()
7363 rajveer 2177
 
2178
    def getSaholicRechargeBalance(self):
2179
        try:
2180
            return RechargeService.getBalance()
2181
        finally:
2182
            self.closeSession()
2183
 
7370 anupam.sin 2184
    def addFrc(self, circle, operatorId, denomination, maxDiscount):
2185
        try:
2186
            return add_frc(circle, operatorId, denomination, maxDiscount)
2187
        except:
2188
            return False
2189
        finally:
2190
            self.closeSession()
2191
 
7371 anupam.sin 2192
    def addSeries(self, circle, operatorId, series):
2193
        try:
2194
            return add_series(circle, operatorId, series)
2195
        except:
2196
            return "Error Occured. Try Again."
2197
        finally:
2198
            self.closeSession()
2199
 
7386 anupam.sin 2200
    def saveStoreOrderDetail(self, storeOrderDetail):
2201
        try:
2202
            return save_store_order_detail(storeOrderDetail)
2203
        except:
2204
            return False
2205
        finally:
2206
            self.closeSession()
2207
 
2208
 
2209
    def getStoreOrderDetail(self, orderId, storeId):
2210
        try:
2211
            return to_t_storeOrderDetail(get_store_order_detail(orderId, storeId))
2212
        finally:
2213
            self.closeSession()
2214
 
2215
    def getAllEdcBanks(self):
2216
        try:
2217
            return get_all_edc_banks()
2218
        finally:
2219
            self.closeSession()
7393 anupam.sin 2220
 
2221
    def saveRefundAmountsForStoreOrder(self, orderId, storeId, cashRefundAmount, cardRefundAmount):
2222
        try:
7399 anupam.sin 2223
            return save_refund_amounts_for_store_order(orderId, storeId, cashRefundAmount, cardRefundAmount)
7393 anupam.sin 2224
        finally:
2225
            self.closeSession()
7386 anupam.sin 2226
 
7427 anupam.sin 2227
    def getCollectionsForStore(self, storeId, startDate, endDate):
2228
        try:
2229
            return [to_t_storeOrderCollection(collection) for collection in get_collections_for_store(storeId, startDate, endDate)]
2230
        finally:
2231
            self.closeSession()
7442 vikram.rag 2232
 
12614 amit.gupta 2233
    def getAmazonOrdersToAcknowledge(self, source):
7442 vikram.rag 2234
        try:
2235
            ordersack = []
12614 amit.gupta 2236
            for amazonOrderId,amazonOrderCode,status,txnid,count in get_amazon_orders_to_acknowledge(source):
7442 vikram.rag 2237
                orderack = AmazonOrdersToAcknowledge()
2238
                orderack.amazonOrderId = amazonOrderId
2239
                orderack.amazonOrderItemId = amazonOrderCode
2240
                orderack.status = status
2241
                orderack.transaction_id = txnid
2242
                orderack.count = count
2243
                ordersack.append(orderack)
2244
            return ordersack    
2245
        except:
2246
            return None
2247
        finally:
2248
            self.closeSession()   
2249
 
2250
    def changeAmazonOrderStatus(self,amazonOrderCode,status):
2251
        try:
2252
            change_amazon_order_status(amazonOrderCode,status) 
2253
        finally:
7460 kshitij.so 2254
            self.closeSession()
2255
 
7741 kshitij.so 2256
    def updateTimestampForAmazonOrder(self,orderDeliveryMap):
7460 kshitij.so 2257
        try:
7741 kshitij.so 2258
            return update_timestamp_for_amazon_order(orderDeliveryMap)
7530 kshitij.so 2259
        except:
2260
            return False
7460 kshitij.so 2261
        finally:
7530 kshitij.so 2262
            self.closeSession()
2263
 
2264
    def updateSourceDetailTimestamp(self,id,lastUpdatedOn):
2265
        try:
2266
            return update_source_detail_timestamp(id,lastUpdatedOn)
2267
        except:
2268
            return False
2269
        finally:
7442 vikram.rag 2270
            self.closeSession()   
7607 anupam.sin 2271
 
2272
    def getOrdersByMobileNumber(self, mobileNumber):
2273
        try:
2274
            orders = get_orders_by_mobile_number(mobileNumber)
2275
            return [to_t_order(order) for order in orders]
2276
        finally:
2277
            self.closeSession()
7427 anupam.sin 2278
 
7645 anupam.sin 2279
    def getOrdersByAmazonOrderCode(self, amazonId):
7607 anupam.sin 2280
        try:
2281
            orders = get_orders_by_amazon_id(amazonId)
2282
            return [to_t_order(order) for order in orders]
2283
        finally:
2284
            self.closeSession()
7730 anupam.sin 2285
 
2286
    def convertStoreToNormal(self, orderId):
2287
        try:
2288
            return convert_store_to_normal(orderId)
2289
        except:
2290
            return False
2291
        finally:
2292
            self.closeSession()
7822 amar.kumar 2293
 
2294
    def updateFreebieItem(self, orderId, newFreebieItemId):
2295
        try:
2296
            return to_t_order(update_freebie_item(orderId, newFreebieItemId))
2297
        finally:
2298
            self.closeSession()
7938 manish.sha 2299
 
7967 anupam.sin 2300
    def getHotspotServiceMatrices(self):
2301
        try:
2302
            return [to_t_hotspotServiceMatrix(hotpotServiceMatrix) for hotpotServiceMatrix in get_hotspot_service_matrices()]
2303
        finally:
2304
            self.closeSession()
2305
 
7938 manish.sha 2306
    def updateOrderAWB(self, orderId, airwayBillNo):
2307
        try:
7985 manish.sha 2308
            return to_t_order(update_order_AWB(orderId, airwayBillNo))
7938 manish.sha 2309
        finally:
2310
            close_session()
8182 amar.kumar 2311
    def getOrdersByVendor(self, vendors, statuses):
2312
        try:
2313
            return [to_t_order(order) for order in get_orders_by_vendor(vendors, statuses)]
2314
        finally:
2315
            close_session()
7607 anupam.sin 2316
 
8182 amar.kumar 2317
    def createEbayOrder(self, ebayOrder):
2318
        try:
2319
            create_ebay_order(ebayOrder)
2320
        finally:
2321
            close_session()
2322
    def getEbayOrderByOrderId(self, orderId):
2323
        try:
2324
            return to_t_ebayOrder(get_ebay_order_by_orderId(orderId))
2325
        finally:
2326
            close_session()
2327
 
2328
    def getEbayOrderBySalesRecNumber(self, salesRecordNumber):
2329
        try:
2330
            return to_t_ebayOrder(get_ebay_order_by_sales_rec_number(salesRecordNumber))
2331
        finally:
2332
            close_session()
2333
 
8241 amar.kumar 2334
    def getEbayOrder(self, salesRecordNumber, listingId, paisaPayId):
8182 amar.kumar 2335
        try:
8253 amar.kumar 2336
            return [to_t_ebayOrder(order) for order in get_ebay_order(salesRecordNumber, listingId, paisaPayId)]
8182 amar.kumar 2337
        finally:
2338
            close_session()
2339
 
2340
    def updateEbayOrder(self, ebayOrder):
2341
        try:
2342
            update_ebay_order(ebayOrder)
2343
        finally:
2344
            close_session()
2345
 
2346
    def ebayOrderExists(self, salesRecNumber, ebayListingId):
2347
        try:
2348
            return ebay_order_exists(salesRecNumber, ebayListingId)
2349
        finally:
2350
            close_session()
2351
 
2352
    def updateOrderForEbay(self, order):
2353
        try:
2354
            update_order_for_ebay(order)
2355
        finally:
2356
            close_session()
2357
 
2358
    def splitEbayOrder(self, orderId, splitOrderQty, splitOrderItemId, usePowerShip):
2359
        try:
2360
            return to_t_order(split_ebay_order(orderId, splitOrderQty, splitOrderItemId, usePowerShip))
2361
        finally:
2362
            close_session()
8282 kshitij.so 2363
 
2364
    def addOrUpdateAmazonFbaSalesSnapshot(self,amazonfbasalessnapshot):
2365
        try:
2366
            add_or_update_amazon_fba_sales_snapshot(amazonfbasalessnapshot)
2367
        finally:
2368
            close_session()
2369
 
2370
    def getAmazonFbaSalesSnapshotForDays(self,days):
2371
        fbasalessnapshot = []
2372
        try:
2373
            snapshots = get_amazon_fba_sales_snapshot_for_days(days)
2374
            for snapshot in snapshots:
2375
                fbasalessnapshot.append(to_t_amazonFbaSalesSnapshot(snapshot)) 
2376
            return fbasalessnapshot
2377
        except:
2378
            return None
2379
        finally:
2380
            close_session()
2381
 
2382
    def getAmazonFbaSalesLatestSnapshotForItem(self,item_id):
2383
        try:
8363 vikram.rag 2384
            return to_t_amazonFbaSalesSnapshot(get_amazon_fba_sales_latest_snapshot_for_item(item_id))
8282 kshitij.so 2385
        except:
2386
            return None
2387
        finally:
2388
            close_session()
8532 vikram.rag 2389
 
8488 amar.kumar 2390
    def createSnapdealOrder(self, snapdeal_order):
2391
        try:
2392
            create_snapdeal_order(snapdeal_order)
2393
        finally:
2394
            close_session()
2395
 
2396
    def getSnapdealOrder(self, orderId, reference_code, suborder_id):
2397
        try:
11424 kshitij.so 2398
            return [to_t_snapdealOrder(snapdealOrder) for snapdealOrder in get_snapdeal_order(orderId, reference_code, suborder_id)]
2399
            #return to_t_snapdealOrder(get_snapdeal_order(orderId, reference_code, suborder_id))
8488 amar.kumar 2400
        finally:
2401
            close_session()
2402
 
8802 amar.kumar 2403
    def snapdealOrderExists(self, suborder_id, referenceCode):
8488 amar.kumar 2404
        try:
8802 amar.kumar 2405
            return snapdeal_order_exists(suborder_id, referenceCode)
8488 amar.kumar 2406
        finally:
2407
            close_session()   
8532 vikram.rag 2408
 
2409
    def updateLatestFbaPricesForItem(self,fbaitemprices):
2410
        try:        
2411
            update_latest_fba_prices_for_item(fbaitemprices)
2412
        finally:
8961 vikram.rag 2413
            close_session()
2414
 
2415
    def flipkartOrderExists(self,flipkartOrderId,flipkartSubOrderId):
2416
        try:
2417
            return flipkart_order_exists(flipkartOrderId,flipkartSubOrderId)
2418
        finally:
2419
            self.closeSession()
8532 vikram.rag 2420
 
8961 vikram.rag 2421
    def createFlipkartOrder(self,flipkartOrder):
2422
        try:
2423
            create_flipkart_order(flipkartOrder)
2424
        finally:           
8990 vikram.rag 2425
            self.closeSession()
2426
 
2427
    def getFlipkartOrder(self,orderId):
2428
        try:
2429
            return to_t_flipkartOrder(get_flipkart_order(orderId))
2430
        finally:
9159 amar.kumar 2431
            self.closeSession()    
2432
 
2433
    def getFlipkartOrderByOrderItemId(self, flipkartOrderItemId):
2434
        try:
2435
            return to_t_flipkartOrder(get_flipkart_order_by_subOrderId(flipkartOrderItemId))
2436
        finally:
2437
            close_session()    
9107 vikram.rag 2438
            self.closeSession()
2439
 
2440
    def updateFlipkartOrderDatesAndAWB(self,flipkartOrderId,flipkartSubOrderId,date,awb):
2441
        try:
2442
            return update_flipkart_order_dates_and_awb(flipkartOrderId,flipkartSubOrderId,date,awb)
2443
        finally:
2444
            self.closeSession()
9338 manish.sha 2445
 
9571 vikram.rag 2446
    def getOrdersCreatedAfterTimestampForSource(self,timestamp,source):
9404 vikram.rag 2447
        try:
9571 vikram.rag 2448
            return get_orders_count_created_after_timestamp_for_source(timestamp,source)
9404 vikram.rag 2449
        finally:
2450
            self.closeSession()
2451
 
2452
 
9338 manish.sha 2453
    def getOrderForAirwayBillNo(self, airwaybillNo):
13276 manish.sha 2454
        ret_Orders =[]
9338 manish.sha 2455
        try:
13276 manish.sha 2456
            orderList = get_order_for_awb(airwaybillNo)
2457
            for order in orderList:
2458
                ret_Orders.append(to_t_order(order))
2459
            return ret_Orders
9338 manish.sha 2460
        finally:
2461
            close_session()
2462
 
9651 manish.sha 2463
    def getMinCreatedTimeStampUndeliveredOrdersForSource(self, source): 
2464
        try:
2465
            return get_min_created_timestamp_undelivered_orders_for_source(source)
2466
        finally:
2467
            close_session()
2468
 
9882 manish.sha 2469
    def updateSnapdealOrdersStatus(self, orders):
9651 manish.sha 2470
        try:
9882 manish.sha 2471
            update_snapdeal_orders_status(orders)
9651 manish.sha 2472
        finally:
2473
            close_session()
2474
 
2475
    def updateFlipkartOrdersStatus(self, delivered_orders):
2476
        try:
2477
            update_flipkart_orders_status(delivered_orders)
2478
        finally:
2479
            close_session()
9801 manish.sha 2480
 
2481
    def bulkAddOrUpdateAmazonFbaSalesSnapshot(self, amazonfbasalessnapshotlist):  
2482
        try:
2483
            bulk_add_or_update_amazon_fba_sales_snapshot(amazonfbasalessnapshotlist)
2484
        finally:
9945 vikram.rag 2485
            close_session()
2486
 
2487
    def getCreatedOrdersForFlipkart(self,flipkartorderids):
2488
        try:
2489
            return get_created_orders_for_flipkart(flipkartorderids)
2490
        finally:
11896 amit.gupta 2491
            close_session()
2492
 
2493
    def isPrivateDealTransaction(self, transactionId):
2494
        try:
11903 amit.gupta 2495
            return is_private_deal_transaction(transactionId)
11896 amit.gupta 2496
        except:
2497
            return False
2498
        finally:
9945 vikram.rag 2499
            close_session()    
9651 manish.sha 2500
 
12103 manish.sha 2501
    def changeEasyshipMfnOrderTxnStatus(self, transactionId, status, description, pickUp, orderType, source, shipTimestamp, deliveryTimeStamp):
2502
        try:
2503
            return change_easyship_mfn_order_txn_status(transactionId, status, description, pickUp, orderType, source, shipTimestamp, deliveryTimeStamp)
2504
        finally:
2505
            close_session() 
2506
 
2507
    def updateAmazonFbaOrdersReturns(self, fbaOrderReturns):
2508
        try:
2509
            update_amazon_fba_order_returns(fbaOrderReturns)
2510
        finally:
2511
            close_session()
2512
 
2513
    def getAllAmazonFbaOrderReturnsByCurrentTime(self, insertionTimestamp):
2514
        try:
2515
            ret_order_returns= []
2516
            returns = get_all_amazon_fba_order_returns(insertionTimestamp)
2517
            for order_return in returns:
2518
                ret_order_returns.append(to_t_amazonFbaOrderReturn(order_return))
2519
            return ret_order_returns
2520
        finally:
2521
            close_session()
2522
 
2523
    def getTotalSaleReturnsFbaSkusCurentTime(self, insertionTimestamp):
2524
        try:
2525
            return get_total_sale_returns_fba_skus_curent_time(insertionTimestamp)
2526
        finally:
2527
            close_session()
12398 kshitij.so 2528
 
2529
    def getAmazonFbaSalesLatestSnapshotForItemLocationWise(self,item_id,location):
2530
        try:
2531
            return to_t_amazonFbaSalesSnapshot(get_amazon_fba_sales_latest_snapshot_for_item_location_wise(item_id,location))
2532
        except:
2533
            return None
2534
        finally:
2535
            close_session()
12103 manish.sha 2536
 
12589 manish.sha 2537
    def getVerificationPendingOrdersFK(self):
2538
        ret_Orders = []
2539
        try:
2540
            fk_Orders = get_verification_pending_orders_fk()
2541
            for fk_order in fk_Orders:
2542
                ret_Orders.append(to_t_flipkartOrder(fk_order))
2543
            return ret_Orders
2544
        finally:
2545
            close_session()
2546
 
12653 manish.sha 2547
    def addInvoiceDetailsToOrders(self, transactionId, customerId):
2548
        try:
2549
            add_invoice_details_to_orders(transactionId, customerId)
2550
        finally:
2551
            close_session()
2552
 
12772 manish.sha 2553
    def getFAOrderByFkOrderId(self, fkOrderId, fkOrderItemId):
2554
        try: 
2555
            return to_t_flipkartAdvantageOrder(get_fa_order_by_fk_order_id(fkOrderId, fkOrderItemId))
2556
        finally:
2557
            close_session()
2558
 
2559
    def getAllFAOrdersList(self, status):
2560
        ret_fa_Orders =[]
2561
        try:
2562
            faOrders = get_all_fa_orders_list(status)
2563
            for faOrder in faOrders:
2564
                ret_fa_Orders.append(to_t_flipkartAdvantageOrder(faOrder))
2565
            return ret_fa_Orders
2566
        finally:
2567
            close_session()
2568
 
2569
    def addUpdateFaOrdersBulk(self, faOrdersList):
2570
        try:
2571
            add_update_fa_orders_bulk(faOrdersList)
2572
        finally:
2573
            close_session()
2574
 
2575
    def flipkartFaOrderExists(self, fkOrderId, fkOrderItemId):
2576
        try:
2577
            return flipkart_fa_order_exists(fkOrderId, fkOrderItemId)
2578
        finally:
2579
            close_session()
2580
 
12979 kshitij.so 2581
    def getRcgOrderStatus(self,rechargeOrderId,isFinal):
2582
        try:
2583
            return get_recharge_order_status(rechargeOrderId,isFinal).to_thrift_object()
2584
        finally:
2585
            self.closeSession()
2586
 
2587
    def getRcgTransactionStatus(self,rechargeTransactionId,isFinal):
2588
        try:
2589
            return to_t_rechargeTransaction(get_recharge_transaction_status(rechargeTransactionId,isFinal))
2590
        finally:
2591
            self.closeSession()
2592
 
13146 manish.sha 2593
    def acceptPackageOrders(self, orders):
2594
        try:
2595
            return accept_package_orders(orders)
2596
        finally:
2597
            self.closeSession()
12979 kshitij.so 2598
 
13146 manish.sha 2599
    def getGroupOrdersByLogisticsTxnId(self, logisticsTxnId):
2600
        ret_Orders =[]
2601
        try:
2602
            ordersList = get_group_orders_by_logistics_txn_id(logisticsTxnId)
2603
            for order in ordersList:
2604
                ret_Orders.append(to_t_order(order))
2605
            return ret_Orders
2606
        finally:
2607
            self.closeSession()
2608
 
20811 kshitij.so 2609
    def addBillingDetailsForGrouppedOrders(self, order_ids, invoice_number, itemNumbersMap, serialNumbersMap, freebieWarehouseIdMap, billed_by, jacketNumber, billingType, authorize, invoiceType):
13146 manish.sha 2610
        try:
20811 kshitij.so 2611
            return add_billing_details_for_groupped_orders(order_ids, invoice_number, itemNumbersMap, serialNumbersMap, freebieWarehouseIdMap, billed_by, jacketNumber, billingType, authorize, invoiceType)
13146 manish.sha 2612
        finally:
2613
            self.closeSession()
13276 manish.sha 2614
 
2615
    def getInvoiceFormatLogisticsTxnId(self, transactionId, shipementSeq):
2616
        try:
2617
            return get_invoice_format_logistics_txn_id(transactionId, shipementSeq)
2618
        finally:
2619
            self.closeSession()
13584 manish.sha 2620
 
13691 manish.sha 2621
    def createHomeShopOrder(self, hsOrder):
2622
        try:
2623
            create_homeshop_order(hsOrder)
2624
        finally:
2625
            close_session()
2626
 
2627
    def getHomeShopOrder(self, orderId, hsOrderNo, hsSubOrderNo):
2628
        try:
2629
            return [to_t_hsOrder(hsOrder) for hsOrder in get_homeshop_order(orderId, hsOrderNo, hsSubOrderNo)]
2630
            #return to_t_snapdealOrder(get_snapdeal_order(orderId, reference_code, suborder_id))
2631
        finally:
2632
            close_session()
2633
 
2634
    def homeShopOrderExists(self, hsOrderNo, hsSubOrderNo):
2635
        try:
2636
            return homeshop_order_exists(hsOrderNo, hsSubOrderNo)
2637
        finally:
2638
            close_session()   
2639
 
2536 chandransh 2640
    def closeSession(self, ):
2641
        close_session()
3376 rajveer 2642
 
2643
    def isAlive(self, ):
2644
        """
5447 anupam.sin 2645
        For checking whether service is alive or not. It also checks connectivity with database
3376 rajveer 2646
        """
2647
        try:
2648
            return is_alive()
2649
        finally:
6988 rajveer 2650
            close_session()
13941 amit.gupta 2651
 
2652
    def creditBatch(self, batchId, userAmount):
14134 amit.gupta 2653
        try:
2654
            now = datetime.datetime.now()
2655
            sum = 0
2656
            for key, amount in json.loads(userAmount).iteritems():
2657
                userId = int(key)
21367 amit.gupta 2658
                add_amount_in_wallet(userId, amount, batchId, WalletReferenceType.CASHBACK, True, "Cashback for orders")
14134 amit.gupta 2659
                sum += amount
2660
 
2661
            batchCreditTracker = DtrBatchCreditTracker()
2662
            batchCreditTracker.id = batchId
2663
            batchCreditTracker.amount = sum
2664
            batchCreditTracker.creditedOn = now
2665
 
2666
            session.commit()
2667
        finally:
2668
            close_session()
17470 manish.sha 2669
 
2670
    def splitBulkOrder(self, orderId, splitOrderQty):
2671
        try:
2672
            return to_t_order(split_bulk_order(orderId, splitOrderQty))
2673
        finally:
2674
            close_session()
18041 manish.sha 2675
 
2676
    def moveOrdersToCorrectWarehouse(self):
2677
        try:
2678
            return move_orders_to_correct_warehouse()
18046 manish.sha 2679
        except:
2680
            return "Error"
18041 manish.sha 2681
        finally:
2682
            close_session()
18046 manish.sha 2683
 
18590 manish.sha 2684
    def verifyOrderForTransaction(self, transactionId):
2685
        try:
2686
            return verify_orders_for_transaction(transactionId)
2687
        finally:
2688
            close_session()
2689
 
18634 manish.sha 2690
    def getCreditorInfo(self, creditorId, name):
2691
        try:
2692
            return to_t_Creditor(get_creditor_info(creditorId, name))
2693
        except:
2694
            return None
2695
        finally:
2696
            close_session()
2697
 
2698
    def updateCreditorInfo(self, creditor):
2699
        try:
2700
            return update_creditor_info(creditor)
2701
        finally:
2702
            close_session()
2703
 
2704
    def getUserSanctionDetails(self, userId):
2705
        try:
18677 manish.sha 2706
            returnMap = get_user_sanction_details(userId, None)
2707
            sanctionsList = []
18700 manish.sha 2708
            for creditorMap in returnMap.values():
18677 manish.sha 2709
                for sanction in creditorMap.get('Sanctions'):
2710
                    sanctionsList.append(to_t_UserSanction(sanction, creditorMap.get('TicketSize')))
2711
            return sanctionsList
18634 manish.sha 2712
        finally:
2713
            close_session()
2714
 
2715
    def getUserSanctionDetailsForCreditor(self, userId, creditorId):
2716
        try:
18703 manish.sha 2717
            returnMap = get_user_sanction_details(userId, creditorId)
2718
            sanctionsList = []
2719
            for creditorMap in returnMap.values():
2720
                for sanction in creditorMap.get('Sanctions'):
2721
                    sanctionsList.append(to_t_UserSanction(sanction, creditorMap.get('TicketSize')))
2722
            return sanctionsList[0]
18634 manish.sha 2723
        except:
2724
            return None
2725
        finally:
2726
            close_session()
2727
 
2728
    def updateUserSanction(self, userSanaction):
2729
        try:
2730
            return update_user_sanction(userSanaction)
2731
        finally:
2732
            close_session()
2733
 
2734
    def getCreditHistoryRecordsForTransaction(self, paymentId, creditTxnType):
2735
        try:
2736
            return [to_t_CreditHistory(creditHistory) for creditHistory in get_credit_history_records(paymentId, None, None, creditTxnType)]
2737
        finally:
2738
            close_session()
2739
 
2740
    def getCreditHistoryRecordsForUserAndCreditor(self, userId, creditorId, creditTxnType):
2741
        try:
2742
            return [to_t_CreditHistory(creditHistory) for creditHistory in get_credit_history_records(None, userId, creditorId, creditTxnType)]
2743
        finally:
2744
            close_session()
2745
 
2746
    def processCreditTransaction(self, paymentId, userId, creditorId, creditTxns):
2747
        try:
2748
            return process_credit_transaction(paymentId, userId, creditorId, creditTxns)
2749
        finally:
2750
            close_session()
2751
 
2752
    def getLoanPayableForUserToCreditor(self, userId, creditorId, dueDate):
2753
        try:
2754
            return get_loan_payable_for_user_to_creditor(userId, creditorId, dueDate)
2755
        finally:
2756
            close_session()
2757
 
2758
    def getLoanHistoryRecordsForTransaction(self, paymentId, creditTxnType):
2759
        try:
2760
            return [to_t_LoanHistory(loanHistory) for loanHistory in get_loan_history_records(paymentId, None, None, creditTxnType)]
2761
        finally:
2762
            close_session()
2763
 
2764
    def getLoanHistoryRecordsForUserAndCreditor(self, userId, creditorId, creditTxnType):
2765
        try:
2766
            return [to_t_LoanHistory(loanHistory) for loanHistory in get_loan_history_records(None, userId, creditorId, creditTxnType)]
2767
        finally:
2768
            close_session()
2769
 
2770
    def processLoanTransaction(self, paymentId, userId, creditorId, creditTxns):
2771
        try:
2772
            return process_loan_transaction(paymentId, creditTxns)
2773
        finally:
18769 manish.sha 2774
            close_session()
2775
 
2776
    def getLimitedCreditHistoryRecords(self, paymentId, userId, creditorId, limit, offset):
2777
        try:
18805 manish.sha 2778
            hasMore, totalCount, creditHistoryList = get_credit_history_records_paginated(paymentId, userId, creditorId, None, limit, offset)
2779
            return to_t_PaginatedCreditHistory(hasMore, totalCount, creditHistoryList)
18769 manish.sha 2780
        finally:
2781
            close_session()
2782
 
2783
    def getLimitedLoanHistoryRecords(self, paymentId, userId, creditorId, limit, offset):
2784
        try:
18805 manish.sha 2785
            hasMore, totalCount, loanHistoryList = get_loan_history_records_paginated(paymentId, userId, creditorId, None, limit, offset)
2786
            return to_t_PaginatedLoanHistory(hasMore, totalCount, loanHistoryList)
18769 manish.sha 2787
        finally:
2788
            close_session()
18794 manish.sha 2789
 
19868 manas 2790
    def getUserSanctionsDetailsAsPerLimit(self, userId, creditorId, limit, offset,sort):
18794 manish.sha 2791
        try:
19868 manas 2792
            hasMore, totalCount, returnMap = get_user_sanction_details_paginated(userId, creditorId, limit, offset,sort)
18794 manish.sha 2793
            sanctionsList = []
2794
            for creditorMap in returnMap.values():
2795
                for sanction in creditorMap.get('Sanctions'):
2796
                    sanctionsList.append(to_t_UserSanction(sanction, creditorMap.get('TicketSize')))
2797
            return to_t_PaginatedUserSanction(hasMore, totalCount, sanctionsList)
2798
        finally:
2799
            close_session()
19004 manish.sha 2800
 
19889 manas 2801
    def getOutstandingPayments(self,fetchType,userId,limit):
2802
        try:
2803
            userCounterMap, outstandingResults = get_outstanding_payments(fetchType,userId,limit)
2804
            return [to_t_OutstandingPayments(outstandingResult,userCounterMap.get(outstandingResult.user_id)) for outstandingResult in outstandingResults]
2805
        finally:
2806
            close_session()
2807
 
19912 manas 2808
    def markPaymentSettled(self,userId,paymentId,totalAmount,repaymentDate):
2809
        returnMap = {}
2810
        try:
2811
            flag, message = mark_payment_settled(userId,paymentId,totalAmount,repaymentDate)
2812
            returnMap[flag] = message
2813
            return returnMap
2814
        finally:
2815
            close_session()
2816
 
19004 manish.sha 2817
    def getOrdersInBatchAsPromisedShipping(self, statuses, offset, limit, warehouse_id, source):
2818
        """
2819
        Returns at most 'limit' orders with the given statuses for the given warehouse starting from the given offset.
2820
        These orders should be in order of promised shipping time. 
2821
        Pass the status as null and the limit as 0 to ignore them.
2822
 
2823
        Parameters:
2824
         - statuses
2825
         - offset
2826
         - limit
2827
         - warehouse_id
2828
        """
2829
        try:
2830
            orders = get_orders_in_batch_as_promised_shipping(statuses, offset, limit, warehouse_id, source)
2831
            return [to_t_order(order) for order in orders]
2832
        finally:
2833
            close_session()
18794 manish.sha 2834
 
19421 manish.sha 2835
    def setOrderAttributeForMasterOrderId(self, logisticsTransactionId, attributes):
2836
        try:
2837
            set_order_attribute_for_master_order_id(logisticsTransactionId, attributes)
2838
        finally:
2839
            close_session()
2840
 
2841
    def updateMasterOrderAWB(self, logisticsTransactionId, airwaybill_no):
2842
        try:
2843
            return update_master_order_awb(logisticsTransactionId, airwaybill_no)
2844
        finally:
2845
            close_session()
2846
 
19474 manish.sha 2847
    def addOrUpdateShipmentLogisticsCostDetails(self, shipmentLogisticsCostDetails):
2848
        try:
2849
            return add_or_update_shipment_logistics_cost_details(shipmentLogisticsCostDetails)
2850
        finally:
2851
            close_session()
19691 manish.sha 2852
 
2853
    def getReturnOrderInfo(self, id):
2854
        try:
2855
            returnOrderInfo = get_return_order_info(id)
19814 kshitij.so 2856
            return to_t_returnOrderInfo(returnOrderInfo)
19691 manish.sha 2857
        finally:
2858
            close_session()
2859
 
2860
    def getReturnOrderInfoList(self, order_ids):
2861
        try:
2862
            returnOrdersInfoMap = get_return_orders_info_map(order_ids)
2863
            mapToReturn = {}
2864
            for orderId, returnOrdersList in returnOrdersInfoMap.items():
2865
                returnList = []
2866
                for returnOrder in returnOrdersList:
2867
                    returnList.append(to_t_returnOrderInfo(returnOrder))
2868
                mapToReturn[orderId] = returnList
2869
            return mapToReturn
2870
        finally:
2871
            close_session()
19474 manish.sha 2872
 
19691 manish.sha 2873
    def getReturnOrderInfoListAsByStatus(self, order_ids, statuses):
2874
        try:
2875
            returnOrdersInfoMap = get_return_orders_info_map(order_ids, statuses)
2876
            mapToReturn = {}
2877
            for orderId, returnOrdersList in returnOrdersInfoMap.items():
2878
                returnList = []
2879
                for returnOrder in returnOrdersList:
2880
                    returnList.append(to_t_returnOrderInfo(returnOrder))
2881
                mapToReturn[orderId] = returnList
2882
            return mapToReturn
2883
        finally:
2884
            close_session()
2885
 
2886
    def updateReturnOrderInfo(self, returnInfo):
2887
        try:
2888
            return update_return_order_info(returnInfo)
2889
        finally:
2890
            close_session()
2891
 
2892
    def bulkUpdateReturnOrderInfo(self, orderReturnInfosMap):
2893
        try:
2894
            return bulk_update_return_order_info(orderReturnInfosMap)
2895
        finally:
2896
            close_session()
2897
 
2898
    def getReturnOrdersAsPerWarehouseId(self, warehouseId):
2899
        """
2900
        Returns all return orders list as per warehouse
2901
 
2902
        Parameters:
2903
         - warehouseId
2904
        """
2905
        try:
2906
            all_returns_orders = get_return_orders_as_per_warehouse(warehouseId)
2907
            return [to_t_returnOrderInfo(order) for order in all_returns_orders]
2908
        finally:
2909
            close_session()
2910
 
19735 manish.sha 2911
    def createReturnTransaction(self, returnTransaction, itemCondition, overrideWarranty):
19691 manish.sha 2912
        """
2913
        Create Return Ticket or Transaction for all Returns
2914
 
2915
        Parameters:
2916
         - returnTransaction Thrift Object
19735 manish.sha 2917
         - itemCondition
2918
         - overrideWarranty
19691 manish.sha 2919
        """
2920
        try:
19814 kshitij.so 2921
            return to_t_returnTransaction(create_return_transaction(returnTransaction, itemCondition, overrideWarranty))
19691 manish.sha 2922
        finally:
2923
            close_session()
2924
 
2925
    def getReturnTransactionsForCustomer(self, statusList, customerMobile, customerEmail, returnTransactionId, customerId):
2926
        """
2927
        Get all return transactions as per customer and status for sepcific time interval
2928
 
2929
        Parameters:
2930
         - statusList
2931
         - customerMobile
2932
         - customerEmail
2933
         - returnTransactionId
2934
        """
2935
 
2936
        try:
2937
            transactions = get_return_transactions_for_customer(statusList, customerMobile, customerEmail, returnTransactionId, customerId)
2938
            if transactions is None:
2939
                return []
2940
            else:
2941
                return [to_t_returnTransaction(transaction) for transaction in transactions]
2942
        finally:
2943
            close_session()
2944
 
2945
    def getReturnTransaction(self, id):
2946
        """
2947
        Get Return Transaction as per given id 
2948
 
2949
        Parameters:
2950
         - id
2951
        """
2952
        try:
2953
            return to_t_returnTransaction(get_return_transaction(id))
2954
        finally:
2955
            close_session()
2956
 
2957
    def getReturnOrdersForReturnTransaction(self, returnTransactionId):
2958
        """
2959
        Get Return Orders for given return transaction
2960
 
2961
        Parameters:
2962
         - returnTransactionId
2963
        """
2964
        try:
2965
            returnorders = get_return_orders_for_return_transaction(returnTransactionId)
2966
            return [to_t_returnOrderInfo(returnorder) for returnorder in returnorders]    
2967
        finally:
2968
            close_session()
2969
 
2970
    def changeReturnTransactionStatus(self, returnTransactionId, new_status, returnOrdersIds):
2971
        """
2972
        Change Return Transaction Status 
2973
 
2974
        Parameters:
2975
         - returnTransactionId
2976
         - new_status        
2977
        """  
2978
        try:
2979
            return change_return_transaction_status(returnTransactionId, new_status, returnOrdersIds)
2980
        finally:
2981
            close_session()
2982
 
20111 kshitij.so 2983
    def createReturnPickupRequest(self, returnOrderIds):
19691 manish.sha 2984
        """
2985
        Create Return Pickup Request
2986
 
2987
        Parameters
2988
         - returnOrderIds
2989
         - providerId
2990
        """    
2991
        try:
20111 kshitij.so 2992
            return create_return_pickup_request(returnOrderIds)
19691 manish.sha 2993
        finally:
2994
            close_session()
2995
 
2996
    def updateReturnPickupRequest(self, returnPickupRequest):
2997
        """
2998
        Update Return Pickup Request
2999
 
3000
        Parameters
3001
         - ReturnPickupRequest Object
3002
        """
3003
        try:
3004
            return update_return_pickup_request(returnPickupRequest)
3005
        finally:
3006
            close_session()
3007
 
3008
    def receiveReturnPickup(self, returnOrdersMap, id):
3009
        """
3010
        Receive Return Pickup
3011
 
3012
        Parameters:
3013
         - returnOrdersMap
3014
         - id
3015
 
3016
        """
3017
        try:
3018
            return receive_return_pickup(returnOrdersMap, id)
3019
        finally:
3020
            close_session()
3021
 
3022
    def validateReturnPickup(self, returnPickupId, returnOrdersMap):
3023
        """
3024
        Validate Return Pickup 
3025
 
3026
        Parameters:
3027
         - returnPickupId 
3028
         - returnOrdersMap
3029
        """
3030
        try:
3031
            return validate_return_pickup(returnPickupId, returnOrdersMap)
3032
        finally:
3033
            close_session()
3034
 
3035
    def processReturnPickup(self, returnPickupId, returnOrdersMap):
3036
        """
3037
        Process Return Pickup
3038
 
3039
        Parameters:
3040
         - returnPickupId
3041
         - returnOrdersMap
3042
        """
3043
        try:
3044
            return process_return_pickup(returnPickupId, returnOrdersMap)
3045
        finally:
3046
            close_session()
3047
 
3048
    def markReturnTransactionComplete(self, returnTransactionId):
3049
        """
3050
        Mark Return Transaction Complete based upon the orders processed.
3051
 
3052
        Parameters:
3053
         - returnTransactionId
3054
        """
3055
        try:
3056
            return mark_return_transaction_complete(returnTransactionId)
3057
        finally:
3058
            close_session()
3059
 
3060
    def refundReturnTransactionPayment(self, returnOrdersMap, returnTransactionId):
3061
        """
3062
        Refund Return Transaction Payment
3063
 
3064
        Parameters
3065
         - returnOrdersMap
3066
         - returnTransactionId
3067
        """
3068
 
3069
        try:
3070
            return refund_return_transaction_payment(returnOrdersMap, returnTransactionId)
3071
        finally:
3072
            close_session()
3073
 
19714 manish.sha 3074
    def getEligibleOrdersForReturn(self, customerId, itemCondition, overrideWarranty):
3075
        """
3076
        Return Eligible Orders for Return Process
3077
 
3078
        Parameters 
3079
         - customerId
3080
         - itemCondition - (Damaged for return and Defective for DOA)
3081
         - overrideWarranty for Admin so that he can return any order without any warranty.
3082
 
3083
        """
3084
        try:
3085
            orders = []
3086
            eligibleOrders = get_eligible_orders_for_return(customerId, itemCondition, overrideWarranty)
3087
            for order in eligibleOrders:
3088
                orders.append(to_t_order(order))
3089
            return orders
3090
        finally:
3091
            close_session()
3092
 
3093
    def getEligibleReturnOrdersForPickup(self, customerId):
3094
        """
3095
        Return All Eligible Return Orders awaiting pickup
3096
 
3097
        Parameters 
3098
         - customerId
3099
 
3100
        """
3101
        try:
3102
            returnOrders = []
3103
            eligibleReturnOrders = get_eligible_return_orders_for_pickup(customerId)
3104
            for returnOrder in eligibleReturnOrders:
3105
                returnOrders.append(to_t_returnOrderInfo(returnOrder))
3106
            return returnOrders
3107
        finally:
3108
            close_session()
19735 manish.sha 3109
 
3110
    def validateReturnTransaction(self, customerId, returnOrdersMap, itemCondition, overrideWarranty):
3111
        """
3112
        To Validate return transaction data
19714 manish.sha 3113
 
19735 manish.sha 3114
        Parameters
3115
         - customerId
3116
         - returnOrdersMap
3117
         - itemCondition
3118
         - overrideWarranty
3119
        """
3120
        try:
3121
            return validate_return_transaction(customerId, returnOrdersMap, itemCondition, overrideWarranty)
3122
        finally:
3123
            close_session()
19817 manish.sha 3124
 
3125
    def markReturnNotRequiredOrdersProcessed(self, returnTransactionId):
3126
        """
3127
        Mark Return Not Required Orders as Processed
19735 manish.sha 3128
 
19817 manish.sha 3129
        Parameters
3130
         - returnTransactionId
3131
        """
3132
        try:
3133
            return mark_return_not_required_orders_as_processed(returnTransactionId) 
3134
        finally:
3135
            close_session()
3136
 
3137
    def getReturnPickupRequest(self, returnPickupId):
3138
        """
3139
        Get Particular Return Pickup Id
3140
        Parameters
3141
         - returnPickupId
3142
        """
3143
        try:
3144
            return to_t_rPickupRequest(get_return_pickup_request(returnPickupId))
3145
        finally:
3146
            close_session()
3147
 
19820 manish.sha 3148
    def getAllReturnOrdersForReturnPickupRequest(self, logisticsRequestId):
3149
        try:
3150
            returnOrders = []
3151
            eligibleReturnOrders = get_all_return_orders_for_return_pickup_request(logisticsRequestId)
3152
            for returnOrder in eligibleReturnOrders:
3153
                returnOrders.append(to_t_returnOrderInfo(returnOrder))
3154
            return returnOrders
3155
        finally:
3156
            close_session()
3157
 
19973 amit.gupta 3158
    def getSellerInfo(self, sellerId):
3159
        try:
3160
            return get_seller_info(sellerId)
3161
        finally:
3162
            close_session()
19980 amit.gupta 3163
 
19983 amit.gupta 3164
    def getWarehouseAddress(self, addressId):
19980 amit.gupta 3165
        try:
3166
            return get_warehouse_address(addressId)
3167
        finally:
3168
            close_session()
20028 kshitij.so 3169
 
3170
    def addShipmentDelay(self,shipmentDelayDetail):
3171
        try:
3172
            return add_shipment_delay(shipmentDelayDetail)
3173
        finally:
3174
            close_session()
19973 amit.gupta 3175
 
20025 amit.gupta 3176
    def getBuyerByWarehouse(self, warehouse_id):
3177
        try:
3178
            return get_buyer_by_warehouse(warehouse_id)
3179
        finally:
3180
            close_session()
20122 kshitij.so 3181
 
3182
    def refundReturnOrder(self, returnOrderInfo, attributes):
3183
        try:
20124 kshitij.so 3184
            return refund_return_order(returnOrderInfo, attributes)
20122 kshitij.so 3185
        finally:
3186
            close_session()
20745 kshitij.so 3187
 
3188
    def getCostDetailForLogisticsTxnId(self, logisticsTxnId):
3189
        try:
3190
            return to_t_ShipmentLogisticsCostDetail(get_cost_detail_for_logistics_txn_id(logisticsTxnId))
3191
        finally:
3192
            close_session()
20811 kshitij.so 3193
 
3194
    def addShipmentLogisticDetail(self, shipmentLogisticsCostDetail):
3195
        try:
3196
            add_shipment_logistic_detail(shipmentLogisticsCostDetail)
3197
        finally:
3198
            close_session()
20025 amit.gupta 3199
 
20873 kshitij.so 3200
    def createPayment(self,userId, txnId, gatewayId):
3201
        try:
3202
            return create_payment(userId, txnId, gatewayId)
3203
        finally:
3204
            close_session()
3205
 
3206
    def calculatePaymentAmount(self, txnId):
3207
        try:
3208
            return calculate_payment_amount(txnId)
3209
        finally:
3210
            close_session()
3211
 
20954 kshitij.so 3212
    def getBilledOrdersForManifestGen(self, warehouse_id, logistics_provider_id, cod):
3213
        try:
3214
            return_orders = []
3215
            orders = get_billed_orders_for_manifest_gen(warehouse_id, logistics_provider_id, cod)
3216
            for order_list in orders:
3217
                for order in order_list:
3218
                    return_orders.append(to_t_order(order))
3219
            return return_orders
3220
        finally:
3221
            close_session()
21044 kshitij.so 3222
 
3223
    def registerRsa(self, userId, activation_code):
3224
        try:
3225
            return register_rsa(userId, activation_code)
3226
        finally:
3227
            close_session()
21090 kshitij.so 3228
 
3229
    def addSalesAssociate(self, pmsa, referrerEmail, l1_userEmail):
3230
        try:
3231
            return add_sales_associate(pmsa, referrerEmail, l1_userEmail)
3232
        finally:
3233
            close_session()
3234
 
3235
    def searchPmsa(self, pmsaSearchFilter, associateEmail):
3236
        pmsa_list = []
3237
        try:
3238
            for pmsa in search_pmsa(pmsaSearchFilter, associateEmail):
3239
                pmsa_list.append(to_t_pmsa(pmsa, "", ""))
3240
            return pmsa_list
3241
        finally:
3242
            close_session()
3243
 
3244
    def getPmsaUser(self,id, associateEmail):
3245
        try:
3246
            pmsa, l1_user_email, l2_user_email = get_pmsa_user(id, associateEmail)
3247
            return to_t_pmsa(pmsa, l1_user_email, l2_user_email)
3248
        finally:
3249
            close_session()
3250
 
3251
    def updatePmsaUser(self, pmsa, associateEmail):
3252
        try:
3253
            return update_pmsa_user(pmsa, associateEmail)
3254
        finally:
3255
            close_session()
3256
 
3257
    def getPendingAssociates(self, associateEmail):
3258
        pmsa_list = []
3259
        try:
3260
            for pmsa in get_pending_pmsa(associateEmail):
3261
                pmsa_list.append(to_t_pmsa(pmsa, "", ""))
3262
            return pmsa_list
3263
        finally:
3264
            close_session()
3265
 
3266
    def getPmsaUsers(self, associateEmail):
3267
        pmsa_list = []
3268
        try:
3269
            for pmsa in get_pmsa_users(associateEmail):
3270
                pmsa_list.append(to_t_pmsa(pmsa, "", ""))
3271
            return pmsa_list
3272
        finally:
3273
            close_session()
3274
 
3275
    def getStatsForAssociates(self, associateEmail):
3276
        try:
3277
            return get_stats_for_associates(associateEmail)
3278
        finally:
3279
            close_session()
20954 kshitij.so 3280
 
21092 kshitij.so 3281
    def getmypmsaprofile(self, associateEmail):
3282
        return to_t_pmsa(get_pmsa_user(None, associateEmail), "" ,"")
21101 kshitij.so 3283
 
21363 kshitij.so 3284
    def creditUserWallet(self, userId, amount, cash_back):
21101 kshitij.so 3285
        try:
21363 kshitij.so 3286
            return credit_user_wallet(userId, amount, cash_back)
21101 kshitij.so 3287
        finally:
3288
            close_session()
3289
 
21092 kshitij.so 3290
 
19817 manish.sha 3291
 
14134 amit.gupta 3292
def main():
3293
    OrderServiceHandler().creditBatch(2, '{"483649":100.0, "8021773":23, "123213":10}')
3294
 
3295
if __name__ == '__main__':
3296
    main()