Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
442 rajveer 1
'''
2
Created on 13-Sep-2010
3
 
4
@author: rajveer
5
'''
6
 
21096 amit.gupta 7
from collections import namedtuple
16025 amit.gupta 8
from elixir import session
9
from shop2020.clients.CatalogClient import CatalogClient
10
from shop2020.clients.InventoryClient import InventoryClient
20724 kshitij.so 11
from shop2020.clients.TransactionClient import TransactionClient
23121 amit.gupta 12
from shop2020.logistics.service.impl import BluedartService, DataService, \
22636 amit.gupta 13
    EcomExpressService
644 chandransh 14
from shop2020.logistics.service.impl.DataService import Awb, AwbUpdate, Provider, \
16025 amit.gupta 15
    DeliveryEstimate, WarehouseAllocation, PublicHolidays, \
21096 amit.gupta 16
    ServiceableLocationDetails, PickupStore, Locations, ProviderCosting, \
17
    BluedartAttribute, PincodeStates
16025 amit.gupta 18
from shop2020.thriftpy.logistics.ttypes import LogisticsServiceException, \
21096 amit.gupta 19
    DeliveryType, LogisticsLocationInfo, LocationInfo, ProviderInfo, \
20
    DeliveryEstimateAndCosting
19413 amit.gupta 21
from shop2020.thriftpy.model.v1.inventory.ttypes import Warehouse, BillingType, \
16025 amit.gupta 22
    WarehouseType
442 rajveer 23
from shop2020.utils.Utils import log_entry, to_py_date, to_java_date
23121 amit.gupta 24
from shop2020.utils.caching.SimpleCaching import memoized
5964 amar.kumar 25
from sqlalchemy.sql import or_
16025 amit.gupta 26
import datetime
3355 chandransh 27
import logging
21096 amit.gupta 28
import math
13146 manish.sha 29
import os
16025 amit.gupta 30
import sys
31
import time
20724 kshitij.so 32
import traceback
19413 amit.gupta 33
 
3355 chandransh 34
logging.basicConfig(level=logging.DEBUG)
442 rajveer 35
 
19413 amit.gupta 36
PincodeProvider = namedtuple("PincodeProvider", ["dest_pin", "provider"])
37
 
3217 rajveer 38
warehouse_allocation_cache = {}
39
serviceable_location_cache = {}
40
delivery_estimate_cache = {}
16025 amit.gupta 41
warehouse_location_cache = {}
19413 amit.gupta 42
location_state={}
20275 amit.gupta 43
 
44
'Delhivery Bluedart, Fedex Surface, Fedex Air'
19413 amit.gupta 45
state_locations = {}
19421 manish.sha 46
provider_costing_sheet = {}
23135 amit.gupta 47
 
48
 
19421 manish.sha 49
DELHIVERY = 3
6370 rajveer 50
 
23135 amit.gupta 51
RQUICK = 47
23839 amit.gupta 52
RQUICKSURFACE = 48
23135 amit.gupta 53
ARAMEX = 2
54
ECOMEXPRESS = 49
23839 amit.gupta 55
PROVIDER_PRIORITY = [RQUICKSURFACE, RQUICK, ARAMEX, ECOMEXPRESS]
23135 amit.gupta 56
 
19413 amit.gupta 57
#pincode location map is ab
58
#{'110001':{1:{"sameState":False, "providerInfo":{1:(1,1), 2:(1,1)}}},}
59
pincode_locations = {}
60
#{(dest_pin, provider):(otgAvailable,providerCodLimit, websiteCodLimit, storeCodLimit, providerPrepaidLimit)} 
61
serviceable_map = {}
62
 
63
#Need to identify a better way
64
statepinmap={'11':0, 
65
             '40':1,'41':1,'42':1,'43':1,'44':1,
66
             '56':2, '57':2, '58':2, '59':2,
67
             '12':3, '13':3, 
68
             '30':4, '31':4, '32':4, '33':4, '34':4,
69
             '36':6,'37':6,'38':6,'39':6
70
             }
71
 
3218 rajveer 72
'''
73
This class is for only data transfer. Never used outside this module.
74
'''
75
class _DeliveryEstimateObject:
6537 rajveer 76
    def __init__(self, delivery_time, delivery_delay, provider_id, codAllowed, otgAvailable):
3218 rajveer 77
        self.delivery_time = delivery_time
6537 rajveer 78
        self.delivery_delay = delivery_delay
3218 rajveer 79
        self.provider_id = provider_id
4866 rajveer 80
        self.codAllowed = codAllowed
6524 rajveer 81
        self.otgAvailable = otgAvailable
3218 rajveer 82
 
3187 rajveer 83
def initialize(dbname="logistics", db_hostname="localhost"):
442 rajveer 84
    log_entry("initialize@DataAccessor", "Initializing data service")
3187 rajveer 85
    DataService.initialize(dbname, db_hostname)
3218 rajveer 86
    print "Starting cache population at: " + str(datetime.datetime.now())
16025 amit.gupta 87
    #__cache_warehouse_allocation_table()
88
    __cache_warehouse_locations()
3217 rajveer 89
    __cache_serviceable_location_details_table()
90
    __cache_delivery_estimate_table()
20275 amit.gupta 91
    __cache_pincode_provider_serviceability()
19413 amit.gupta 92
    __cache_locations()
93
    __cache_pincode_estimates()    
19421 manish.sha 94
    __cache_courier_costing_table()
3217 rajveer 95
    close_session()
3218 rajveer 96
    print "Done cache population at: " + str(datetime.datetime.now())
23121 amit.gupta 97
 
98
@memoized(3600)
99
def fetchStateMaster():
100
    inventory_client = InventoryClient().get_client()
101
    return inventory_client.getStateMaster()
442 rajveer 102
 
23121 amit.gupta 103
 
19413 amit.gupta 104
def __cache_locations():
105
    locations = Locations.query.all()
106
    for location in locations:
107
        location_state[location.id] = location.state_id
108
        if not state_locations.has_key(location.state_id):
109
            state_locations[location.state_id] = []
110
        state_locations[location.state_id] = state_locations[location.state_id].append(location.state_id)
111
 
112
def __cache_pincode_estimates():
113
    delivery_estimates = DeliveryEstimate.query.all()
114
    for delivery_estimate in delivery_estimates:
115
        if not pincode_locations.has_key(delivery_estimate.destination_pin):
116
            pincode_locations[delivery_estimate.destination_pin] = {}
117
        destination_pinMap = pincode_locations[delivery_estimate.destination_pin] 
118
        if not destination_pinMap.has_key(delivery_estimate.warehouse_location):
119
            destination_pinMap[delivery_estimate.warehouse_location] = {}
120
            state_id = location_state.get(delivery_estimate.warehouse_location)
121
            sameState = __getStateFromPin(delivery_estimate.destination_pin) == state_id
