Subversion Repositories SmartDukaan

Rev

Rev 20025 | Rev 20745 | 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)
19981 amit.gupta 188
    warehouse_address_id = Field(Integer) 
2628 chandransh 189
    using_options(shortnames=True)
190
    using_table_options(mysql_engine="InnoDB")
5348 anupam.sin 191
 
192
class CodVerificationAgent(Entity):
193
    orderId = Field(Integer, primary_key=True, autoincrement=True)
194
    verificationAgent = Field(String(200))
195
    using_options(shortnames=True)
196
    using_table_options(mysql_engine="InnoDB")
197
 
104 ashish 198
class Transaction(Entity):
483 rajveer 199
    id = Field(Integer, primary_key=True, autoincrement=True)
200
    createdOn = Field(DateTime)
201
    status = Field(Integer)
202
    status_message = Field(String(100))
203
    customer_id = Field(Integer)
204
    shopping_cart_id = Field(Integer)
2815 vikas 205
    session_source = Field(String(100))
206
    session_start_time = Field(DateTime)
3858 vikas 207
    first_source = Field(String(100))
208
    first_source_start_time = Field(DateTime)
483 rajveer 209
    orders = OneToMany("Order")
2219 varun.gupt 210
    coupon_code = Field(String(20))
17488 manish.sha 211
    totalShippingCost = Field(Float, default=0, server_default="0")
212
    totalCodCharges = Field(Float, default=0, server_default="0")
18586 manish.sha 213
    payment_option = Field(Integer)
746 rajveer 214
    using_options(shortnames=True)
215
    using_table_options(mysql_engine="InnoDB")
132 ashish 216
 
4394 rajveer 217
class Alert(Entity):
132 ashish 218
    id = Field(Integer, primary_key=True, autoincrement=True)
483 rajveer 219
    type = Field(Integer)
4394 rajveer 220
    status = Field(Integer)
221
    timestamp = Field(DateTime)
222
    description = Field(String(100))
4444 rajveer 223
    warehouseId = Field(Integer)
746 rajveer 224
    using_options(shortnames=True)
1225 chandransh 225
    using_table_options(mysql_engine="InnoDB")
226
 
227
class BatchNoGenerator(Entity):
228
    id=Field(Integer, primary_key=True)
229
    using_options(shortnames=True)
230
    using_table_options(mysql_engine="InnoDB")
4008 mandeep.dh 231
 
232
class TransactionRequiringExtraProcessing(Entity):
4015 mandeep.dh 233
    transaction_id = Field(Integer, primary_key=True, autoincrement=False)
6733 anupam.sin 234
    category = Field(Enum('COD_VERIFICATION', 'DELAYED_DELIVERY', 'PAYMENT_FLAGGED', 'RECHARGE_UNKNOWN'), primary_key=True, autoincrement=False)
4008 mandeep.dh 235
    using_options(shortnames=True)
236
    using_table_options(mysql_engine="InnoDB")
4303 rajveer 237
 
238
class OrderInventory(Entity):
239
    order = ManyToOne("Order", primary_key=True)
240
    itemId = Field(Integer)
241
    timestamp = Field(DateTime)
242
    hotspotAction = Field(Integer)
243
    estimate = Field(Integer)
244
    using_options(shortnames=True)
245
    using_table_options(mysql_engine="InnoDB")
4600 varun.gupt 246
 
247
class EBSSettlementSummary(Entity):
248
    settlementId = Field(Integer, primary_key = True)
249
    settlementDate = Field(DateTime)
250
    transactionDateFrom = Field(DateTime)
251
    transactionDateTo = Field(DateTime)
5389 phani.kuma 252
    amount = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 253
    detailsUploaded = Field(Boolean)
254
    using_options(shortnames=True)
255
    using_table_options(mysql_engine="InnoDB")
4905 varun.gupt 256
 
4600 varun.gupt 257
class PaymentSettlement(Entity):
4905 varun.gupt 258
    referenceId = Field(Integer)    #PaymentID in case of prepaid & Order Id in case of COD
5386 phani.kuma 259
    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 260
    paymentGatewayId = Field(Integer)
261
    settlementDate = Field(DateTime)
5389 phani.kuma 262
    serviceTax = Field(Numeric(precision=11, scale=3, asdecimal=False))
263
    otherCharges = Field(Numeric(precision=11, scale=3, asdecimal=False))
264
    netCollection = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 265
    using_options(shortnames=True)
5527 anupam.sin 266
    using_table_options(mysql_engine="InnoDB")
