Subversion Repositories SmartDukaan

Rev

Rev 19973 | Rev 19977 | 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
'''
6594 anupam.sin 6
from MySQLdb.constants.FLAG import AUTO_INCREMENT
4501 mandeep.dh 7
from elixir import metadata, setup_all
104 ashish 8
from elixir.entity import Entity
9
from elixir.fields import Field
4501 mandeep.dh 10
from elixir.options import using_options, using_table_options
11
from elixir.relationships import ManyToOne, OneToMany
12
from sqlalchemy.engine import create_engine
6594 anupam.sin 13
from sqlalchemy.types import Integer, String, Float, DateTime, Boolean, Enum, \
18585 amit.gupta 14
    Numeric, BigInteger, LargeBinary, Date
15
import datetime
104 ashish 16
 
17
#===============================================================================
18
# Different entities in the model
19
#===============================================================================
20
 
19235 manish.sha 21
def initialize(dbname='transaction', db_hostname="localhost", echoOn=True, setup=True):
746 rajveer 22
    #metadata.bind = "sqlite:///Transactionsnew.sqlite"
1122 chandransh 23
    #metadata.bind = 'mysql://root:shop2020@localhost/transaction'
3187 rajveer 24
    engine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200)
1122 chandransh 25
    metadata.bind = engine
1911 chandransh 26
    metadata.bind.echo = echoOn
19235 manish.sha 27
    setup_all(setup)
483 rajveer 28
 
29
 
30
if __name__=="__main__":
31
    initialize()
2783 chandransh 32
 
33
class InvoiceIDGenerator(Entity):
5527 anupam.sin 34
    id = Field(Integer)
5528 anupam.sin 35
    orderType = Field(Integer, primary_key = True)
2783 chandransh 36
    using_options(shortnames=True)
37
    using_table_options(mysql_engine="InnoDB")   
483 rajveer 38
 
12772 manish.sha 39
class InvoiceCounterGenerator(Entity):
40
    id = Field(Integer)
19950 amit.gupta 41
    companyId = Field(Integer, primary_key = True)
12772 manish.sha 42
    orderType = Field(Integer, primary_key = True)
43
    stateId = Field(Integer, primary_key = True)
12775 manish.sha 44
    prefix = Field(String(20))
12772 manish.sha 45
    using_options(shortnames=True)
46
    using_table_options(mysql_engine="InnoDB")
47
 
5508 rajveer 48
class RechargeVoucherTracker(Entity):
49
    order = ManyToOne("Order")
50
    voucherType = Field(Integer)
51
    amount = Field(Integer)
52
    voucherIssued = Field(Boolean)
53
    voucherCode = Field(String(30))
54
    issuedOn = Field(DateTime)
55
    using_options(shortnames=True)
56
    using_table_options(mysql_engine="InnoDB")
14134 amit.gupta 57
 
58
class DtrBatchCreditTracker(Entity):
59
    id=Field(Integer, primary_key = True)
60
    amount = Field(Integer)
61
    creditedOn = Field(DateTime)
62
    using_options(shortnames=True)
63
    using_table_options(mysql_engine="InnoDB")
5508 rajveer 64
 
483 rajveer 65
class LineItem(Entity):
66
    id = Field(Integer, primary_key=True, autoincrement=True)
699 chandransh 67
    item_id = Field(Integer)
963 chandransh 68
    productGroup = Field(String(100))
69
    brand = Field(String(100))
18707 manish.sha 70
    model_number = Field(String(100))
71
    model_name = Field(String(100))
669 chandransh 72
    color = Field(String(20))
483 rajveer 73
    extra_info = Field(String(100))
74
    quantity = Field(Float)
12280 amit.gupta 75
    mrp = Field(Float)
483 rajveer 76
    unit_price = Field(Float)
77
    unit_weight = Field(Float)
78
    total_price = Field(Float)
996 varun.gupt 79
    transfer_price = Field(Float)
6751 amar.kumar 80
    nlc = Field(Float)
483 rajveer 81
    total_weight = Field(Float)
2783 chandransh 82
    item_number = Field(String(50))
12653 manish.sha 83
    serial_number = Field(String(8192)) 
4172 rajveer 84
    dealText = Field(String(100))
4295 varun.gupt 85
    warranty_expiry_timestamp = Field(DateTime)
483 rajveer 86
    order = ManyToOne("Order")
6039 amit.gupta 87
    vatRate = Field(Float)
19421 manish.sha 88
    logisticsCost = Field(Float, default=0, server_default="0")
89
    codCollectionCharges = Field(Float, default=0, server_default="0")
19691 manish.sha 90
    returnQty = Field(Float, default=0, server_default="0")
19714 manish.sha 91
    damaged_expiry_timestamp = Field(DateTime)
746 rajveer 92
    using_options(shortnames=True)
93
    using_table_options(mysql_engine="InnoDB")
94
 
1276 chandransh 95
    def __repr__(self):
96
        return "{0} {1} {2} {3}".format(self.brand or "", self.model_name or "", self.model_number or "", self.color or "")
97
 
483 rajveer 98
class Order(Entity):
99
    id = Field(Integer, primary_key=True, autoincrement=True)
100
    warehouse_id = Field(Integer)
101
    logistics_provider_id = Field(Integer)
102
    airwaybill_no = Field(String(50))
103
    tracking_id = Field(String(50))
104
    expected_delivery_time = Field(DateTime)
3986 chandransh 105
    promised_delivery_time = Field(DateTime)
4004 chandransh 106
    expected_shipping_time = Field(DateTime)
4102 chandransh 107
    promised_shipping_time = Field(DateTime)
6726 rajveer 108
    courier_delivery_time = Field(DateTime)
483 rajveer 109
    customer_id = Field(Integer)
110
    customer_name = Field(String(50))
111
    customer_mobilenumber = Field(String(20))
112
    customer_pincode = Field(String(10))
738 chandransh 113
    customer_address1 = Field(String(100))
114
    customer_address2 = Field(String(100))
669 chandransh 115
    customer_city = Field(String(100))
116
    customer_state = Field(String(100))
483 rajveer 117
    customer_email = Field(String(50))
118
    status = Field(Integer)
119
    statusDescription = Field(String(50))
120
    total_amount = Field(Float)
6318 rajveer 121
    gvAmount = Field(Float)
483 rajveer 122
    total_weight = Field(Float)
123
    invoice_number = Field(String(30))
124
    billed_by = Field(String(30))
125
    created_timestamp = Field(DateTime)
126
    accepted_timestamp = Field(DateTime)
127
    billing_timestamp = Field(DateTime)
128
    shipping_timestamp = Field(DateTime)
1113 chandransh 129
    pickup_timestamp = Field(DateTime)
483 rajveer 130
    delivery_timestamp = Field(DateTime)
1208 chandransh 131
    outofstock_timestamp = Field(DateTime)
483 rajveer 132
    lineitems = OneToMany("LineItem")
133
    transaction = ManyToOne("Transaction")
6903 anupam.sin 134
    insuranceDetails = OneToMany("InsuranceDetailForOrder")
9575 kshitij.so 135
    dataInsuranceDetails = OneToMany("DataInsuranceDetailForOrder")
642 chandransh 136
    jacket_number = Field(Integer)
1132 chandransh 137
    receiver = Field(String(50))
1220 chandransh 138
    batchNo = Field(Integer)
139
    serialNo = Field(Integer)
2536 chandransh 140
    doaFlag = Field(Boolean)
141
    pickupRequestNo = Field(String(20))
2764 chandransh 142
    doa_auth_timestamp = Field(DateTime)
143
    doa_pickup_timestamp = Field(DateTime)
144
    received_return_timestamp = Field(DateTime)
145
    reship_timestamp = Field(DateTime)
146
    refund_timestamp = Field(DateTime)
2628 chandransh 147
    new_order_id = Field(Integer)
2819 chandransh 148
    purchase_order_id = Field(Integer)
3064 chandransh 149
    cod = Field(Boolean)
3226 chandransh 150
    refunded_by = Field(String(30))
5141 anupam.sin 151
    refund_reason = Field(String(256))
3064 chandransh 152
    verification_timestamp = Field(DateTime)
3581 chandransh 153
    delay_reason = Field(Enum('INVENTORY_LOW_PHASED_OUT', 'INVENTORY_LOW_COLOR_NOT_AVAILABLE',\
154
                              'INVENTORY_LOW_REVERSAL_NOT_ON_TIME', 'INVENTORY_LOW_PRODUCT_NOT_SEALED',\
155
                              'COURIER_DELAY_NOT_DELIVERED_TO_COURIER_ON_TIME', 'COURIER_DELAY_DID_NOT_CONNECT',\
156
                              'COURIER_DELAY_CUSTOMER_NOT_AVAILABLE', 'COURIER_DELAY_INCORRECT_ADDRESS',\
157
                              'COURIER_DELAY_OCTROI_DELAY', 'COURIER_DELAY_FORCES_OF_NATURE',\
158
                              'COD_VERIFICATION_DELAY', 'PAYMENT_FLAGGED', 'OTHERS'))
3956 chandransh 159
    cod_reconciliation_timestamp = Field(DateTime)
4247 rajveer 160
    previousStatus = Field(Integer)
4269 anupam.sin 161
    vendorId = Field(Integer)
5302 rajveer 162
    delayReasonText= Field(String(250))
4815 phani.kuma 163
    doa_logistics_provider_id = Field(Integer)
4910 phani.kuma 164
    local_connected_timestamp = Field(DateTime)
165
    reached_destination_timestamp = Field(DateTime)
166
    first_dlvyatmp_timestamp = Field(DateTime)
4303 rajveer 167
    orderInventory = OneToMany("OrderInventory")
5386 phani.kuma 168
    vendor_paid = Field(Boolean, default=0, server_default="0")
5062 varun.gupt 169
    originalOrderId = Field(Integer)
5110 mandeep.dh 170
    fulfilmentWarehouseId = Field(Integer)
5527 anupam.sin 171
    orderType = Field(Integer)
5720 rajveer 172
    pickupStoreId = Field(Integer, default=0, server_default="0")
6525 rajveer 173
    otg = Field(Boolean, default=0, server_default="0")
7033 anupam.sin 174
    insurer = Field(Integer, default=0, server_default="0")
175
    insuranceAmount = Field(Float, default=0, server_default="0")
7190 amar.kumar 176
    freebieItemId = Field(Integer, default=0, server_default="0")
7564 rajveer 177
    source = Field(Integer, default=1, server_default="1")
7293 anupam.sin 178
    storeId = Field(Integer, default=0, server_default="0")
7549 rajveer 179
    advanceAmount = Field(Float, default=0, server_default="0")
8717 amar.kumar 180
    productCondition = Field(Integer, default=0, server_default="0")
9299 kshitij.so 181
    dataProtectionInsurer = Field(Integer, default=0, server_default="0")
182
    dataProtectionAmount = Field(Float, default=0, server_default="0")
9416 amar.kumar 183
    taxType = Field(Integer, default=0, server_default="0")
13146 manish.sha 184
    logisticsTransactionId = Field(String(100))
17488 manish.sha 185
    shippingCost = Field(Float, default=0, server_default="0")
186
    codCharges = Field(Float, default=0, server_default="0")
19973 amit.gupta 187
    seller_id = Field(Integer)
2628 chandransh 188
    using_options(shortnames=True)
189
    using_table_options(mysql_engine="InnoDB")
5348 anupam.sin 190
 
191
class CodVerificationAgent(Entity):
192
    orderId = Field(Integer, primary_key=True, autoincrement=True)
193
    verificationAgent = Field(String(200))
194
    using_options(shortnames=True)
195
    using_table_options(mysql_engine="InnoDB")
196
 
104 ashish 197
class Transaction(Entity):
483 rajveer 198
    id = Field(Integer, primary_key=True, autoincrement=True)
199
    createdOn = Field(DateTime)
200
    status = Field(Integer)
201
    status_message = Field(String(100))
202
    customer_id = Field(Integer)
203
    shopping_cart_id = Field(Integer)
2815 vikas 204
    session_source = Field(String(100))
205
    session_start_time = Field(DateTime)
3858 vikas 206
    first_source = Field(String(100))
207
    first_source_start_time = Field(DateTime)
483 rajveer 208
    orders = OneToMany("Order")
2219 varun.gupt 209
    coupon_code = Field(String(20))
17488 manish.sha 210
    totalShippingCost = Field(Float, default=0, server_default="0")
211
    totalCodCharges = Field(Float, default=0, server_default="0")
18586 manish.sha 212
    payment_option = Field(Integer)
746 rajveer 213
    using_options(shortnames=True)
214
    using_table_options(mysql_engine="InnoDB")
132 ashish 215
 
4394 rajveer 216
class Alert(Entity):
132 ashish 217
    id = Field(Integer, primary_key=True, autoincrement=True)
483 rajveer 218
    type = Field(Integer)
4394 rajveer 219
    status = Field(Integer)
220
    timestamp = Field(DateTime)
221
    description = Field(String(100))
4444 rajveer 222
    warehouseId = Field(Integer)
746 rajveer 223
    using_options(shortnames=True)
1225 chandransh 224
    using_table_options(mysql_engine="InnoDB")
225
 
226
class BatchNoGenerator(Entity):
227
    id=Field(Integer, primary_key=True)
228
    using_options(shortnames=True)
229
    using_table_options(mysql_engine="InnoDB")
4008 mandeep.dh 230
 
231
class TransactionRequiringExtraProcessing(Entity):
4015 mandeep.dh 232
    transaction_id = Field(Integer, primary_key=True, autoincrement=False)
6733 anupam.sin 233
    category = Field(Enum('COD_VERIFICATION', 'DELAYED_DELIVERY', 'PAYMENT_FLAGGED', 'RECHARGE_UNKNOWN'), primary_key=True, autoincrement=False)
4008 mandeep.dh 234
    using_options(shortnames=True)
235
    using_table_options(mysql_engine="InnoDB")
4303 rajveer 236
 
237
class OrderInventory(Entity):
238
    order = ManyToOne("Order", primary_key=True)
239
    itemId = Field(Integer)
240
    timestamp = Field(DateTime)
241
    hotspotAction = Field(Integer)
242
    estimate = Field(Integer)
243
    using_options(shortnames=True)
244
    using_table_options(mysql_engine="InnoDB")
4600 varun.gupt 245
 
246
class EBSSettlementSummary(Entity):
247
    settlementId = Field(Integer, primary_key = True)
248
    settlementDate = Field(DateTime)
249
    transactionDateFrom = Field(DateTime)
250
    transactionDateTo = Field(DateTime)
5389 phani.kuma 251
    amount = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 252
    detailsUploaded = Field(Boolean)
253
    using_options(shortnames=True)
254
    using_table_options(mysql_engine="InnoDB")
4905 varun.gupt 255
 
4600 varun.gupt 256
class PaymentSettlement(Entity):
4905 varun.gupt 257
    referenceId = Field(Integer)    #PaymentID in case of prepaid & Order Id in case of COD
5386 phani.kuma 258
    originalOrderId = Field(Integer)    #originalOrderId in case of prepaid is NULL & Order Id of original Order or Order Id in case of COD
4600 varun.gupt 259
    paymentGatewayId = Field(Integer)
260
    settlementDate = Field(DateTime)
5389 phani.kuma 261
    serviceTax = Field(Numeric(precision=11, scale=3, asdecimal=False))
262
    otherCharges = Field(Numeric(precision=11, scale=3, asdecimal=False))
263
    netCollection = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 264
    using_options(shortnames=True)
5527 anupam.sin 265
    using_table_options(mysql_engine="InnoDB")
266
 
267
class Attribute(Entity):
268
    orderId = Field(Integer)
269
    name = Field(String(100))
270
    value = Field(String(100))
271
    using_options(shortnames=True)
6389 rajveer 272
    using_table_options(mysql_engine="InnoDB")
273
 
274
 
275
class EmiScheme(Entity):
276
    id  = Field(Integer, primary_key=True)
277
    gatewayId  = Field(Integer)
278
    bankId = Field(Integer)
279
    tenure = Field(Integer)
6396 amit.gupta 280
    bankName = Field(String(256))
281
    tenureDescription = Field(String(256))
6389 rajveer 282
    minAmount = Field(Integer)
283
    chargeType = Field(Integer)
6409 rajveer 284
    chargeValue = Field(Float)
8942 rajveer 285
    interestRate = Field(Float)
6389 rajveer 286
    using_options(shortnames=True)
287
    using_table_options(mysql_engine="InnoDB")
288
 
289
class MiscCharges(Entity):
290
    transaction = ManyToOne("Transaction", primary_key=True)
6396 amit.gupta 291
    chargeType = Field(Integer, primary_key=True, autoincrement=False)
6389 rajveer 292
    chargeAmount = Field(Float)
293
    using_options(shortnames=True)
6580 anupam.sin 294
    using_table_options(mysql_engine="InnoDB")
295
 
6591 anupam.sin 296
class BlockedIpRange(Entity):
6580 anupam.sin 297
    id = Field(Integer, primary_key=True, autoincrement=True)
6594 anupam.sin 298
    start = Field(BigInteger)
299
    end = Field(BigInteger)
6591 anupam.sin 300
    expiredOn = Field(DateTime)
6580 anupam.sin 301
    using_options(shortnames=True)
6591 anupam.sin 302
    using_table_options(mysql_engine="InnoDB")
303
 
304
class DeniedIpAddress(Entity):
305
    id = Field(Integer, primary_key=True, autoincrement=True)
306
    ip = Field(String(256))
307
    deniedOn = Field(DateTime)
308
    rechargeType = Field(Integer)
309
    deviceNumber = Field(String(128))
310
    using_options(shortnames=True)
6903 anupam.sin 311
    using_table_options(mysql_engine="InnoDB")
312
 
313
class InsuranceDetailForOrder(Entity):
314
    id = Field(Integer, primary_key=True, autoincrement=True)
315
    dob = Field(String(64))
316
    guardianName = Field(String(255))
317
    startDate = Field(DateTime)
318
    expiryDate = Field(DateTime)
6915 anupam.sin 319
    isDeclared = Field(Boolean, default=0)
6903 anupam.sin 320
    order = ManyToOne("Order")
321
    using_options(shortnames=True)
6906 rajveer 322
    using_table_options(mysql_engine="InnoDB")
323
 
6915 anupam.sin 324
    def __init__(self):
325
        self.isDeclared = 0
326
 
9575 kshitij.so 327
class DataInsuranceDetailForOrder(Entity):
328
    id = Field(Integer, primary_key=True, autoincrement=True)
329
    startDate = Field(DateTime)
330
    expiryDate = Field(DateTime)
9608 kshitij.so 331
    isDeclared = Field(Boolean, default=0, server_default="0")
9575 kshitij.so 332
    order = ManyToOne("Order")
333
    using_options(shortnames=True)
334
    using_table_options(mysql_engine="InnoDB")
335
 
6906 rajveer 336
class DocumentStore(Entity):
337
    docType = Field(Integer, primary_key=True, autoincrement=False)
338
    docSource = Field(Integer, primary_key=True, autoincrement=False)
339
    document  = Field(LargeBinary)
340
    using_options(shortnames=True)
7073 anupam.sin 341
    using_table_options(mysql_engine="InnoDB")
342
 
343
class Company(Entity):
344
    id = Field(Integer, primary_key=True, autoincrement=True)
345
    name = Field(String(255))
346
    Address = Field(String(255))
347
    using_options(shortnames=True)
348
    using_table_options(mysql_engine="InnoDB")
349
 
19973 amit.gupta 350
 
351
class Organisation(Entity):
352
    id = Field(Integer, primary_key=True, autoincrement=True)
353
    name = Field(String(255))
354
    address = Field(String(255))
355
    type = Field(Enum('company'), default='company')
356
    registered_id = Field(String(127))
357
    using_options(shortnames=True)
358
    using_table_options(mysql_engine="InnoDB")
359
 
360
class Seller(Entity):
361
    id = Field(Integer, primary_key=True, autoincrement=True)
362
    organisation_id = Field(Integer)
363
    state_id = Field(Integer)
364
    tin = Field(String(15))
19975 amit.gupta 365
    address = Field(String(255))
19973 amit.gupta 366
    using_options(shortnames=True)
367
    using_table_options(mysql_engine="InnoDB")
368
 
369
class SellerWarehouse(Entity):
370
    id = Field(Integer, default=0)
371
    seller_id = Field(Integer, primary_key=True)
372
    warehouse_id = Field(Integer, primary_key=True)
373
    orderType = Field(Integer, primary_key = True)
374
    prefix = Field(String)
375
    created_on = Field(String)
376
    is_active = Field(Boolean)
377
    using_options(shortnames=True)
378
    using_table_options(mysql_engine="InnoDB")
379
 
380
 
7073 anupam.sin 381
class WalletForCompany(Entity):
382
    id = Field(Integer, primary_key=True, autoincrement=True)
383
    companyId = Field(Integer)
7102 rajveer 384
    amount = Field(Integer)
7073 anupam.sin 385
    using_options(shortnames=True)
386
    using_table_options(mysql_engine="InnoDB")
387
 
388
class WalletHistoryForCompany(Entity):
389
    id = Field(Integer, primary_key=True, autoincrement=True)
390
    walletId = Field(Integer)
7102 rajveer 391
    amount = Field(Integer)
7073 anupam.sin 392
    transactionTime = Field(DateTime)
7102 rajveer 393
    openingBal = Field(Integer)
394
    closingBal = Field(Integer)
7073 anupam.sin 395
    referenceNumber = Field(Integer)
396
    description = Field(String(255))
397
    using_options(shortnames=True)
398
    using_table_options(mysql_engine="InnoDB")
399
 
400
class RechargeTransaction(Entity):
401
    id = Field(Integer, primary_key=True, autoincrement=True)
402
    storeId = Field(Integer)
7102 rajveer 403
    amount = Field(Integer)
7073 anupam.sin 404
    transactionTime = Field(DateTime)
7075 rajveer 405
    responseTime = Field(DateTime)
406
    description = Field(String(255))
407
    spiceTID = Field(String(255))
7369 rajveer 408
    aggTID = Field(String(255))
409
    providerTID = Field(String(255))
7075 rajveer 410
    plan = Field(String(255))
7073 anupam.sin 411
    deviceNum = Field(String(64))
412
    deviceType = Field(Integer)
413
    isFrc = Field(Boolean)
414
    email = Field(String(255))
7102 rajveer 415
    discount = Field(Integer)
416
    paymentAmount = Field(Integer)
7145 rajveer 417
    payMethod = Field(Integer, default=0, server_default="0")
7073 anupam.sin 418
    status = Field(Integer)
419
    invoiceNumber = Field(Integer)
420
    circleId = Field(Integer)
7075 rajveer 421
    operatorId = Field(Integer)
7073 anupam.sin 422
    name = Field(String(255))
423
    simNum = Field(String(255))
424
    cafNum = Field(String(255))
7080 anupam.sin 425
    ipAddress = Field(String(255))
426
    alternateNumber = Field(String(255))
7073 anupam.sin 427
    using_options(shortnames=True)
7075 rajveer 428
    using_table_options(mysql_engine="InnoDB")
7076 rajveer 429
 
7120 rajveer 430
class OperatorSeries(Entity):
431
    series = Field(Integer, primary_key=True, autoincrement=False)
432
    operatorId = Field(Integer)
433
    circleId = Field(Integer)
434
    using_options(shortnames=True)
435
    using_table_options(mysql_engine="InnoDB")
436
 
7076 rajveer 437
class FRC(Entity):
438
    id = Field(Integer, primary_key=True)
439
    operatorId = Field(Integer)
440
    circleId = Field(Integer)
441
    denomination = Field(Integer)
442
    maxDiscount = Field(Integer)
443
    using_options(shortnames=True)
444
    using_table_options(mysql_engine="InnoDB")
7120 rajveer 445
 
7075 rajveer 446
class HotspotStore(Entity):
447
    id = Field(Integer, primary_key=True)
448
    hotspotId = Field(String(3))
449
    companyId = Field(Integer)
450
    name = Field(String(100))
451
    city = Field(String(100))
7076 rajveer 452
    collectedAmount = Field(Integer)
7075 rajveer 453
    availableLimit = Field(Integer)
454
    creditLimit = Field(Integer)
455
    salt = Field(String(100))
456
    password = Field(String(100))
457
    isActive = Field(Boolean)
7096 anupam.sin 458
    circleId = Field(Integer)
7169 anupam.sin 459
    email = Field(String(100))
7308 rajveer 460
    line1 = Field(String(100))
461
    line2 = Field(String(100))
462
    state = Field(String(100))
463
    pin = Field(String(10))
464
    phone = Field(String(20))
7423 anupam.sin 465
    tin = Field(String(100))
7308 rajveer 466
    approvalEmail = Field(String(255))
7967 anupam.sin 467
    clusterEmail = Field(String(100))
7075 rajveer 468
    using_options(shortnames=True)
7251 rajveer 469
    using_table_options(mysql_engine="InnoDB")
470
 
471
class RechargeCollection(Entity):
472
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
473
    reconDate = Field(Integer, primary_key=True, autoincrement=False)
474
    cash = Field(Integer)
475
    hdfc = Field(Integer)
476
    grossAmount = Field(Integer)
477
    discount = Field(Integer)
478
    netCollection = Field(Integer)
479
    addedAt = Field(DateTime)
480
    pushedAt = Field(DateTime)
481
    pushedToOcr = Field(Boolean)
482
    using_options(shortnames=True)
483
    using_table_options(mysql_engine="InnoDB")
7406 rajveer 484
 
485
class StoreOrderCollection(Entity):
486
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
487
    orderId = Field(Integer, primary_key=True, autoincrement=False)
488
    collectionType = Field(String(255), primary_key=True, autoincrement=False)
489
    productName = Field(String(255))
490
    advanceAmount = Field(Integer)
491
    cash = Field(Integer)
492
    card = Field(Integer)
493
    addedAt = Field(DateTime)
494
    pushedAt = Field(DateTime)
495
    pushedToOcr = Field(Boolean)
496
    using_options(shortnames=True)
497
    using_table_options(mysql_engine="InnoDB")
7263 anupam.sin 498
 
499
class SourceDetail(Entity):
500
    id = Field(Integer, primary_key=True, autoincrement=False)
501
    name = Field(String(255))
502
    email = Field(String(255))
7410 amar.kumar 503
    tinNumber = Field(String(255))
7530 kshitij.so 504
    lastUpdatedOn = Field(DateTime)
7263 anupam.sin 505
    using_options(shortnames=True)
7311 kshitij.so 506
    using_table_options(mysql_engine="InnoDB")
507
 
508
class AmazonOrder(Entity):
509
    orderId = Field(Integer, primary_key=True, autoincrement=False)
7322 vikram.rag 510
    amazonOrderCode = Field(String(255))
511
    amazonOrderItemCode = Field(String(255))
7311 kshitij.so 512
    transactionId = Field(Integer)
513
    item_id = Field(Integer)
7322 vikram.rag 514
    status = Field(String(50))
7715 vikram.rag 515
    purchaseDateOnAmazon = Field(DateTime)
7311 kshitij.so 516
    using_options(shortnames=True)
7386 anupam.sin 517
    using_table_options(mysql_engine="InnoDB")
518
 
519
class StoreOrderDetail(Entity):
520
    orderId = Field(Integer, primary_key=True, autoincrement=False)
521
    storeId = Field(Integer, primary_key=True, autoincrement=False)
522
    advanceAmount = Field(Float)
523
    cashAmount = Field(Float)
524
    cardAmount = Field(Float)
525
    payStatus = Field(Integer)
7393 anupam.sin 526
    edcBank = Field(String(100))
527
    cashRefundAmount = Field(Float)
528
    cardRefundAmount = Field(Float)
7423 anupam.sin 529
    approvalCode = Field(String(100))
7611 anupam.sin 530
    cardType = Field(String(100))
7386 anupam.sin 531
    using_options(shortnames=True)
532
    using_table_options(mysql_engine="InnoDB")
533
 
534
class EdcBank(Entity):
535
    id = Field(Integer, primary_key=True, autoincrement=True)
536
    name = Field(String(255))
537
    using_options(shortnames=True)
7967 anupam.sin 538
    using_table_options(mysql_engine="InnoDB")
539
 
540
class HotspotServiceMatrix(Entity): 
541
    storeId = Field(Integer, primary_key=True)
542
    hotspotId = Field(String(3))
543
    rechargeService = Field(Boolean, default=0, server_default="0")
544
    storeWebsiteService = Field(Boolean, default=0, server_default="0")
545
    pickupFromStoreService = Field(Boolean, default=0, server_default="0")
546
    using_options(shortnames=True)
8182 amar.kumar 547
    using_table_options(mysql_engine="InnoDB")
548
 
549
class  EbayOrder(Entity):
550
    orderId = Field(Integer, primary_key=True, autoincrement=False)
551
    salesRecordNumber = Field(Integer)
552
    paisaPayId = Field(String(32))
553
    ebayListingId = Field(String(32))
554
    subsidyAmount = Field(Float)
555
    ebayTxnDate = Field(DateTime)
556
    transactionId = Field(String(16))
557
    listingName = Field(String(128))
558
    listingPrice = Field(Float)
8247 amar.kumar 559
    bluedartPaisaPayRef = Field(String(16))
8182 amar.kumar 560
    using_options(shortnames=True)
561
    using_table_options(mysql_engine="InnoDB")
8488 amar.kumar 562
 
563
class  SnapdealOrder(Entity):
11423 vikram.rag 564
    orderId = Field(Integer)
11422 vikram.rag 565
    subOrderId = Field(String(32), primary_key=True, autoincrement=False)
566
    referenceCode = Field(String(32),primary_key=True, autoincrement=False)
8488 amar.kumar 567
    snapdealTxnDate = Field(DateTime)
568
    productName = Field(String(128))
569
    listingPrice = Field(Float)
9456 vikram.rag 570
    maxNlc = Field(Float)
8488 amar.kumar 571
    using_options(shortnames=True)
572
    using_table_options(mysql_engine="InnoDB")
8282 kshitij.so 573
 
574
class AmazonFbaSalesSnapshot(Entity):
575
    dateOfSale = Field(Date, primary_key=True)
8363 vikram.rag 576
    item_id = Field(Integer, primary_key=True,autoincrement=False)
577
    totalOrderCount = Field(Integer)
8282 kshitij.so 578
    amazonFbaInventory = Field(Integer)
579
    isOutOfStock = Field(Boolean)
580
    salePrice = Field(Float)
8445 vikram.rag 581
    ourPrice = Field(Float)
8282 kshitij.so 582
    minFbaPrice = Field(Float)
8363 vikram.rag 583
    minMfnPrice = Field(Float)
8542 vikram.rag 584
    totalSale = Field(Numeric(precision=11, scale=3, asdecimal=False))
585
    promotionSale =  Field(Numeric(precision=11, scale=3, asdecimal=False))
8363 vikram.rag 586
    promotionOrderCount = Field(Integer)
8532 vikram.rag 587
    ourPriceSnapshotDate  =  Field(DateTime)
588
    salePriceSnapshotDate  = Field(DateTime)
589
    minMfnPriceSnapshotDate = Field(DateTime)
590
    minFbaPriceSnapshotDate = Field(DateTime)
11173 vikram.rag 591
    fcLocation = Field(Integer, primary_key=True,autoincrement=False)
8282 kshitij.so 592
    using_options(shortnames=True)
8921 anupam.sin 593
    using_table_options(mysql_engine="InnoDB")
594
 
595
class SpiceTransactionHistory(Entity):
596
    orderId = Field(Integer, primary_key=True, autoincrement=False)
597
    spiceTID = Field(String(32))
598
    reponseCode = Field(String(32))
599
    rechargeTime = Field(DateTime)
8923 anupam.sin 600
    reconciliationTime = Field(DateTime)
8922 anupam.sin 601
    using_options(shortnames=True)
8961 vikram.rag 602
    using_table_options(mysql_engine="InnoDB")
603
 
604
class FlipkartOrder(Entity):   
11423 vikram.rag 605
    orderId = Field(Integer)
11422 vikram.rag 606
    flipkartSubOrderId = Field(String(30),primary_key=True, autoincrement=False)
607
    flipkartOrderId = Field(String(30),primary_key=True, autoincrement=False)
8961 vikram.rag 608
    flipkartTxnDate = Field(DateTime)
609
    shippingPrice = Field(Float)
610
    octroiFee = Field(Float)
611
    emiFee = Field(Float)
9456 vikram.rag 612
    maxNlc = Field(Float)
8961 vikram.rag 613
    using_options(shortnames=True)
614
    using_table_options(mysql_engine="InnoDB")
12103 manish.sha 615
 
616
class AmazonFbaOrderReturns(Entity):
617
    amazonOrderId = Field(String(30),primary_key=True, autoincrement=False)
618
    insertionTimestamp = Field(DateTime, primary_key=True, autoincrement=False)
619
    sku = Field(Integer, primary_key=True, autoincrement=False)
620
    creationTimestamp = Field(DateTime)    
621
    shippedQuantity = Field(Integer)
622
    sellableReturnQuantity = Field(Integer)
623
    nonSellableReturnQuantity = Field(Integer)
624
    using_options(shortnames=True)
625
    using_table_options(mysql_engine="InnoDB")
12772 manish.sha 626
 
12936 kshitij.so 627
class MobileActivationRecord(Entity):
628
    orderId = Field(Integer)
629
    deviceNumber = Field(String(64))
12940 kshitij.so 630
    serialNumber = Field(String(20))
12936 kshitij.so 631
    circle = Field(String(100))
632
    operator = Field(String(100))
633
    activationTime = Field(DateTime)
634
    using_options(shortnames=True)
635
    using_table_options(mysql_engine="InnoDB")
636
 
12772 manish.sha 637
class FlipkartAdvantageOrder(Entity):
638
    fkOrderId = Field(String(30),primary_key=True, autoincrement=False)
639
    fkOrderItemId = Field(String(30),primary_key=True, autoincrement=False)
640
    sku = Field(Integer)
641
    creationTimestamp = Field(DateTime)
642
    customerName = Field(String(50))
643
    customerAddress = Field(String(500))
644
    pincode = Field(String(10))
645
    customerCity = Field(String(30))
646
    customerState = Field(String(30))
647
    customerPhone = Field(String(30))
648
    status = Field(String(20))
649
    quantity = Field(Integer)
650
    totalPrice = Field(Float)
651
    listPrice = Field(Float)
652
    modifiedDate = Field(DateTime)
653
    listingId = Field(String(50))
654
    cancelReason = Field(String(100))
655
    returnReason = Field(String(100))
12779 manish.sha 656
    freebieItemId = Field(String(20))
12772 manish.sha 657
    productTitle = Field(String(200))
658
    using_options(shortnames=True)
659
    using_table_options(mysql_engine="InnoDB")
13146 manish.sha 660
 
661
class FlipkartFaSalesSnapshot(Entity):
662
    dateOfSale = Field(Date, primary_key=True)
663
    item_id = Field(Integer, primary_key=True,autoincrement=False)
664
    totalOrderCount = Field(Integer)
665
    isOutOfStock = Field(Boolean)
666
    totalSale = Field(Numeric(precision=11, scale=3, asdecimal=False))
667
    ourPrice = Field(Float)
13584 manish.sha 668
    fcLocation = Field(Integer, primary_key=True,autoincrement=False)
13146 manish.sha 669
    using_options(shortnames=True)
670
    using_table_options(mysql_engine="InnoDB")
13152 manish.sha 671
 
672
class TransactionShipmentSequence(Entity):
673
    id = Field(Integer, primary_key=True, autoincrement=True)
674
    transactionId = Field(Integer)
675
    createdTimestamp = Field(DateTime)
676
    sequence = Field(Integer, default=0)
13276 manish.sha 677
    invoiceFormat = Field(Integer, default=1)
13152 manish.sha 678
    using_options(shortnames=True)
13691 manish.sha 679
    using_table_options(mysql_engine="InnoDB")
18585 amit.gupta 680
 
18591 manish.sha 681
class Creditor(Entity):
18585 amit.gupta 682
    id = Field(Integer, primary_key=True, autoincrement=True)
683
    name = Field(String(64))
18674 amit.gupta 684
    ticket_size = Field(Float)
685
    credit_due_days = Field(Integer)
18585 amit.gupta 686
    active = Field(Boolean)
687
    updated = Field(DateTime, onupdate=datetime.datetime.now)
688
    created = Field(DateTime,default = datetime.datetime.now)
689
    using_options(shortnames=True)
690
    using_table_options(mysql_engine="InnoDB")
691
 
18591 manish.sha 692
class UserSanction(Entity):
18585 amit.gupta 693
    id = Field(Integer, primary_key=True, autoincrement=True)
18586 manish.sha 694
    user_id = Field(Integer)
695
    creditor_id = Field(Integer)
18592 amit.gupta 696
    user_ref_id = Field(String(24))
18586 manish.sha 697
    credit_limit = Field(Float)
698
    credit_blocked = Field(Float)
699
    loan = Field(Float)
18585 amit.gupta 700
    active = Field(Boolean)
701
    updated = Field(DateTime, onupdate=datetime.datetime.now)
702
    created = Field(DateTime,default = datetime.datetime.now)
703
    using_options(shortnames=True)
704
    using_table_options(mysql_engine="InnoDB")
13691 manish.sha 705
 
18585 amit.gupta 706
class CreditHistory(Entity):
707
    id = Field(Integer, primary_key=True, autoincrement=True)
18586 manish.sha 708
    user_id = Field(Integer)
709
    creditor_id = Field(Integer)
18634 manish.sha 710
    payment_id = Field(Integer)
18585 amit.gupta 711
    amount = Field(Float)
18634 manish.sha 712
    credit_type = Field(Enum('BLOCKED', 'BLOCKED_REVERSED', 'LOAN',  'LOAN_CANCELLED', 'PAID', 'DEFAULTED'))
713
    shipping_id = Field(String(30))
18585 amit.gupta 714
    created = Field(DateTime,default = datetime.datetime.now)
18586 manish.sha 715
    using_options(shortnames=True)
716
    using_table_options(mysql_engine="InnoDB")
18585 amit.gupta 717
 
18634 manish.sha 718
class LoanHistory(Entity):
719
    id = Field(Integer, primary_key=True, autoincrement=True)
720
    user_id = Field(Integer)
721
    creditor_id = Field(Integer)
722
    payment_id = Field(Integer)
723
    amount = Field(Float)
724
    credit_type = Field(Enum('BLOCKED', 'BLOCKED_REVERSED', 'LOAN',  'LOAN_CANCELLED', 'PAID', 'DEFAULTED', 'CORRECTION'))
725
    loan_id = Field(String(30))
726
    created = Field(DateTime,default = datetime.datetime.now)
727
    updated = Field(DateTime)
728
    due_date = Field(DateTime)
729
    value_date = Field(DateTime)
18769 manish.sha 730
    invoiceNumber = Field(String(30))
18634 manish.sha 731
    using_options(shortnames=True)
732
    using_table_options(mysql_engine="InnoDB")
733
 
13691 manish.sha 734
class HsOrder(Entity):
735
    orderId = Field(Integer, primary_key=True, autoincrement=False)
736
    hsOrderNo = Field(String(32))
737
    hsSubOrderNo = Field(String(32))
738
    catalogueName = Field(String(50))
739
    hsOrderDate = Field(DateTime)
740
    hsProductId = Field(String(32))
741
    hsItemId = Field(String(32))
742
    sellerSku = Field(String(32))
743
    paymentMode = Field(String(50))
744
    courierName = Field(String(50))
745
    slaDays = Field(Integer)
13734 manish.sha 746
    shippingName = Field(String(50))
13691 manish.sha 747
    using_options(shortnames=True)
18578 manish.sha 748
    using_table_options(mysql_engine="InnoDB")
19832 amit.gupta 749
 
750
class PendingStoreOrder(Entity):
751
    orderId = Field(Integer, primary_key=True, autoincrement=False)
752
    hsOrderNo = Field(String(32))
753
    hsSubOrderNo = Field(String(32))
754
    catalogueName = Field(String(50))
755
    hsOrderDate = Field(DateTime)
756
    hsProductId = Field(String(32))
757
    hsItemId = Field(String(32))
758
    sellerSku = Field(String(32))
759
    paymentMode = Field(String(50))
760
    courierName = Field(String(50))
761
    slaDays = Field(Integer)
762
    shippingName = Field(String(50))
763
    using_options(shortnames=True)
764
    using_table_options(mysql_engine="InnoDB")
18578 manish.sha 765
 
766
class ReturnPickupRequest(Entity):
767
    id = Field(Integer, primary_key=True, autoincrement=True)
768
    logisticsProviderId = Field(Integer)
769
    pickupRequestNo = Field(String(50))
770
    confirmedAt = Field(DateTime)
771
    promised_pickup_timestamp = Field(DateTime)
772
    pickedUpAt = Field(DateTime)
773
    pickupStatus = Field(Enum('PENDING','PICKUP_REQUESTED','PICKUP_CONFIRMED','PICKUP_SCHEDULED','PICKUP_IN_TRANSIT','PICKUP_RECEIVED'))
774
    using_options(shortnames=True)
775
    using_table_options(mysql_engine="InnoDB")
776
 
777
class ReturnOrderInfo(Entity):
778
    id = Field(Integer, primary_key=True, autoincrement=True)
779
    returnTransaction = ManyToOne("ReturnTransaction")
780
    masterOrderId = Field(String(100))
781
    orderId = Field(Integer)
782
    lineItemId = Field(Integer)
783
    logisticsRequestId = Field(Integer)
784
    returnQuantity = Field(Integer)
785
    receivedQuantity = Field(Integer)
786
    createdAt = Field(DateTime)
787
    processedAt = Field(DateTime)
788
    returnStatus = Field(String(256))
789
    reshippedAt = Field(DateTime)
790
    receivedAt = Field(DateTime)
791
    refundReason = Field(String(256))
792
    refundedBy = Field(String(256))
793
    refundedAt = Field(DateTime)
794
    warehouse_id = Field(Integer)
795
    refundAmount = Field(Float)
19694 manish.sha 796
    refundType = Field(Integer, default=0, server_default="0")
18578 manish.sha 797
    refundDescription = Field(String(256))
798
    returnPickupType = Field(Integer, default=0, server_default="0")
799
    shippingType = Field(Integer, default=0, server_default="0")
800
    replacementOrderId = Field(Integer)
801
    receivedReturnType = Field(Integer)
802
    freebieItemId = Field(Integer, default=0, server_default="0")
803
    returnAction = Field(Integer)
804
    returnTxnResolutionStatus = Field(Enum('PENDING','AWAITING_PICKUP','QUALITY_CHECK','REPLACEMENT_DONE'\
805
                              'REPLACEMENT_ORDER_CREATED','REFUND_IN_PROCESS','REFUND_DONE','CLOSED'))
806
    lineitem = ManyToOne("LineItem", field=lineItemId)
807
    returnPickUpRequest = ManyToOne("ReturnPickupRequest", field=logisticsRequestId)
808
    using_options(shortnames=True)
809
    using_table_options(mysql_engine="InnoDB")
810
 
811
class ReturnTransaction(Entity):
812
    id = Field(Integer, primary_key=True, autoincrement=True)
813
    status = Field(Enum('INITIATED','AUTHORIZED','INPROCESS','REJECTED','PROCESSED','COMPLETED','CLOSED'))
814
    customer_email = Field(String(50))
815
    customer_name = Field(String(50))
816
    customer_id = Field(Integer)
817
    address_id = Field(Integer)
818
    ticketId = Field(Integer)
819
    createdAt = Field(DateTime)
820
    processedAt = Field(DateTime)
821
    authorizedAt = Field(DateTime)
822
    closedAt = Field(DateTime)
823
    customerAddress = Field(String(512))
824
    pincode = Field(String(10))
825
    customerCity = Field(String(100))
826
    customerState = Field(String(50))
827
    customerPhone = Field(String(50))
828
    returnOrders = OneToMany("ReturnOrderInfo")
829
    using_options(shortnames=True)
830
    using_table_options(mysql_engine="InnoDB")
19474 manish.sha 831
 
832
class ShipmentLogisticsCostDetail(Entity):
833
    logisticsTransactionId = Field(String(100), primary_key=True)
834
    airwayBillNo = Field(String(50), primary_key=True)
835
    shipmentAmount = Field(Float, default=0, server_default="0")
836
    shipmentWeight = Field(Float, default=0, server_default="0")
837
    shipmentLogsiticsCost = Field(Float, default=0, server_default="0")
838
    shipmentCodCollectionCharges = Field(Float, default=0, server_default="0")
839
    createdAt = Field(DateTime,default = datetime.datetime.now)
840
    updatedAt = Field(DateTime)
841
    using_options(shortnames=True)
842
    using_table_options(mysql_engine="InnoDB")