122
            destination_pinMap[delivery_estimate.warehouse_location]['sameState']=sameState
123
            destination_pinMap[delivery_estimate.warehouse_location]['providerInfo'] = {} 
124
        destination_pinMap[delivery_estimate.warehouse_location]['providerInfo'][delivery_estimate.provider_id] = delivery_estimate.delivery_time + delivery_estimate.delivery_delay
125
 
126
 
127
 
128
def __cache_pincode_provider_serviceability():
129
    pincode_providers = ServiceableLocationDetails.query.filter(ServiceableLocationDetails.exp==1)
130
    for pp in pincode_providers:
131
        serviceable_map[PincodeProvider(pp.dest_pincode, pp.provider_id)] = (pp.cod, pp.otgAvailable,pp.providerCodLimit, pp.websiteCodLimit, pp.storeCodLimit, pp.providerPrepaidLimit)
132
 
133
 
3217 rajveer 134
def __cache_delivery_estimate_table():
135
    delivery_estimates = DeliveryEstimate.query.all()
136
    for delivery_estimate in delivery_estimates:
7857 rajveer 137
        delivery_estimate_cache[delivery_estimate.destination_pin, delivery_estimate.provider_id, delivery_estimate.warehouse_location]\
19421 manish.sha 138
        =delivery_estimate.delivery_time, delivery_estimate.delivery_delay, delivery_estimate.providerZoneCode
3217 rajveer 139
 
140
def __cache_serviceable_location_details_table():
5964 amar.kumar 141
    serviceable_locations = ServiceableLocationDetails.query.filter(or_("exp!=0","cod!=0"))
3217 rajveer 142
    for serviceable_location in serviceable_locations:
22147 amit.gupta 143
        #Bluedart is temporarily not serviceable
144
        if serviceable_location.provider_id==1:
145
            continue
3217 rajveer 146
        try:
147
            provider_pincodes = serviceable_location_cache[serviceable_location.provider_id]
148
        except:
149
            provider_pincodes = {}
150
            serviceable_location_cache[serviceable_location.provider_id] = provider_pincodes 
19474 manish.sha 151
        provider_pincodes[serviceable_location.dest_pincode] = serviceable_location.dest_code, serviceable_location.exp, serviceable_location.cod, serviceable_location.otgAvailable, serviceable_location.websiteCodLimit, serviceable_location.storeCodLimit, serviceable_location.providerPrepaidLimit, serviceable_location.providerCodLimit
3217 rajveer 152
 
153
def __cache_warehouse_allocation_table():
154
    warehouse_allocations = WarehouseAllocation.query.all()
155
    for warehouse_allocation in warehouse_allocations:
156
        warehouse_allocation_cache[warehouse_allocation.pincode]=warehouse_allocation.primary_warehouse_location
157
 
16025 amit.gupta 158
def __cache_warehouse_locations():
159
    client = InventoryClient().get_client()
19413 amit.gupta 160
    #client.getAllWarehouses(True)
16025 amit.gupta 161
    for warehouse in client.getAllWarehouses(True):
22636 amit.gupta 162
        if warehouse.billingWarehouseId == warehouse.id:
163
            warehouse_location_cache[warehouse.billingWarehouseId]=warehouse.logisticsLocation
19421 manish.sha 164
 
165
def __cache_courier_costing_table():
166
    allCostings = ProviderCosting.query.all()
167
    for costing in allCostings:
168
        if provider_costing_sheet.has_key(costing.provider_id):
169
            costingMap = provider_costing_sheet.get(costing.provider_id)
170
            costingMap[costing.zoneCode] = costing
171
            provider_costing_sheet[costing.provider_id] = costingMap
172
        else:
173
            costingMap = {}
174
            costingMap[costing.zoneCode] = costing
175
            provider_costing_sheet[costing.provider_id] = costingMap
176
 
16025 amit.gupta 177
 
644 chandransh 178
def get_provider(provider_id):
766 rajveer 179
    provider =  Provider.get_by(id=provider_id)
180
    return provider
644 chandransh 181
 
182
def get_providers():
5387 rajveer 183
    providers = Provider.query.filter_by(isActive = 1).all()
19413 amit.gupta 184
    return providers
644 chandransh 185
 
19413 amit.gupta 186
#it would return only states where our warehouses are present else return -1
187
def __getStateFromPin(pin):
188
    if pin[:3] in ['744', '682']:
189
        return -1
190
    elif statepinmap.has_key(pin[:2]):
191
        return statepinmap[pin[:2]]
192
    else:
193
        return -1
194
 
195
 
196
def get_logistics_locations(destination_pin, selling_price_list):
197
    #pincode_locations = {1:{"sameState":False, "providerInfo":{<provider_id>:<delay_days>}},}
198
    #pp.otgAvailable,pp.providerCodLimit, pp.websiteCodLimit, pp.storeCodLimit, pp.providerPrepaidLimit
199
    returnMap = {}
200
    if pincode_locations.has_key(destination_pin):
201
        locations = pincode_locations[destination_pin]
202
        for item_selling_price in selling_price_list:
203
            returnMap[item_selling_price] = {}
204
            for location_id, value in locations.iteritems():
205
                #put weight logic here
206
                otgAvailable = False
207
                codAvailable = False
208
                minDelay = -1
209
                maxDelay = -1
210
                serviceable = False
211
                for provider_id, delay_days in value['providerInfo'].iteritems():
19420 amit.gupta 212
                    pp = PincodeProvider(destination_pin, provider_id)
213
                    if not serviceable_map.has_key(pp):
214
                        continue
215
                    iscod, isotg, providerCodLimit, websiteCodLimit, storeCodLimit, providerPrepaidLimit = serviceable_map[pp]  
19413 amit.gupta 216
                    if item_selling_price <= providerPrepaidLimit:
217
                        if not serviceable:
20275 amit.gupta 218
                            returnMap[item_selling_price][location_id] = LocationInfo(locationId = location_id, sameState=value['sameState'])
19413 amit.gupta 219
                            serviceable = True
220
                            minDelay = delay_days
221
                            maxDelay = delay_days
222
                        else:
223
                            minDelay = min(delay_days,minDelay)
224
                            maxDelay = max(delay_days,maxDelay)
225
                        iscod = iscod and item_selling_price <= min(providerCodLimit, websiteCodLimit)
226
                        isotg = (isotg and item_selling_price >= 2000)
227
                        otgAvailable = otgAvailable or isotg
228
                        codAvailable = codAvailable or iscod
229
                if serviceable:        
20275 amit.gupta 230
                    returnMap[item_selling_price][location_id].isOtg = otgAvailable
231
                    returnMap[item_selling_price][location_id].isCod = codAvailable
19413 amit.gupta 232
                    returnMap[item_selling_price][location_id].minDelay = minDelay
233
                    returnMap[item_selling_price][location_id].maxDelay = maxDelay
234
    return returnMap
235
 