267
 
268
class Attribute(Entity):
269
    orderId = Field(Integer)
270
    name = Field(String(100))
271
    value = Field(String(100))
272
    using_options(shortnames=True)
6389 rajveer 273
    using_table_options(mysql_engine="InnoDB")
274
 
275
 
276
class EmiScheme(Entity):
277
    id  = Field(Integer, primary_key=True)
278
    gatewayId  = Field(Integer)
279
    bankId = Field(Integer)
280
    tenure = Field(Integer)
6396 amit.gupta 281
    bankName = Field(String(256))
282
    tenureDescription = Field(String(256))
6389 rajveer 283
    minAmount = Field(Integer)
284
    chargeType = Field(Integer)
6409 rajveer 285
    chargeValue = Field(Float)
8942 rajveer 286
    interestRate = Field(Float)
6389 rajveer 287
    using_options(shortnames=True)
288
    using_table_options(mysql_engine="InnoDB")
289
 
290
class MiscCharges(Entity):
291
    transaction = ManyToOne("Transaction", primary_key=True)
6396 amit.gupta 292
    chargeType = Field(Integer, primary_key=True, autoincrement=False)
6389 rajveer 293
    chargeAmount = Field(Float)
294
    using_options(shortnames=True)
6580 anupam.sin 295
    using_table_options(mysql_engine="InnoDB")
296
 
6591 anupam.sin 297
class BlockedIpRange(Entity):
6580 anupam.sin 298
    id = Field(Integer, primary_key=True, autoincrement=True)
6594 anupam.sin 299
    start = Field(BigInteger)
300
    end = Field(BigInteger)
6591 anupam.sin 301
    expiredOn = Field(DateTime)
6580 anupam.sin 302
    using_options(shortnames=True)
6591 anupam.sin 303
    using_table_options(mysql_engine="InnoDB")
304
 
305
class DeniedIpAddress(Entity):
306
    id = Field(Integer, primary_key=True, autoincrement=True)
307
    ip = Field(String(256))
308
    deniedOn = Field(DateTime)
309
    rechargeType = Field(Integer)
310
    deviceNumber = Field(String(128))
311
    using_options(shortnames=True)
6903 anupam.sin 312
    using_table_options(mysql_engine="InnoDB")
313
 
314
class InsuranceDetailForOrder(Entity):
315
    id = Field(Integer, primary_key=True, autoincrement=True)
316
    dob = Field(String(64))
317
    guardianName = Field(String(255))
318
    startDate = Field(DateTime)
319
    expiryDate = Field(DateTime)
6915 anupam.sin 320
    isDeclared = Field(Boolean, default=0)
6903 anupam.sin 321
    order = ManyToOne("Order")
322
    using_options(shortnames=True)
6906 rajveer 323
    using_table_options(mysql_engine="InnoDB")
324
 
6915 anupam.sin 325
    def __init__(self):
326
        self.isDeclared = 0
327
 
9575 kshitij.so 328
class DataInsuranceDetailForOrder(Entity):
329
    id = Field(Integer, primary_key=True, autoincrement=True)
330
    startDate = Field(DateTime)
331
    expiryDate = Field(DateTime)
9608 kshitij.so 332
    isDeclared = Field(Boolean, default=0, server_default="0")
9575 kshitij.so 333
    order = ManyToOne("Order")
334
    using_options(shortnames=True)
335
    using_table_options(mysql_engine="InnoDB")
336
 
6906 rajveer 337
class DocumentStore(Entity):
338
    docType = Field(Integer, primary_key=True, autoincrement=False)
339
    docSource = Field(Integer, primary_key=True, autoincrement=False)
340
    document  = Field(LargeBinary)
341
    using_options(shortnames=True)
7073 anupam.sin 342
    using_table_options(mysql_engine="InnoDB")
343
 
344
class Company(Entity):
345
    id = Field(Integer, primary_key=True, autoincrement=True)
346
    name = Field(String(255))
347
    Address = Field(String(255))
348
    using_options(shortnames=True)
349
    using_table_options(mysql_engine="InnoDB")
350
 
19973 amit.gupta 351
 
352
class Organisation(Entity):
353
    id = Field(Integer, primary_key=True, autoincrement=True)
354
    name = Field(String(255))
355
    address = Field(String(255))
356
    type = Field(Enum('company'), default='company')
357
    registered_id = Field(String(127))
358
    using_options(shortnames=True)
359
    using_table_options(mysql_engine="InnoDB")
360
 
361
class Seller(Entity):
362
    id = Field(Integer, primary_key=True, autoincrement=True)
19978 amit.gupta 363
    label=Field(String(31), unique=True)
19973 amit.gupta 364
    organisation_id = Field(Integer)
365
    state_id = Field(Integer)
366
    tin = Field(String(15))
19975 amit.gupta 367
    address = Field(String(255))
19973 amit.gupta 368
    using_options(shortnames=True)
369
    using_table_options(mysql_engine="InnoDB")
370
 
19980 amit.gupta 371
class WarehouseAddressMapping(Entity):
372
    warehouse_id = Field(Integer)
373
    address_id = Field(Integer)
374
    created = Field(DateTime, default=datetime.datetime.now)
375
    updated = Field(DateTime)
19982 amit.gupta 376
    using_options(shortnames=True)
377
    using_table_options(mysql_engine="InnoDB")
19980 amit.gupta 378
 
379
class WarehouseAddressMaster(Entity):
380
    id = Field(Integer, primary_key=True, autoincrement=True)
381
    address = Field(String(255))
382
    pin = Field(String(6))
383
    state_id = Field(Integer)
384
    created = Field(DateTime, default=datetime.datetime.now)
19982 amit.gupta 385
    using_options(shortnames=True)
386
    using_table_options(mysql_engine="InnoDB")
19980 amit.gupta 387
 
19973 amit.gupta 388
class SellerWarehouse(Entity):
389
    id = Field(Integer, default=0)
390
    seller_id = Field(Integer, primary_key=True)
391
    warehouse_id = Field(Integer, primary_key=True)
392
    orderType = Field(Integer, primary_key = True)
19977 amit.gupta 393
    prefix = Field(String(7))
394
    created_on = Field(DateTime)
19973 amit.gupta 395
    is_active = Field(Boolean)
396
    using_options(shortnames=True)
397
    using_table_options(mysql_engine="InnoDB")
398
 
399
 
7073 anupam.sin 400
class WalletForCompany(Entity):
401
    id = Field(Integer, primary_key=True, autoincrement=True)
402
    companyId = Field(Integer)
7102 rajveer 403
    amount = Field(Integer)
7073 anupam.sin 404
    using_options(shortnames=True)
405
    using_table_options(mysql_engine="InnoDB")
406
 
407
class WalletHistoryForCompany(Entity):
408
    id = Field(Integer, primary_key=True, autoincrement=True)
409
    walletId = Field(Integer)
7102 rajveer 410
    amount = Field(Integer)
7073 anupam.sin 411
    transactionTime = Field(DateTime)
7102 rajveer 412
    openingBal = Field(Integer)
413
    closingBal = Field(Integer)
7073 anupam.sin 414
    referenceNumber = Field(Integer)
415
    description = Field(String(255))
416
    using_options(shortnames=True)
417
    using_table_options(mysql_engine="InnoDB")
418
 
419
class RechargeTransaction(Entity):
420
    id = Field(Integer, primary_key=True, autoincrement=True)
421
    storeId = Field(Integer)
7102 rajveer 422
    amount = Field(Integer)
7073 anupam.sin 423
    transactionTime = Field(DateTime)
7075 rajveer 424
    responseTime = Field(DateTime)
425
    description = Field(String(255))
426
    spiceTID = Field(String(255))
7369 rajveer 427
    aggTID = Field(String(255))
428
    providerTID = Field(String(255))
7075 rajveer 429
    plan = Field(String(255))
7073 anupam.sin 430
    deviceNum = Field(String(64))
431
    deviceType = Field(Integer)
432
    isFrc = Field(Boolean)
433
    email = Field(String(255))
7102 rajveer 434
    discount = Field(Integer)
435
    paymentAmount = Field(Integer)
7145 rajveer 436
    payMethod = Field(Integer, default=0, server_default="0")
7073 anupam.sin 437
    status = Field(Integer)
438
    invoiceNumber = Field(Integer)
439
    circleId = Field(Integer)
7075 rajveer 440
    operatorId = Field(Integer)
7073 anupam.sin 441
    name = Field(String(255))
442
    simNum = Field(String(255))
443
    cafNum = Field(String(255))
7080 anupam.sin 444
    ipAddress = Field(String(255))
445
    alternateNumber = Field(String(255))
7073 anupam.sin 446
    using_options(shortnames=True)
7075 rajveer 447
    using_table_options(mysql_engine="InnoDB")
7076 rajveer 448
 
7120 rajveer 449
class OperatorSeries(Entity):
450
    series = Field(Integer, primary_key=True, autoincrement=False)