7608 rajveer 236
def get_logistics_estimation(destination_pin, item_selling_price, weight, type, billingWarehouseId):
5692 rajveer 237
    logging.info("Getting logistics estimation for pincode:" + destination_pin )
1504 ankur.sing 238
 
7608 rajveer 239
    provider_id, codAllowed, otgAvailable = __get_logistics_provider_for_destination_pincode(destination_pin, item_selling_price, weight, type, billingWarehouseId)
9964 anupam.sin 240
 
17530 manish.sha 241
    logging.info("Provider Id:  " + str(provider_id) +" codAllowed: "+str(codAllowed)+" otgAvailable: "+str(otgAvailable)+ " item_selling_price: "+str(item_selling_price))
242
 
243
    if item_selling_price > 60000:# or item_selling_price <= 250:
9964 anupam.sin 244
        codAllowed = False
245
 
16025 amit.gupta 246
    warehouse_location = warehouse_location_cache.get(billingWarehouseId)
247
    if warehouse_location is None:
248
        warehouse_location = 0
7857 rajveer 249
 
3217 rajveer 250
    if not provider_id:
5692 rajveer 251
        raise LogisticsServiceException(101, "No provider assigned for pincode: " + str(destination_pin))
644 chandransh 252
    try:
16025 amit.gupta 253
        logging.info( "destination_pin %s, provider_id %s, warehouse_location %s"%(destination_pin, provider_id, warehouse_location))
19481 manish.sha 254
        logging.info( "Estimates %s, %s, %s"%(delivery_estimate_cache[destination_pin, provider_id, warehouse_location]))
7857 rajveer 255
        delivery_time = delivery_estimate_cache[destination_pin, provider_id, warehouse_location][0]
256
        delivery_delay = delivery_estimate_cache[destination_pin, provider_id, warehouse_location][1]
6537 rajveer 257
        delivery_estimate = _DeliveryEstimateObject(delivery_time, delivery_delay, provider_id, codAllowed, otgAvailable)
3218 rajveer 258
        return delivery_estimate
1504 ankur.sing 259
    except Exception as ex:
260
        print ex
644 chandransh 261
        raise LogisticsServiceException(103, "No Logistics partner listed for this destination pincode and the primary warehouse")
23132 amit.gupta 262
 
263
def __get_provider(providerList, destination_pin, item_selling_price, weight, type, billingWarehouseId):
264
        provider_id = providerList[0]
265
        provider_serviable = serviceable_location_cache.has_key(provider_id) and serviceable_location_cache.get(provider_id).has_key(destination_pin)
266
        if provider_serviable:
267
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(provider_id).get(destination_pin)
268
            if item_selling_price <= providerPrepaidLimit:
269
                iscod = iscod and item_selling_price <= websiteCodLimit
270
                if iscod:
271
                    return provider_id, True
272
                elif len(providerList) > 1:
273
                    providerList = providerList[1:]
274
                    next_provider_id, next_cod = __get_provider(providerList, destination_pin, item_selling_price, weight, type, billingWarehouseId)
275
                    if next_cod:
276
                        return  next_provider_id, next_cod
277
                    else:
278
                        return provider_id, False
279
                else:
280
                    return provider_id, False
281
        elif len(providerList) > 1:
282
                providerList = providerList[1:]
283
                return __get_provider(providerList, destination_pin, item_selling_price, weight, type, billingWarehouseId)
284
        else:
285
            return None, False
286
 
287
 
3150 rajveer 288
 
7608 rajveer 289
def __get_logistics_provider_for_destination_pincode(destination_pin, item_selling_price, weight, type, billingWarehouseId):
20641 amit.gupta 290
    otg=False
23135 amit.gupta 291
    providerList = list(PROVIDER_PRIORITY)
292
    provider_id, isCod = __get_provider(providerList, destination_pin, item_selling_price, weight, type, billingWarehouseId)
293
    print "provider_id", provider_id 
294
    return provider_id, isCod, otg
22147 amit.gupta 295
 
20641 amit.gupta 296
 
21096 amit.gupta 297
def __getStateByPin(destination_pin):
298
    pinCodeState = PincodeStates.get_by(pin=destination_pin)
299
    if pinCodeState is not None:
300
        return pinCodeState.statename
301
    else:
302
        return None 
303
 
20641 amit.gupta 304
def __get_logistics_provider_for_destination_pincode_old(destination_pin, item_selling_price, weight, type, billingWarehouseId):
13357 manish.sha 305
    '''
306
    if serviceable_location_cache.get(6).has_key(destination_pin):
307
        if weight < 480 and serviceable_location_cache.get(3).has_key(destination_pin) and type == DeliveryType.PREPAID:
308
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit = serviceable_location_cache.get(3).get(destination_pin)
309
            if item_selling_price <= providerPrepaidLimit:
310
                iscod = iscod and item_selling_price <= websiteCodLimit
311
                otgAvailable = otgAvailable and item_selling_price >= 2000
312
                return 3, iscod, otgAvailable
313
        else:
314
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit = serviceable_location_cache.get(6).get(destination_pin)
315
            if item_selling_price <= providerPrepaidLimit:
316
                iscod = iscod and item_selling_price <= websiteCodLimit
317
                otgAvailable = otgAvailable and item_selling_price >= 2000
318
                return 6, iscod, otgAvailable
20641 amit.gupta 319
    '''        
320
    if serviceable_location_cache.has_key(3) and serviceable_location_cache.get(3).has_key(destination_pin):
321
        dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(3).get(destination_pin)
322
        if item_selling_price <= providerPrepaidLimit:
323
            iscod = iscod and item_selling_price <= websiteCodLimit
324
            otgAvailable = otgAvailable and item_selling_price >= 2000
325
            return 3, iscod, otgAvailable
8575 rajveer 326
 
17992 manish.sha 327
    if billingWarehouseId not in [12,13] and serviceable_location_cache.has_key(7) and serviceable_location_cache.get(7).has_key(destination_pin):
19533 manish.sha 328
        if item_selling_price < 3000 and serviceable_location_cache.has_key(1) and serviceable_location_cache.get(1).has_key(destination_pin):
19476 manish.sha 329
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(1).get(destination_pin)
8575 rajveer 330
            if item_selling_price <= providerPrepaidLimit:
331
                iscod = iscod and item_selling_price <= websiteCodLimit
332
                otgAvailable = otgAvailable and item_selling_price >= 2000
20275 amit.gupta 333
                if iscod:
334
                    return 1, iscod, otgAvailable
8575 rajveer 335
        else:
19476 manish.sha 336
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(7).get(destination_pin)
8575 rajveer 337
            if item_selling_price <= providerPrepaidLimit:
338
                iscod = iscod and item_selling_price <= websiteCodLimit
339
                otgAvailable = otgAvailable and item_selling_price >= 2000
20275 amit.gupta 340
                if iscod:
341
                    return 7, iscod, otgAvailable