451
    operatorId = Field(Integer)
452
    circleId = Field(Integer)
453
    using_options(shortnames=True)
454
    using_table_options(mysql_engine="InnoDB")
455
 
7076 rajveer 456
class FRC(Entity):
457
    id = Field(Integer, primary_key=True)
458
    operatorId = Field(Integer)
459
    circleId = Field(Integer)
460
    denomination = Field(Integer)
461
    maxDiscount = Field(Integer)
462
    using_options(shortnames=True)
463
    using_table_options(mysql_engine="InnoDB")
7120 rajveer 464
 
7075 rajveer 465
class HotspotStore(Entity):
466
    id = Field(Integer, primary_key=True)
467
    hotspotId = Field(String(3))
468
    companyId = Field(Integer)
469
    name = Field(String(100))
470
    city = Field(String(100))
7076 rajveer 471
    collectedAmount = Field(Integer)
7075 rajveer 472
    availableLimit = Field(Integer)
473
    creditLimit = Field(Integer)
474
    salt = Field(String(100))
475
    password = Field(String(100))
476
    isActive = Field(Boolean)
7096 anupam.sin 477
    circleId = Field(Integer)
7169 anupam.sin 478
    email = Field(String(100))
7308 rajveer 479
    line1 = Field(String(100))
480
    line2 = Field(String(100))
481
    state = Field(String(100))
482
    pin = Field(String(10))
483
    phone = Field(String(20))
7423 anupam.sin 484
    tin = Field(String(100))
7308 rajveer 485
    approvalEmail = Field(String(255))
7967 anupam.sin 486
    clusterEmail = Field(String(100))
7075 rajveer 487
    using_options(shortnames=True)
7251 rajveer 488
    using_table_options(mysql_engine="InnoDB")
489
 
490
class RechargeCollection(Entity):
491
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
492
    reconDate = Field(Integer, primary_key=True, autoincrement=False)
493
    cash = Field(Integer)
494
    hdfc = Field(Integer)
495
    grossAmount = Field(Integer)
496
    discount = Field(Integer)
497
    netCollection = Field(Integer)
498
    addedAt = Field(DateTime)
499
    pushedAt = Field(DateTime)
500
    pushedToOcr = Field(Boolean)
501
    using_options(shortnames=True)
502
    using_table_options(mysql_engine="InnoDB")
7406 rajveer 503
 
504
class StoreOrderCollection(Entity):
505
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
506
    orderId = Field(Integer, primary_key=True, autoincrement=False)
507
    collectionType = Field(String(255), primary_key=True, autoincrement=False)
508
    productName = Field(String(255))
509
    advanceAmount = Field(Integer)
510
    cash = Field(Integer)
511
    card = Field(Integer)
512
    addedAt = Field(DateTime)
513
    pushedAt = Field(DateTime)
514
    pushedToOcr = Field(Boolean)
515
    using_options(shortnames=True)
516
    using_table_options(mysql_engine="InnoDB")
7263 anupam.sin 517
 
518
class SourceDetail(Entity):
519
    id = Field(Integer, primary_key=True, autoincrement=False)
520
    name = Field(String(255))
521
    email = Field(String(255))
7410 amar.kumar 522
    tinNumber = Field(String(255))
7530 kshitij.so 523
    lastUpdatedOn = Field(DateTime)
7263 anupam.sin 524
    using_options(shortnames=True)
7311 kshitij.so 525
    using_table_options(mysql_engine="InnoDB")
526
 
527
class AmazonOrder(Entity):
528
    orderId = Field(Integer, primary_key=True, autoincrement=False)
7322 vikram.rag 529
    amazonOrderCode = Field(String(255))
530
    amazonOrderItemCode = Field(String(255))
7311 kshitij.so 531
    transactionId = Field(Integer)
532
    item_id = Field(Integer)
7322 vikram.rag 533
    status = Field(String(50))
7715 vikram.rag 534
    purchaseDateOnAmazon = Field(DateTime)
7311 kshitij.so 535
    using_options(shortnames=True)
7386 anupam.sin 536
    using_table_options(mysql_engine="InnoDB")
537
 
538
class StoreOrderDetail(Entity):
539
    orderId = Field(Integer, primary_key=True, autoincrement=False)
540
    storeId = Field(Integer, primary_key=True, autoincrement=False)
541
    advanceAmount = Field(Float)
542
    cashAmount = Field(Float)
543
    cardAmount = Field(Float)
544
    payStatus = Field(Integer)
7393 anupam.sin 545
    edcBank = Field(String(100))
546
    cashRefundAmount = Field(Float)
547
    cardRefundAmount = Field(Float)
7423 anupam.sin 548
    approvalCode = Field(String(100))
7611 anupam.sin 549
    cardType = Field(String(100))
7386 anupam.sin 550
    using_options(shortnames=True)
551
    using_table_options(mysql_engine="InnoDB")
552
 
553
class EdcBank(Entity):
554
    id = Field(Integer, primary_key=True, autoincrement=True)
555
    name = Field(String(255))
556
    using_options(shortnames=True)
7967 anupam.sin 557
    using_table_options(mysql_engine="InnoDB")
558
 
559
class HotspotServiceMatrix(Entity): 
560
    storeId = Field(Integer, primary_key=True)
561
    hotspotId = Field(String(3))
562
    rechargeService = Field(Boolean, default=0, server_default="0")
563
    storeWebsiteService = Field(Boolean, default=0, server_default="0")
564
    pickupFromStoreService = Field(Boolean, default=0, server_default="0")
565
    using_options(shortnames=True)
8182 amar.kumar 566
    using_table_options(mysql_engine="InnoDB")
567
 
568
class  EbayOrder(Entity):
569
    orderId = Field(Integer, primary_key=True, autoincrement=False)
570
    salesRecordNumber = Field(Integer)
571
    paisaPayId = Field(String(32))
572
    ebayListingId = Field(String(32))
573
    subsidyAmount = Field(Float)
574
    ebayTxnDate = Field(DateTime)
575
    transactionId = Field(String(16))
576
    listingName = Field(String(128))
577
    listingPrice = Field(Float)
8247 amar.kumar 578
    bluedartPaisaPayRef = Field(String(16))
8182 amar.kumar 579
    using_options(shortnames=True)
580
    using_table_options(mysql_engine="InnoDB")
8488 amar.kumar 581
 
582
class  SnapdealOrder(Entity):
11423 vikram.rag 583
    orderId = Field(Integer)
11422 vikram.rag 584
    subOrderId = Field(String(32), primary_key=True, autoincrement=False)
585
    referenceCode = Field(String(32),primary_key=True, autoincrement=False)
8488 amar.kumar 586
    snapdealTxnDate = Field(DateTime)
587
    productName = Field(String(128))
588
    listingPrice = Field(Float)
9456 vikram.rag 589
    maxNlc = Field(Float)
8488 amar.kumar 590
    using_options(shortnames=True)
591
    using_table_options(mysql_engine="InnoDB")
8282 kshitij.so 592
 
593
class AmazonFbaSalesSnapshot(Entity):
594
    dateOfSale = Field(Date, primary_key=True)
8363 vikram.rag 595
    item_id = Field(Integer, primary_key=True,autoincrement=False)
596
    totalOrderCount = Field(Integer)
8282 kshitij.so 597
    amazonFbaInventory = Field(Integer)
598
    isOutOfStock = Field(Boolean)
599
    salePrice = Field(Float)
8445 vikram.rag 600
    ourPrice = Field(Float)
8282 kshitij.so 601
    minFbaPrice = Field(Float)
8363 vikram.rag 602
    minMfnPrice = Field(Float)
8542 vikram.rag 603
    totalSale = Field(Numeric(precision=11, scale=3, asdecimal=False))
604
    promotionSale =  Field(Numeric(precision=11, scale=3, asdecimal=False))
8363 vikram.rag 605
    promotionOrderCount = Field(Integer)
8532 vikram.rag 606
    ourPriceSnapshotDate  =  Field(DateTime)
607
    salePriceSnapshotDate  = Field(DateTime)
608
    minMfnPriceSnapshotDate = Field(DateTime)
609
    minFbaPriceSnapshotDate = Field(DateTime)
11173 vikram.rag 610
    fcLocation = Field(Integer, primary_key=True,autoincrement=False)
8282 kshitij.so 611
    using_options(shortnames=True)
8921 anupam.sin 612
    using_table_options(mysql_engine="InnoDB")
613
 
614
class SpiceTransactionHistory(Entity):
615
    orderId = Field(Integer, primary_key=True, autoincrement=False)
616
    spiceTID = Field(String(32))
617
    reponseCode = Field(String(32))
618
    rechargeTime = Field(DateTime)
8923 anupam.sin 619
    reconciliationTime = Field(DateTime)
8922 anupam.sin 620
    using_options(shortnames=True)