19533 manish.sha 342
 
343
    if billingWarehouseId not in [12,13] and serviceable_location_cache.has_key(46) and serviceable_location_cache.get(46).has_key(destination_pin):
344
        if item_selling_price < 3000 and serviceable_location_cache.has_key(1) and serviceable_location_cache.get(1).has_key(destination_pin):
345
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(1).get(destination_pin)
346
            if item_selling_price <= providerPrepaidLimit:
347
                iscod = iscod and item_selling_price <= websiteCodLimit
348
                otgAvailable = otgAvailable and item_selling_price >= 2000
20275 amit.gupta 349
                if iscod:
350
                    return 1, iscod, otgAvailable
19533 manish.sha 351
        else:
352
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(46).get(destination_pin)
353
            if item_selling_price <= providerPrepaidLimit:
354
                iscod = iscod and item_selling_price <= websiteCodLimit
355
                otgAvailable = otgAvailable and item_selling_price >= 2000
20275 amit.gupta 356
                if iscod:
357
                    return 46, iscod, otgAvailable
8575 rajveer 358
 
19533 manish.sha 359
    if serviceable_location_cache.has_key(1) and serviceable_location_cache.get(1).has_key(destination_pin):
19476 manish.sha 360
        dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(1).get(destination_pin)
7627 rajveer 361
        if item_selling_price <= providerPrepaidLimit:
7608 rajveer 362
            iscod = iscod and item_selling_price <= websiteCodLimit
363
            otgAvailable = otgAvailable and item_selling_price >= 2000
20275 amit.gupta 364
            if iscod:
365
                return 1, iscod, otgAvailable
7981 rajveer 366
 
20275 amit.gupta 367
    if serviceable_location_cache.has_key(3) and serviceable_location_cache.get(3).has_key(destination_pin):
368
        dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(3).get(destination_pin)
369
        if item_selling_price <= providerPrepaidLimit:
370
            iscod = iscod and item_selling_price <= websiteCodLimit
371
            otgAvailable = otgAvailable and item_selling_price >= 2000
372
            return 3, iscod, otgAvailable
10185 amit.gupta 373
    return None, False, False    
5278 rajveer 374
 
6017 amar.kumar 375
def get_destination_code(providerId, pinCode):
376
    serviceableLocationDetail = ServiceableLocationDetails.query.filter_by(provider_id = providerId, dest_pincode = pinCode).one()
377
    return serviceableLocationDetail.dest_code
378
 
644 chandransh 379
def add_empty_AWBs(numbers, provider_id, type):
442 rajveer 380
    for number in numbers:
644 chandransh 381
        query = Awb.query.filter_by(awb_number = number, provider_id = provider_id)
444 rajveer 382
        try:
383
            query.one()
384
        except:    
644 chandransh 385
            awb = Awb()
444 rajveer 386
            awb.awb_number = number
644 chandransh 387
            awb.provider_id = provider_id
444 rajveer 388
            awb.is_available = True
644 chandransh 389
            awb.type = type
22636 amit.gupta 390
            awb.awbUsedFor = 2
644 chandransh 391
    session.commit()
442 rajveer 392
 
444 rajveer 393
def set_AWB_as_used(awb_number):
644 chandransh 394
    query = Awb.query.filter_by(awb_number = awb_number)
444 rajveer 395
    awb = query.one() 
396
    awb.is_available=False
397
    session.commit()
398
 
20924 kshitij.so 399
def get_awb(provider_id, logisticsTransactionId, type):
400
    query = Awb.query.with_lockmode("update").filter_by(provider_id = provider_id, is_available = True)  #check the provider thing
401
    if type == DeliveryType.PREPAID:
402
        query = query.filter_by(type="Prepaid")
403
    if type == DeliveryType.COD:
404
        query = query.filter_by(type="COD")
405
 
406
    additionalQuery = query
407
    query = query.filter_by(awbUsedFor=0)
408
 
409
    try:
23140 amit.gupta 410
        success = True
20924 kshitij.so 411
        awb = query.first()
412
        if awb is None:
413
            additionalQuery = additionalQuery.filter_by(awbUsedFor=2)
414
            awb = additionalQuery.first()
22749 amit.gupta 415
        print "-------", awb.awb_number, awb.is_available
20924 kshitij.so 416
        awb.is_available = False
23218 amit.gupta 417
        session.commit()
23220 amit.gupta 418
 
419
        return awb.awb_number
20924 kshitij.so 420
    except:
23140 amit.gupta 421
        traceback.print_exc()
22749 amit.gupta 422
        session.close()
20924 kshitij.so 423
        raise LogisticsServiceException(103, "Unable to get an AWB for the given Provider: " + str(provider_id))
20724 kshitij.so 424
 
425
def get_empty_AWB(provider_id, logisticsTransactionId):
442 rajveer 426
    try:
20724 kshitij.so 427
        if logisticsTransactionId is None:
428
            return ""
429
        if provider_id ==1:
23128 amit.gupta 430
            bluedartAttribute = BluedartAttribute.get_by(logisticsTransactionId=logisticsTransactionId,name="awb")
20745 kshitij.so 431
            if bluedartAttribute is None:
432
                client = TransactionClient().get_client()
433
                orders_list = client.getGroupOrdersByLogisticsTxnId(logisticsTransactionId)
434
                bluedartResponse = BluedartService.generate_awb(orders_list)
435
                bluedartAttribute = BluedartAttribute()
436
                bluedartAttribute.logisticsTransactionId = logisticsTransactionId
437
                bluedartAttribute.name = "awb"
438
                bluedartAttribute.value = bluedartResponse.awbNo
439
                bluedartAttribute_destcode = BluedartAttribute()
440
                bluedartAttribute_destcode.logisticsTransactionId = logisticsTransactionId
441
                bluedartAttribute_destcode.name = "destCode"
442
                bluedartAttribute_destcode.value = bluedartResponse.destArea +"/"+ bluedartResponse.destLocation
443
                session.commit()
444
            return bluedartAttribute.value
22636 amit.gupta 445
        else :
22750 amit.gupta 446
            client = TransactionClient().get_client()
447
            return get_awb(provider_id, logisticsTransactionId, DeliveryType.COD if client.isShipmentCod(logisticsTransactionId) else DeliveryType.PREPAID)
442 rajveer 448
    except:
20724 kshitij.so 449
        traceback.print_exc()
644 chandransh 450
        raise LogisticsServiceException(103, "Unable to get an AWB for the given Provider: " + str(provider_id))
20724 kshitij.so 451
 
1137 chandransh 452
 
3103 chandransh 453
def get_free_awb_count(provider_id, type):
454
    count = Awb.query.filter_by(provider_id = provider_id, is_available = True, type=type).count()
1137 chandransh 455
    if count == None:
456
        count = 0
457
    return count
442 rajveer 458
 