8961 vikram.rag 621
    using_table_options(mysql_engine="InnoDB")
622
 
623
class FlipkartOrder(Entity):   
11423 vikram.rag 624
    orderId = Field(Integer)
11422 vikram.rag 625
    flipkartSubOrderId = Field(String(30),primary_key=True, autoincrement=False)
626
    flipkartOrderId = Field(String(30),primary_key=True, autoincrement=False)
8961 vikram.rag 627
    flipkartTxnDate = Field(DateTime)
628
    shippingPrice = Field(Float)
629
    octroiFee = Field(Float)
630
    emiFee = Field(Float)
9456 vikram.rag 631
    maxNlc = Field(Float)
8961 vikram.rag 632
    using_options(shortnames=True)
633
    using_table_options(mysql_engine="InnoDB")
12103 manish.sha 634
 
635
class AmazonFbaOrderReturns(Entity):
636
    amazonOrderId = Field(String(30),primary_key=True, autoincrement=False)
637
    insertionTimestamp = Field(DateTime, primary_key=True, autoincrement=False)
638
    sku = Field(Integer, primary_key=True, autoincrement=False)
639
    creationTimestamp = Field(DateTime)    
640
    shippedQuantity = Field(Integer)
641
    sellableReturnQuantity = Field(Integer)
642
    nonSellableReturnQuantity = Field(Integer)
643
    using_options(shortnames=True)
644
    using_table_options(mysql_engine="InnoDB")
12772 manish.sha 645
 
12936 kshitij.so 646
class MobileActivationRecord(Entity):
647
    orderId = Field(Integer)
648
    deviceNumber = Field(String(64))
12940 kshitij.so 649
    serialNumber = Field(String(20))
12936 kshitij.so 650
    circle = Field(String(100))
651
    operator = Field(String(100))
652
    activationTime = Field(DateTime)
653
    using_options(shortnames=True)
654
    using_table_options(mysql_engine="InnoDB")
655
 
12772 manish.sha 656
class FlipkartAdvantageOrder(Entity):
657
    fkOrderId = Field(String(30),primary_key=True, autoincrement=False)
658
    fkOrderItemId = Field(String(30),primary_key=True, autoincrement=False)
659
    sku = Field(Integer)
660
    creationTimestamp = Field(DateTime)
661
    customerName = Field(String(50))
662
    customerAddress = Field(String(500))
663
    pincode = Field(String(10))
664
    customerCity = Field(String(30))
665
    customerState = Field(String(30))
666
    customerPhone = Field(String(30))
667
    status = Field(String(20))
668
    quantity = Field(Integer)
669
    totalPrice = Field(Float)
670
    listPrice = Field(Float)
671
    modifiedDate = Field(DateTime)
672
    listingId = Field(String(50))
673
    cancelReason = Field(String(100))
674
    returnReason = Field(String(100))
12779 manish.sha 675
    freebieItemId = Field(String(20))
12772 manish.sha 676
    productTitle = Field(String(200))
677
    using_options(shortnames=True)
678
    using_table_options(mysql_engine="InnoDB")
13146 manish.sha 679
 
680
class FlipkartFaSalesSnapshot(Entity):
681
    dateOfSale = Field(Date, primary_key=True)
682
    item_id = Field(Integer, primary_key=True,autoincrement=False)
683
    totalOrderCount = Field(Integer)
684
    isOutOfStock = Field(Boolean)
685
    totalSale = Field(Numeric(precision=11, scale=3, asdecimal=False))
686
    ourPrice = Field(Float)
13584 manish.sha 687
    fcLocation = Field(Integer, primary_key=True,autoincrement=False)
13146 manish.sha 688
    using_options(shortnames=True)
689
    using_table_options(mysql_engine="InnoDB")
13152 manish.sha 690
 
691
class TransactionShipmentSequence(Entity):
692
    id = Field(Integer, primary_key=True, autoincrement=True)
693
    transactionId = Field(Integer)
694
    createdTimestamp = Field(DateTime)
695
    sequence = Field(Integer, default=0)
13276 manish.sha 696
    invoiceFormat = Field(Integer, default=1)
13152 manish.sha 697
    using_options(shortnames=True)
13691 manish.sha 698
    using_table_options(mysql_engine="InnoDB")
18585 amit.gupta 699
 
18591 manish.sha 700
class Creditor(Entity):
18585 amit.gupta 701
    id = Field(Integer, primary_key=True, autoincrement=True)
702
    name = Field(String(64))
18674 amit.gupta 703
    ticket_size = Field(Float)
704
    credit_due_days = Field(Integer)
18585 amit.gupta 705
    active = Field(Boolean)
706
    updated = Field(DateTime, onupdate=datetime.datetime.now)
707
    created = Field(DateTime,default = datetime.datetime.now)
708
    using_options(shortnames=True)
709
    using_table_options(mysql_engine="InnoDB")
710
 
18591 manish.sha 711
class UserSanction(Entity):
18585 amit.gupta 712
    id = Field(Integer, primary_key=True, autoincrement=True)
18586 manish.sha 713
    user_id = Field(Integer)
714
    creditor_id = Field(Integer)
18592 amit.gupta 715
    user_ref_id = Field(String(24))
18586 manish.sha 716
    credit_limit = Field(Float)
717
    credit_blocked = Field(Float)
718
    loan = Field(Float)
18585 amit.gupta 719
    active = Field(Boolean)
720
    updated = Field(DateTime, onupdate=datetime.datetime.now)
721
    created = Field(DateTime,default = datetime.datetime.now)
722
    using_options(shortnames=True)
723
    using_table_options(mysql_engine="InnoDB")
13691 manish.sha 724
 
18585 amit.gupta 725
class CreditHistory(Entity):
726
    id = Field(Integer, primary_key=True, autoincrement=True)
18586 manish.sha 727
    user_id = Field(Integer)
728
    creditor_id = Field(Integer)
18634 manish.sha 729
    payment_id = Field(Integer)
18585 amit.gupta 730
    amount = Field(Float)
18634 manish.sha 731
    credit_type = Field(Enum('BLOCKED', 'BLOCKED_REVERSED', 'LOAN',  'LOAN_CANCELLED', 'PAID', 'DEFAULTED'))
732
    shipping_id = Field(String(30))
18585 amit.gupta 733
    created = Field(DateTime,default = datetime.datetime.now)
18586 manish.sha 734
    using_options(shortnames=True)
735
    using_table_options(mysql_engine="InnoDB")
18585 amit.gupta 736
 
18634 manish.sha 737
class LoanHistory(Entity):
738
    id = Field(Integer, primary_key=True, autoincrement=True)
739
    user_id = Field(Integer)
740
    creditor_id = Field(Integer)
741
    payment_id = Field(Integer)
742
    amount = Field(Float)
743
    credit_type = Field(Enum('BLOCKED', 'BLOCKED_REVERSED', 'LOAN',  'LOAN_CANCELLED', 'PAID', 'DEFAULTED', 'CORRECTION'))
744
    loan_id = Field(String(30))
745
    created = Field(DateTime,default = datetime.datetime.now)
746
    updated = Field(DateTime)
747
    due_date = Field(DateTime)
748
    value_date = Field(DateTime)
18769 manish.sha 749
    invoiceNumber = Field(String(30))
18634 manish.sha 750
    using_options(shortnames=True)
751
    using_table_options(mysql_engine="InnoDB")
752
 
13691 manish.sha 753
class HsOrder(Entity):
754
    orderId = Field(Integer, primary_key=True, autoincrement=False)
755
    hsOrderNo = Field(String(32))
756
    hsSubOrderNo = Field(String(32))
757
    catalogueName = Field(String(50))
758
    hsOrderDate = Field(DateTime)
759
    hsProductId = Field(String(32))
760
    hsItemId = Field(String(32))
761
    sellerSku = Field(String(32))
762
    paymentMode = Field(String(50))
763
    courierName = Field(String(50))
764
    slaDays = Field(Integer)
13734 manish.sha 765
    shippingName = Field(String(50))
13691 manish.sha 766
    using_options(shortnames=True)
18578 manish.sha 767
    using_table_options(mysql_engine="InnoDB")
19832 amit.gupta 768
 
769
class PendingStoreOrder(Entity):
770
    orderId = Field(Integer, primary_key=True, autoincrement=False)
771
    hsOrderNo = Field(String(32))
772
    hsSubOrderNo = Field(String(32))
773
    catalogueName = Field(String(50))
774
    hsOrderDate = Field(DateTime)
775
    hsProductId = Field(String(32))
776
    hsItemId = Field(String(32))
777
    sellerSku = Field(String(32))
778
    paymentMode = Field(String(50))
779
    courierName = Field(String(50))
780
    slaDays = Field(Integer)
781
    shippingName = Field(String(50))
782
    using_options(shortnames=True)
783
    using_table_options(mysql_engine="InnoDB")
18578 manish.sha 784
 