644 chandransh 459
def get_shipment_info(awb_number, provider_id):
460
    awb = Awb.get_by(awb_number = awb_number, provider_id = provider_id)
461
    query = AwbUpdate.query.filter_by(awb = awb)
766 rajveer 462
    info = query.all()
463
    return info
464
 
6643 rajveer 465
def store_shipment_info(update):
466
    updates = AwbUpdate.query.filter_by(providerId = update.providerId, awbNumber  = update.awbNumber, location = update.location, date = to_py_date(update.date), status = update.status, description = update.description).all()
467
    if not updates:
468
        dupdate = AwbUpdate()
469
        dupdate.providerId = update.providerId
470
        dupdate.awbNumber  = update.awbNumber
471
        dupdate.location = update.location
472
        dupdate.date = to_py_date(update.date)
473
        dupdate.status = update.status
474
        dupdate.description = update.description
475
        session.commit()
476
 
1730 ankur.sing 477
def get_holidays(start_date, end_date):
478
    query = PublicHolidays.query
479
    if start_date != -1:
480
        query = query.filter(PublicHolidays.date >= to_py_date(start_date))
481
    if end_date != -1:
482
        query = query.filter(PublicHolidays.date <= to_py_date(end_date))
483
    holidays = query.all()
484
    holiday_dates = [to_java_date(datetime.datetime(*time.strptime(str(holiday.date), '%Y-%m-%d')[:3])) for holiday in holidays] 
485
    return holiday_dates
486
 
5527 anupam.sin 487
def get_provider_for_pickup_type(pickUp):
488
    return Provider.query.filter(Provider.pickup == pickUp).first().id
489
 
766 rajveer 490
def close_session():
491
    if session.is_active:
492
        print "session is active. closing it."
2823 chandransh 493
        session.close()
3376 rajveer 494
 
495
def is_alive():
496
    try:
497
        session.query(Awb.id).limit(1).one()
498
        return True
499
    except:
5555 rajveer 500
        return False
501
 
502
def get_all_pickup_stores():
5572 anupam.sin 503
    pickupStores = PickupStore.query.all()
504
    return pickupStores
5555 rajveer 505
 
506
def get_pickup_store(storeId):
5719 rajveer 507
    return PickupStore.query.filter_by(id = storeId).one()
508
 
509
def get_pickup_store_by_hotspot_id(hotspotId):
510
    return PickupStore.query.filter_by(hotspotId = hotspotId).one()
6322 amar.kumar 511
 
6524 rajveer 512
def add_pincode(provider, pincode, destCode, exp, cod, stationType, otgAvailable):
7914 rajveer 513
    provider = Provider.query.filter_by(id = provider).one()
6322 amar.kumar 514
    serviceableLocationDetails = ServiceableLocationDetails()
515
    serviceableLocationDetails.provider = provider
516
    serviceableLocationDetails.dest_pincode = pincode
517
    serviceableLocationDetails.dest_code = destCode
518
    serviceableLocationDetails.exp = exp
519
    serviceableLocationDetails.cod = cod
520
    serviceableLocationDetails.station_type = stationType
6524 rajveer 521
    serviceableLocationDetails.otgAvailable = otgAvailable
7733 manish.sha 522
    if provider.id == 1:
7627 rajveer 523
        codlimit = 10000
524
        prepaidlimit = 50000
7733 manish.sha 525
    elif provider.id == 3:
7627 rajveer 526
        codlimit = 25000
527
        prepaidlimit = 100000
7733 manish.sha 528
    elif provider.id == 6:
7627 rajveer 529
        codlimit = 25000
530
        prepaidlimit = 100000
531
    serviceableLocationDetails.providerPrepaidLimit = prepaidlimit
532
    serviceableLocationDetails.providerCodLimit = codlimit
533
    serviceableLocationDetails.websiteCodLimit = codlimit
534
    serviceableLocationDetails.storeCodLimit = codlimit
6322 amar.kumar 535
    session.commit()
536
 
6524 rajveer 537
def update_pincode(providerId, pincode, exp, cod, otgAvailable):
6615 amar.kumar 538
    serviceableLocationDetails = ServiceableLocationDetails.get_by(provider_id = providerId, dest_pincode = pincode)
6322 amar.kumar 539
    serviceableLocationDetails.exp = exp
540
    serviceableLocationDetails.cod = cod
6524 rajveer 541
    serviceableLocationDetails.otgAvailable = otgAvailable
7256 rajveer 542
    session.commit()
7567 rajveer 543
 
13146 manish.sha 544
def add_new_awbs(provider_id, isCod, awbs, awbUsedFor):
7567 rajveer 545
    provider = get_provider(provider_id)
546
    if isCod:
547
        dtype = 'Cod'
548
    else:
549
        dtype = 'Prepaid'
550
    for awb in awbs:
551
        a = Awb()
552
        a.type =  dtype
553
        a.is_available = True
554
        a.awb_number = awb
13146 manish.sha 555
        a.awbUsedFor = awbUsedFor
7567 rajveer 556
        a.provider = provider 
557
    session.commit()
7608 rajveer 558
    return True
7256 rajveer 559
 
560
def adjust_delivery_time(start_time, delivery_days):
561
    '''
562
    Returns the actual no. of days which will pass while 'delivery_days'
563
    no. of business days will pass since 'order_time'. 
564
    '''
565
    start_date = start_time.date()
566
    end_date = start_date + datetime.timedelta(days = delivery_days)
7272 amit.gupta 567
    holidays = get_holidays(to_java_date(start_time), -1)
7256 rajveer 568
    holidays = [to_py_date(holiday).date() for holiday in holidays]
569
 
570
    while start_date <= end_date:
571
        if start_date.weekday() == 6 or start_date in holidays:
572
            delivery_days = delivery_days + 1
573
            end_date = end_date + datetime.timedelta(days = 1)
574
        start_date = start_date + datetime.timedelta(days = 1)
575
 
576
    return delivery_days
7275 rajveer 577
 
578
def get_min_advance_amount(itemId, destination_pin, providerId, codAllowed):
579
    client = CatalogClient().get_client()
580
    sp = client.getStorePricing(itemId)
581
 
582
    if codAllowed:
583
        return sp.minAdvancePrice, True
584
    else:
20275 amit.gupta 585
        dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit  = serviceable_location_cache.get(providerId).get(destination_pin)
7275 rajveer 586
        if iscod:
587
            if providerId == 6:
7489 rajveer 588
                return max(sp.minAdvancePrice, sp.recommendedPrice - storeCodLimit), True
7275 rajveer 589
            if providerId == 3:
7489 rajveer 590
                return max(sp.minAdvancePrice, sp.recommendedPrice - storeCodLimit), True
7275 rajveer 591
            if providerId == 1:
7489 rajveer 592
                return max(sp.minAdvancePrice, sp.recommendedPrice - storeCodLimit), True
7275 rajveer 593
        else:
7425 rajveer 594
            return sp.recommendedPrice, False
7733 manish.sha 595
#Start:- Added by Manish Sharma for Multiple Pincode Updation on 05-Jul-2013
596
 
23121 amit.gupta 597
def run_Logistics_Location_Info_Update(logisticsLocationInfoList, runCompleteUpdate, providerId):
7786 manish.sha 598
    if runCompleteUpdate == True :
23128 amit.gupta 599
        serviceableLocationDetails = ServiceableLocationDetails.query.filter_by(provider_id=providerId).all()
23132 amit.gupta 600
        provider = Provider.query.filter_by(id = providerId).one()
7786 manish.sha 601
        for serviceableLocationDetail in serviceableLocationDetails:
7841 manish.sha 602
            serviceableLocationDetail.exp = False
603
            serviceableLocationDetail.cod = False
7786 manish.sha 604
    for logisticsLocationInfo in logisticsLocationInfoList:
7841 manish.sha 605
        serviceableLocationDetail = ServiceableLocationDetails.get_by(provider_id = logisticsLocationInfo.providerId, dest_pincode = logisticsLocationInfo.pinCode)
23132 amit.gupta 606
        if provider is None:
607
            provider = Provider.query.filter_by(id = logisticsLocationInfo.providerId).one()
7841 manish.sha 608
        if serviceableLocationDetail:
609
            serviceableLocationDetail.exp = logisticsLocationInfo.expAvailable
610
            serviceableLocationDetail.cod = logisticsLocationInfo.codAvailable
611
            serviceableLocationDetail.otgAvailable = logisticsLocationInfo.otgAvailable
612
            serviceableLocationDetail.providerCodLimit = logisticsLocationInfo.codLimit
613
            serviceableLocationDetail.providerPrepaidLimit = logisticsLocationInfo.prepaidLimit
614
            serviceableLocationDetail.storeCodLimit = logisticsLocationInfo.codLimit
8219 manish.sha 615
            serviceableLocationDetail.websiteCodLimit = min(26000,logisticsLocationInfo.codLimit)
7841 manish.sha 616
        else:
617
            serviceableLocationDetail= ServiceableLocationDetails()
618
            serviceableLocationDetail.provider = provider
619
            serviceableLocationDetail.dest_pincode = logisticsLocationInfo.pinCode
620
            serviceableLocationDetail.dest_code = logisticsLocationInfo.destinationCode
621
            serviceableLocationDetail.exp = logisticsLocationInfo.expAvailable
622
            serviceableLocationDetail.cod = logisticsLocationInfo.codAvailable
623
            serviceableLocationDetail.station_type = 0
624
            serviceableLocationDetail.otgAvailable = logisticsLocationInfo.otgAvailable
625
            serviceableLocationDetail.providerCodLimit = logisticsLocationInfo.codLimit
626
            serviceableLocationDetail.providerPrepaidLimit = logisticsLocationInfo.prepaidLimit
627
            serviceableLocationDetail.storeCodLimit = logisticsLocationInfo.codLimit
8219 manish.sha 628
            serviceableLocationDetail.websiteCodLimit = min(26000,logisticsLocationInfo.codLimit)
7841 manish.sha 629
 
7870 rajveer 630
        deliveryEstimate = DeliveryEstimate.get_by(provider_id = logisticsLocationInfo.providerId, destination_pin = logisticsLocationInfo.pinCode, warehouse_location = logisticsLocationInfo.warehouseId) 
7841 manish.sha 631
        if deliveryEstimate:
632
            deliveryEstimate.warehouse_location= logisticsLocationInfo.warehouseId
633
            deliveryEstimate.delivery_time= logisticsLocationInfo.deliveryTime
634
            deliveryEstimate.delivery_delay= logisticsLocationInfo.delivery_delay
19421 manish.sha 635
            deliveryEstimate.providerZoneCode = logisticsLocationInfo.zoneCode
7841 manish.sha 636
        else:
637
            deliveryEstimate = DeliveryEstimate()
638
            deliveryEstimate.destination_pin= logisticsLocationInfo.pinCode
639
            deliveryEstimate.provider = provider
640
            deliveryEstimate.warehouse_location= logisticsLocationInfo.warehouseId
641
            deliveryEstimate.delivery_time= logisticsLocationInfo.deliveryTime
642
            deliveryEstimate.delivery_delay= logisticsLocationInfo.delivery_delay
19421 manish.sha 643
            deliveryEstimate.providerZoneCode = logisticsLocationInfo.zoneCode
7733 manish.sha 644
    session.commit()
7786 manish.sha 645
 
7733 manish.sha 646
#End:- Added by Manish Sharma for Multiple Pincode Updation on 05-Jul-2013             
7275 rajveer 647
 
12895 manish.sha 648
def get_first_delivery_estimate_for_wh_location(pincode, whLocation):
649
    delEstimate = DeliveryEstimate.query.filter(DeliveryEstimate.destination_pin == pincode).filter(DeliveryEstimate.warehouse_location == whLocation).first()
650
    if delEstimate is None:
651
        return -1
652
    else:
653
        return 1
13146 manish.sha 654
 
655
def get_provider_limit_details_for_pincode(provider, pincode):
656
    serviceAbleDetails = ServiceableLocationDetails.get_by(provider_id = provider, dest_pincode = pincode)
657
    returnDataMap = {}
658
    if serviceAbleDetails:
659
        returnDataMap["websiteCodLimit"] = str(serviceAbleDetails.websiteCodLimit)
19230 manish.sha 660
        returnDataMap["providerCodLimit"] = str(serviceAbleDetails.providerCodLimit)
13146 manish.sha 661
        returnDataMap["providerPrepaidLimit"] = str(serviceAbleDetails.providerPrepaidLimit)
662
 
663
    return returnDataMap
664
 
665
def get_new_empty_awb(providerId, type, orderQuantity):
666
    query = Awb.query.with_lockmode("update").filter_by(provider_id = providerId, is_available = True)  #check the provider thing
667
    if type == DeliveryType.PREPAID:
668
        query = query.filter_by(type="Prepaid")
669
    if type == DeliveryType.COD:
670
        query = query.filter_by(type="COD")
671
 
672
    additionalQuery = query
673
    if orderQuantity == 1:
674
        query = query.filter_by(awbUsedFor=0)
675
    if orderQuantity >1:
676
        query = query.filter_by(awbUsedFor=1) 
677
 
678
    try:
679
        awb = query.first()
680
        if awb is None:
681
            additionalQuery = additionalQuery.filter_by(awbUsedFor=2)
682
            awb = additionalQuery.first()
683
        awb.is_available = False
684
        session.commit()
685
        return awb.awb_number
686
    except:
687
        raise LogisticsServiceException(103, "Unable to get an AWB for the given Provider: " + str(providerId))
19421 manish.sha 688
 