785
class ReturnPickupRequest(Entity):
786
    id = Field(Integer, primary_key=True, autoincrement=True)
787
    logisticsProviderId = Field(Integer)
788
    pickupRequestNo = Field(String(50))
789
    confirmedAt = Field(DateTime)
790
    promised_pickup_timestamp = Field(DateTime)
791
    pickedUpAt = Field(DateTime)
792
    pickupStatus = Field(Enum('PENDING','PICKUP_REQUESTED','PICKUP_CONFIRMED','PICKUP_SCHEDULED','PICKUP_IN_TRANSIT','PICKUP_RECEIVED'))
793
    using_options(shortnames=True)
794
    using_table_options(mysql_engine="InnoDB")
795
 
796
class ReturnOrderInfo(Entity):
797
    id = Field(Integer, primary_key=True, autoincrement=True)
798
    returnTransaction = ManyToOne("ReturnTransaction")
799
    masterOrderId = Field(String(100))
800
    orderId = Field(Integer)
801
    lineItemId = Field(Integer)
802
    logisticsRequestId = Field(Integer)
803
    returnQuantity = Field(Integer)
804
    receivedQuantity = Field(Integer)
805
    createdAt = Field(DateTime)
806
    processedAt = Field(DateTime)
807
    returnStatus = Field(String(256))
808
    reshippedAt = Field(DateTime)
809
    receivedAt = Field(DateTime)
810
    refundReason = Field(String(256))
811
    refundedBy = Field(String(256))
812
    refundedAt = Field(DateTime)
813
    warehouse_id = Field(Integer)
814
    refundAmount = Field(Float)
19694 manish.sha 815
    refundType = Field(Integer, default=0, server_default="0")
18578 manish.sha 816
    refundDescription = Field(String(256))
817
    returnPickupType = Field(Integer, default=0, server_default="0")
818
    shippingType = Field(Integer, default=0, server_default="0")
819
    replacementOrderId = Field(Integer)
820
    receivedReturnType = Field(Integer)
821
    freebieItemId = Field(Integer, default=0, server_default="0")
822
    returnAction = Field(Integer)
823
    returnTxnResolutionStatus = Field(Enum('PENDING','AWAITING_PICKUP','QUALITY_CHECK','REPLACEMENT_DONE'\
824
                              'REPLACEMENT_ORDER_CREATED','REFUND_IN_PROCESS','REFUND_DONE','CLOSED'))
825
    lineitem = ManyToOne("LineItem", field=lineItemId)
826
    returnPickUpRequest = ManyToOne("ReturnPickupRequest", field=logisticsRequestId)
827
    using_options(shortnames=True)
828
    using_table_options(mysql_engine="InnoDB")
829
 
830
class ReturnTransaction(Entity):
831
    id = Field(Integer, primary_key=True, autoincrement=True)
832
    status = Field(Enum('INITIATED','AUTHORIZED','INPROCESS','REJECTED','PROCESSED','COMPLETED','CLOSED'))
833
    customer_email = Field(String(50))
834
    customer_name = Field(String(50))
835
    customer_id = Field(Integer)
836
    address_id = Field(Integer)
837
    ticketId = Field(Integer)
838
    createdAt = Field(DateTime)
839
    processedAt = Field(DateTime)
840
    authorizedAt = Field(DateTime)
841
    closedAt = Field(DateTime)
842
    customerAddress = Field(String(512))
843
    pincode = Field(String(10))
844
    customerCity = Field(String(100))
845
    customerState = Field(String(50))
846
    customerPhone = Field(String(50))
847
    returnOrders = OneToMany("ReturnOrderInfo")
848
    using_options(shortnames=True)
849
    using_table_options(mysql_engine="InnoDB")
19474 manish.sha 850
 
851
class ShipmentLogisticsCostDetail(Entity):
852
    logisticsTransactionId = Field(String(100), primary_key=True)
853
    airwayBillNo = Field(String(50), primary_key=True)
854
    shipmentAmount = Field(Float, default=0, server_default="0")
855
    shipmentWeight = Field(Float, default=0, server_default="0")
856
    shipmentLogsiticsCost = Field(Float, default=0, server_default="0")
857
    shipmentCodCollectionCharges = Field(Float, default=0, server_default="0")
858
    createdAt = Field(DateTime,default = datetime.datetime.now)
859
    updatedAt = Field(DateTime)
20737 kshitij.so 860
    packageDimensions = Field(String(20))
19474 manish.sha 861
    using_options(shortnames=True)
862
    using_table_options(mysql_engine="InnoDB")