19474 manish.sha 689
def get_costing_and_delivery_estimate_for_pincode(pincode, transactionAmount, isCod, weight, billingWarehouseId, isCompleteTxn):
690
    print pincode, transactionAmount, isCod, weight, billingWarehouseId
19421 manish.sha 691
    deliveryEstimate = {}
692
    logsiticsCosting = {}
693
    providerCostingMap = {}
694
    serviceability = {}
23135 amit.gupta 695
    providerList = list(PROVIDER_PRIORITY)
696
    #for now this part is disabled and only the same logistics partner is used as priority
23316 amit.gupta 697
    provider_id, cod = __get_provider(providerList, pincode, transactionAmount, weight, type, billingWarehouseId)
698
    providerIds = [provider_id]
23135 amit.gupta 699
    #for providerId in serviceable_location_cache.keys():
700
    for providerId in providerIds:
19421 manish.sha 701
        if serviceable_location_cache.has_key(providerId) and serviceable_location_cache.get(providerId).has_key(pincode):
19474 manish.sha 702
            dest_code, exp, iscod, otgAvailable, websiteCodLimit, storeCodLimit, providerPrepaidLimit, providerCodLimit = serviceable_location_cache.get(providerId).get(pincode)
19421 manish.sha 703
            if isCod and iscod:
19474 manish.sha 704
                if not isCompleteTxn:
705
                    if transactionAmount <= providerCodLimit:
706
                        serviceability[providerId] = serviceable_location_cache.get(providerId).get(pincode)
707
                    else:
708
                        continue
709
                else:
710
                    serviceability[providerId] = serviceable_location_cache.get(providerId).get(pincode)
19421 manish.sha 711
            elif isCod and not iscod:
712
                continue
713
            else:
19474 manish.sha 714
                if not isCompleteTxn:
715
                    if transactionAmount <= providerPrepaidLimit:
716
                        serviceability[providerId] = serviceable_location_cache.get(providerId).get(pincode)
717
                    else:
718
                        continue
719
                else:
720
                    serviceability[providerId] = serviceable_location_cache.get(providerId).get(pincode)
19421 manish.sha 721
 
722
    warehouse_location = warehouse_location_cache.get(billingWarehouseId)
723
    if warehouse_location is None:
724
        warehouse_location = 0
725
 
726
    noCostFoundCount = 0
727
    if len(serviceability)>0:
728
        for providerId, serviceableDetails in serviceability.items():
729
            delivery_time = delivery_estimate_cache[pincode, providerId, warehouse_location][0]
730
            delivery_delay = delivery_estimate_cache[pincode, providerId, warehouse_location][1]
731
            zoneCode = delivery_estimate_cache[pincode, providerId, warehouse_location][2]
732
            sla = delivery_time + delivery_delay
733
            if deliveryEstimate.has_key(sla):
734
                estimate = deliveryEstimate.get(sla)
735
                estimate.append(providerId)
736
                deliveryEstimate[sla] = estimate
737
            else:
738
                estimate = []
739
                estimate.append(providerId)
740
                deliveryEstimate[sla] = estimate
741
 
742
            logisticsCost = 0
743
            codCollectionCharges = 0    
744
            logisticsCostObj = None 
745
            if provider_costing_sheet.has_key(providerId) and provider_costing_sheet.get(providerId).has_key(zoneCode):
746
                logisticsCostObj = provider_costing_sheet.get(providerId).get(zoneCode)
747
                logisticsCost = logisticsCostObj.initialLogisticsCost
748
                if weight > logisticsCostObj.initialWeightUpperLimit:
749
                    additionalWeight = weight-logisticsCostObj.initialWeightUpperLimit
19663 manish.sha 750
                    additionalWeight = round(additionalWeight,0)
19483 manish.sha 751
                    additionalCostMultiplier = math.ceil(additionalWeight/logisticsCostObj.additionalUnitWeight)
19421 manish.sha 752
                    additionalCost = additionalCostMultiplier*logisticsCostObj.additionalUnitLogisticsCost
753
                    logisticsCost = logisticsCost + additionalCost
754
                if isCod:
755
                    if logisticsCostObj.codCollectionFactor:
19474 manish.sha 756
                        codCollectionCharges = max(logisticsCostObj.minimumCodCollectionCharges, (transactionAmount*logisticsCostObj.codCollectionFactor)/100)
757
                        logisticsCost = logisticsCost + max(logisticsCostObj.minimumCodCollectionCharges, (transactionAmount*logisticsCostObj.codCollectionFactor)/100)
19421 manish.sha 758
                    else:
759
                        codCollectionCharges = logisticsCostObj.minimumCodCollectionCharges
760
                        logisticsCost = logisticsCost + logisticsCostObj.minimumCodCollectionCharges
761
 
19474 manish.sha 762
                if logsiticsCosting.has_key(round(logisticsCost,0)):
763
                    costingList = logsiticsCosting.get(round(logisticsCost,0))
19421 manish.sha 764
                    costingList.append(providerId)
19474 manish.sha 765
                    logsiticsCosting[round(logisticsCost,0)] = costingList
19421 manish.sha 766
                else:
767
                    costingList = []
768
                    costingList.append(providerId)
19474 manish.sha 769
                    logsiticsCosting[round(logisticsCost,0)] = costingList                    
19421 manish.sha 770
 
771
                providerCostingMap[providerId] = [logisticsCost,codCollectionCharges]
772
            else:
773
                noCostFoundCount = noCostFoundCount +1
774
                continue
775
    else:
19474 manish.sha 776
        print "No provider assigned for pincode: " + str(pincode)
19535 manish.sha 777
        raise LogisticsServiceException(103, "Unable to get Provider for given pincode: " + str(pincode)+" Amount:- "+str(transactionAmount)+" Weight:- "+ str(weight))
19421 manish.sha 778
 
779
 
780
    if noCostFoundCount == len(serviceability):
19474 manish.sha 781
        print "No Costing Found for this pincode: " + str(pincode) +" for any of the provider"
19535 manish.sha 782
        raise LogisticsServiceException(103, "Unable to get Provider for given pincode: " + str(pincode)+" Amount:- "+str(transactionAmount)+" Weight:- "+ str(weight)+". Due to no costing found")
19421 manish.sha 783
 
784
    allSla = sorted(deliveryEstimate.keys())
785
    if len(allSla)==1:
786
        allEligibleProviders = deliveryEstimate.get(allSla[0])
787
        if len(allEligibleProviders)==1:
19474 manish.sha 788
            try:
19421 manish.sha 789
                costingDetails = providerCostingMap.get(allEligibleProviders[0])
790
                delEstCostObj = DeliveryEstimateAndCosting()
791
                delEstCostObj.logistics_provider_id = allEligibleProviders[0]
792
                delEstCostObj.pincode = pincode
793
                delEstCostObj.deliveryTime = delivery_estimate_cache[pincode, allEligibleProviders[0], warehouse_location][0]
794
                delEstCostObj.delivery_delay = delivery_estimate_cache[pincode, allEligibleProviders[0], warehouse_location][1]
795
                delEstCostObj.codAllowed = serviceability[allEligibleProviders[0]][2]
796
                delEstCostObj.otgAvailable = serviceability[allEligibleProviders[0]][3]
797
                delEstCostObj.logisticsCost = costingDetails[0]-costingDetails[1]
798
                delEstCostObj.codCollectionCharges = costingDetails[1]
799
                return delEstCostObj
19474 manish.sha 800
            except:
19535 manish.sha 801
                raise LogisticsServiceException(103, "Unable to get Provider for given pincode: " + str(pincode)+" Amount:- "+str(transactionAmount)+" Weight:- "+ str(weight)+".")
19421 manish.sha 802
        else:
803
            costingListOrder = []
804
            for providerId in allEligibleProviders:
19474 manish.sha 805
                costingDetails = providerCostingMap.get(providerId)
806
                if costingDetails and costingDetails[0] not in costingListOrder:
807
                    costingListOrder.append(round(costingDetails[0],0))
808
 
809
            costingListOrder = sorted(costingListOrder)
810
            eligibleProviders = logsiticsCosting.get(costingListOrder[0])
811
            for providerId in eligibleProviders:
812
                if providerCostingMap.has_key(providerId):
813
                    costingDetails = providerCostingMap.get(providerId)
19421 manish.sha 814
                    delEstCostObj = DeliveryEstimateAndCosting()
19474 manish.sha 815
                    delEstCostObj.logistics_provider_id = providerId
19421 manish.sha 816
                    delEstCostObj.pincode = pincode
19474 manish.sha 817
                    delEstCostObj.deliveryTime = delivery_estimate_cache[pincode, providerId, warehouse_location][0]
818
                    delEstCostObj.delivery_delay = delivery_estimate_cache[pincode, providerId, warehouse_location][1]
819
                    delEstCostObj.codAllowed = serviceability[providerId][2]
820
                    delEstCostObj.otgAvailable = serviceability[providerId][3]
19421 manish.sha 821
                    delEstCostObj.logisticsCost = costingDetails[0]-costingDetails[1]
822
                    delEstCostObj.codCollectionCharges = costingDetails[1]
823
                    return delEstCostObj
19474 manish.sha 824
                else:
825
                    continue
19535 manish.sha 826
            raise LogisticsServiceException(103, "Unable to get Provider for given pincode: " + str(pincode)+" Amount:- "+str(transactionAmount)+" Weight:- "+ str(weight)+".")
19474 manish.sha 827
    else:
828
        allEligibleProviders = []
829
        virtualDelayCostMap = {}
830
        virtualCommercialsCostMap = {} 
831
        for sla in allSla:
832
            if sla-allSla[0]<=1:
833
                consideredProviders = deliveryEstimate.get(sla)
834
                for providerId in consideredProviders:
835
                    if isCod and providerId in [7,46]:
836
                        virtualCommercialsCostMap[providerId] = 10
837
                    if providerId not in allEligibleProviders:
838
                        allEligibleProviders.append(providerId)
839
                    virtualDelayCostMap[providerId] = 0
840
            elif sla-allSla[0]==2:
841
                consideredProviders = deliveryEstimate.get(sla)
842
                for providerId in consideredProviders:
843
                    if isCod and providerId in [7,46]:
844
                        virtualCommercialsCostMap[providerId] = 10
845
                    if providerId not in allEligibleProviders:
846
                        allEligibleProviders.append(providerId)
847
                    virtualDelayCostMap[providerId] = 20+round((0.3*transactionAmount)/100,0)
848
            elif sla-allSla[0]==3:
849
                consideredProviders = deliveryEstimate.get(sla)
850
                for providerId in consideredProviders:
851
                    if isCod and providerId in [7,46]:
852
                        virtualCommercialsCostMap[providerId] = 10
853
                    if providerId not in allEligibleProviders:
854
                        allEligibleProviders.append(providerId)
855
                    virtualDelayCostMap[providerId] = 40+round((0.6*transactionAmount)/100,0)
856
 
857
        costingListOrder = []
858
        costingListMap = {}
859
        for providerId in allEligibleProviders:
860
            costingDetails = providerCostingMap.get(providerId)
861
            if costingDetails:
862
                cost = round(costingDetails[0],0)
863
                if virtualDelayCostMap.has_key(providerId):
864
                    cost = cost + virtualDelayCostMap.get(providerId)
865
                if virtualCommercialsCostMap.has_key(providerId):
866
                    cost = cost + virtualCommercialsCostMap.get(providerId)
867
                if costingListMap.has_key(cost):
868
                    providers = costingListMap.get(cost)
869
                    providers.append(providerId)                       
870
                    costingListMap[cost] = providers 
871
                else:
872
                    providers = []
873
                    providers.append(providerId)                       
874
                    costingListMap[cost] = providers  
875
                if cost not in costingListOrder:
876
                    costingListOrder.append(cost)
877
 
878
        costingListOrder = sorted(costingListOrder)
879
 
880
        print costingListMap
881
        eligibleProviders = costingListMap.get(costingListOrder[0])
882
        for providerId in eligibleProviders:
883
            if providerCostingMap.has_key(providerId):
884
                costingDetails = providerCostingMap.get(providerId)
19421 manish.sha 885
                delEstCostObj = DeliveryEstimateAndCosting()
19474 manish.sha 886
                delEstCostObj.logistics_provider_id = providerId
19421 manish.sha 887
                delEstCostObj.pincode = pincode
19474 manish.sha 888
                delEstCostObj.deliveryTime = delivery_estimate_cache[pincode, providerId, warehouse_location][0]
889
                delEstCostObj.delivery_delay = delivery_estimate_cache[pincode, providerId, warehouse_location][1]
890
                delEstCostObj.codAllowed = serviceability[providerId][2]
891
                delEstCostObj.otgAvailable = serviceability[providerId][3]
19421 manish.sha 892
                delEstCostObj.logisticsCost = costingDetails[0]-costingDetails[1]
893
                delEstCostObj.codCollectionCharges = costingDetails[1]
894
                return delEstCostObj
19474 manish.sha 895
            else:
896
                continue
20745 kshitij.so 897
        raise LogisticsServiceException(103, "Unable to get Provider for given pincode: " + str(pincode)+" Amount:- "+str(transactionAmount)+" Weight:- "+ str(weight)+".")
898
 
899
def get_bluedart_attributes_for_logistics_txn_id(logisticsTxnId, name):
900
    bluedartAttr =  BluedartAttribute.get_by(logisticsTransactionId=logisticsTxnId,name=name)
901
    if bluedartAttr is None:
902
        raise LogisticsServiceException(103, "Unable to get bluedart attributes for logisticsTxnId "+logisticsTxnId+" and name "+name)
903
    return bluedartAttr