Subversion Repositories SmartDukaan

Rev

Rev 12778 | Rev 12936 | 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, \
8282 kshitij.so 14
    Numeric, BigInteger, LargeBinary,Date
104 ashish 15
 
16
#===============================================================================
17
# Different entities in the model
18
#===============================================================================
19
 
3187 rajveer 20
def initialize(dbname='transaction', db_hostname="localhost", echoOn=True):
746 rajveer 21
    #metadata.bind = "sqlite:///Transactionsnew.sqlite"
1122 chandransh 22
    #metadata.bind = 'mysql://root:shop2020@localhost/transaction'
3187 rajveer 23
    engine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200)
1122 chandransh 24
    metadata.bind = engine
1911 chandransh 25
    metadata.bind.echo = echoOn
483 rajveer 26
    setup_all(True)
27
 
28
 
29
if __name__=="__main__":
30
    initialize()
2783 chandransh 31
 
32
class InvoiceIDGenerator(Entity):
5527 anupam.sin 33
    id = Field(Integer)
5528 anupam.sin 34
    orderType = Field(Integer, primary_key = True)
2783 chandransh 35
    using_options(shortnames=True)
36
    using_table_options(mysql_engine="InnoDB")   
483 rajveer 37
 
12772 manish.sha 38
class InvoiceCounterGenerator(Entity):
39
    id = Field(Integer)
40
    orderType = Field(Integer, primary_key = True)
41
    stateId = Field(Integer, primary_key = True)
12775 manish.sha 42
    prefix = Field(String(20))
12772 manish.sha 43
    using_options(shortnames=True)
44
    using_table_options(mysql_engine="InnoDB")
45
 
5508 rajveer 46
class RechargeVoucherTracker(Entity):
47
    order = ManyToOne("Order")
48
    voucherType = Field(Integer)
49
    amount = Field(Integer)
50
    voucherIssued = Field(Boolean)
51
    voucherCode = Field(String(30))
52
    issuedOn = Field(DateTime)
53
    using_options(shortnames=True)
54
    using_table_options(mysql_engine="InnoDB")
55
 
483 rajveer 56
class LineItem(Entity):
57
    id = Field(Integer, primary_key=True, autoincrement=True)
699 chandransh 58
    item_id = Field(Integer)
963 chandransh 59
    productGroup = Field(String(100))
60
    brand = Field(String(100))
61
    model_number = Field(String(50))
62
    model_name = Field(String(50))
669 chandransh 63
    color = Field(String(20))
483 rajveer 64
    extra_info = Field(String(100))
65
    quantity = Field(Float)
12280 amit.gupta 66
    mrp = Field(Float)
483 rajveer 67
    unit_price = Field(Float)
68
    unit_weight = Field(Float)
69
    total_price = Field(Float)
996 varun.gupt 70
    transfer_price = Field(Float)
6751 amar.kumar 71
    nlc = Field(Float)
483 rajveer 72
    total_weight = Field(Float)
2783 chandransh 73
    item_number = Field(String(50))
12653 manish.sha 74
    serial_number = Field(String(8192)) 
4172 rajveer 75
    dealText = Field(String(100))
4295 varun.gupt 76
    warranty_expiry_timestamp = Field(DateTime)
483 rajveer 77
    order = ManyToOne("Order")
6039 amit.gupta 78
    vatRate = Field(Float)
746 rajveer 79
    using_options(shortnames=True)
80
    using_table_options(mysql_engine="InnoDB")
81
 
1276 chandransh 82
    def __repr__(self):
83
        return "{0} {1} {2} {3}".format(self.brand or "", self.model_name or "", self.model_number or "", self.color or "")
84
 
483 rajveer 85
class Order(Entity):
86
    id = Field(Integer, primary_key=True, autoincrement=True)
87
    warehouse_id = Field(Integer)
88
    logistics_provider_id = Field(Integer)
89
    airwaybill_no = Field(String(50))
90
    tracking_id = Field(String(50))
91
    expected_delivery_time = Field(DateTime)
3986 chandransh 92
    promised_delivery_time = Field(DateTime)
4004 chandransh 93
    expected_shipping_time = Field(DateTime)
4102 chandransh 94
    promised_shipping_time = Field(DateTime)
6726 rajveer 95
    courier_delivery_time = Field(DateTime)
483 rajveer 96
    customer_id = Field(Integer)
97
    customer_name = Field(String(50))
98
    customer_mobilenumber = Field(String(20))
99
    customer_pincode = Field(String(10))
738 chandransh 100
    customer_address1 = Field(String(100))
101
    customer_address2 = Field(String(100))
669 chandransh 102
    customer_city = Field(String(100))
103
    customer_state = Field(String(100))
483 rajveer 104
    customer_email = Field(String(50))
105
    status = Field(Integer)
106
    statusDescription = Field(String(50))
107
    total_amount = Field(Float)
6318 rajveer 108
    gvAmount = Field(Float)
483 rajveer 109
    total_weight = Field(Float)
110
    invoice_number = Field(String(30))
111
    billed_by = Field(String(30))
112
    created_timestamp = Field(DateTime)
113
    accepted_timestamp = Field(DateTime)
114
    billing_timestamp = Field(DateTime)
115
    shipping_timestamp = Field(DateTime)
1113 chandransh 116
    pickup_timestamp = Field(DateTime)
483 rajveer 117
    delivery_timestamp = Field(DateTime)
1208 chandransh 118
    outofstock_timestamp = Field(DateTime)
483 rajveer 119
    lineitems = OneToMany("LineItem")
120
    transaction = ManyToOne("Transaction")
6903 anupam.sin 121
    insuranceDetails = OneToMany("InsuranceDetailForOrder")
9575 kshitij.so 122
    dataInsuranceDetails = OneToMany("DataInsuranceDetailForOrder")
642 chandransh 123
    jacket_number = Field(Integer)
1132 chandransh 124
    receiver = Field(String(50))
1220 chandransh 125
    batchNo = Field(Integer)
126
    serialNo = Field(Integer)
2536 chandransh 127
    doaFlag = Field(Boolean)
128
    pickupRequestNo = Field(String(20))
2764 chandransh 129
    doa_auth_timestamp = Field(DateTime)
130
    doa_pickup_timestamp = Field(DateTime)
131
    received_return_timestamp = Field(DateTime)
132
    reship_timestamp = Field(DateTime)
133
    refund_timestamp = Field(DateTime)
2628 chandransh 134
    new_order_id = Field(Integer)
2819 chandransh 135
    purchase_order_id = Field(Integer)
3064 chandransh 136
    cod = Field(Boolean)
3226 chandransh 137
    refunded_by = Field(String(30))
5141 anupam.sin 138
    refund_reason = Field(String(256))
3064 chandransh 139
    verification_timestamp = Field(DateTime)
3581 chandransh 140
    delay_reason = Field(Enum('INVENTORY_LOW_PHASED_OUT', 'INVENTORY_LOW_COLOR_NOT_AVAILABLE',\
141
                              'INVENTORY_LOW_REVERSAL_NOT_ON_TIME', 'INVENTORY_LOW_PRODUCT_NOT_SEALED',\
142
                              'COURIER_DELAY_NOT_DELIVERED_TO_COURIER_ON_TIME', 'COURIER_DELAY_DID_NOT_CONNECT',\
143
                              'COURIER_DELAY_CUSTOMER_NOT_AVAILABLE', 'COURIER_DELAY_INCORRECT_ADDRESS',\
144
                              'COURIER_DELAY_OCTROI_DELAY', 'COURIER_DELAY_FORCES_OF_NATURE',\
145
                              'COD_VERIFICATION_DELAY', 'PAYMENT_FLAGGED', 'OTHERS'))
3956 chandransh 146
    cod_reconciliation_timestamp = Field(DateTime)
4247 rajveer 147
    previousStatus = Field(Integer)
4269 anupam.sin 148
    vendorId = Field(Integer)
5302 rajveer 149
    delayReasonText= Field(String(250))
4815 phani.kuma 150
    doa_logistics_provider_id = Field(Integer)
4910 phani.kuma 151
    local_connected_timestamp = Field(DateTime)
152
    reached_destination_timestamp = Field(DateTime)
153
    first_dlvyatmp_timestamp = Field(DateTime)
4303 rajveer 154
    orderInventory = OneToMany("OrderInventory")
5386 phani.kuma 155
    vendor_paid = Field(Boolean, default=0, server_default="0")
5062 varun.gupt 156
    originalOrderId = Field(Integer)
5110 mandeep.dh 157
    fulfilmentWarehouseId = Field(Integer)
5527 anupam.sin 158
    orderType = Field(Integer)
5720 rajveer 159
    pickupStoreId = Field(Integer, default=0, server_default="0")
6525 rajveer 160
    otg = Field(Boolean, default=0, server_default="0")
7033 anupam.sin 161
    insurer = Field(Integer, default=0, server_default="0")
162
    insuranceAmount = Field(Float, default=0, server_default="0")
7190 amar.kumar 163
    freebieItemId = Field(Integer, default=0, server_default="0")
7564 rajveer 164
    source = Field(Integer, default=1, server_default="1")
7293 anupam.sin 165
    storeId = Field(Integer, default=0, server_default="0")
7549 rajveer 166
    advanceAmount = Field(Float, default=0, server_default="0")
8717 amar.kumar 167
    productCondition = Field(Integer, default=0, server_default="0")
9299 kshitij.so 168
    dataProtectionInsurer = Field(Integer, default=0, server_default="0")
169
    dataProtectionAmount = Field(Float, default=0, server_default="0")
9416 amar.kumar 170
    taxType = Field(Integer, default=0, server_default="0")
2628 chandransh 171
    using_options(shortnames=True)
172
    using_table_options(mysql_engine="InnoDB")
5348 anupam.sin 173
 
174
class CodVerificationAgent(Entity):
175
    orderId = Field(Integer, primary_key=True, autoincrement=True)
176
    verificationAgent = Field(String(200))
177
    using_options(shortnames=True)
178
    using_table_options(mysql_engine="InnoDB")
179
 
104 ashish 180
class Transaction(Entity):
483 rajveer 181
    id = Field(Integer, primary_key=True, autoincrement=True)
182
    createdOn = Field(DateTime)
183
    status = Field(Integer)
184
    status_message = Field(String(100))
185
    customer_id = Field(Integer)
186
    shopping_cart_id = Field(Integer)
2815 vikas 187
    session_source = Field(String(100))
188
    session_start_time = Field(DateTime)
3858 vikas 189
    first_source = Field(String(100))
190
    first_source_start_time = Field(DateTime)
483 rajveer 191
    orders = OneToMany("Order")
2219 varun.gupt 192
    coupon_code = Field(String(20))
746 rajveer 193
    using_options(shortnames=True)
194
    using_table_options(mysql_engine="InnoDB")
132 ashish 195
 
4394 rajveer 196
class Alert(Entity):
132 ashish 197
    id = Field(Integer, primary_key=True, autoincrement=True)
483 rajveer 198
    type = Field(Integer)
4394 rajveer 199
    status = Field(Integer)
200
    timestamp = Field(DateTime)
201
    description = Field(String(100))
4444 rajveer 202
    warehouseId = Field(Integer)
746 rajveer 203
    using_options(shortnames=True)
1225 chandransh 204
    using_table_options(mysql_engine="InnoDB")
205
 
206
class BatchNoGenerator(Entity):
207
    id=Field(Integer, primary_key=True)
208
    using_options(shortnames=True)
209
    using_table_options(mysql_engine="InnoDB")
4008 mandeep.dh 210
 
211
class TransactionRequiringExtraProcessing(Entity):
4015 mandeep.dh 212
    transaction_id = Field(Integer, primary_key=True, autoincrement=False)
6733 anupam.sin 213
    category = Field(Enum('COD_VERIFICATION', 'DELAYED_DELIVERY', 'PAYMENT_FLAGGED', 'RECHARGE_UNKNOWN'), primary_key=True, autoincrement=False)
4008 mandeep.dh 214
    using_options(shortnames=True)
215
    using_table_options(mysql_engine="InnoDB")
4303 rajveer 216
 
217
class OrderInventory(Entity):
218
    order = ManyToOne("Order", primary_key=True)
219
    itemId = Field(Integer)
220
    timestamp = Field(DateTime)
221
    hotspotAction = Field(Integer)
222
    estimate = Field(Integer)
223
    using_options(shortnames=True)
224
    using_table_options(mysql_engine="InnoDB")
4600 varun.gupt 225
 
226
class EBSSettlementSummary(Entity):
227
    settlementId = Field(Integer, primary_key = True)
228
    settlementDate = Field(DateTime)
229
    transactionDateFrom = Field(DateTime)
230
    transactionDateTo = Field(DateTime)
5389 phani.kuma 231
    amount = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 232
    detailsUploaded = Field(Boolean)
233
    using_options(shortnames=True)
234
    using_table_options(mysql_engine="InnoDB")
4905 varun.gupt 235
 
4600 varun.gupt 236
class PaymentSettlement(Entity):
4905 varun.gupt 237
    referenceId = Field(Integer)    #PaymentID in case of prepaid & Order Id in case of COD
5386 phani.kuma 238
    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 239
    paymentGatewayId = Field(Integer)
240
    settlementDate = Field(DateTime)
5389 phani.kuma 241
    serviceTax = Field(Numeric(precision=11, scale=3, asdecimal=False))
242
    otherCharges = Field(Numeric(precision=11, scale=3, asdecimal=False))
243
    netCollection = Field(Numeric(precision=11, scale=3, asdecimal=False))
4600 varun.gupt 244
    using_options(shortnames=True)
5527 anupam.sin 245
    using_table_options(mysql_engine="InnoDB")
246
 
247
class Attribute(Entity):
248
    orderId = Field(Integer)
249
    name = Field(String(100))
250
    value = Field(String(100))
251
    using_options(shortnames=True)
6389 rajveer 252
    using_table_options(mysql_engine="InnoDB")
253
 
254
 
255
class EmiScheme(Entity):
256
    id  = Field(Integer, primary_key=True)
257
    gatewayId  = Field(Integer)
258
    bankId = Field(Integer)
259
    tenure = Field(Integer)
6396 amit.gupta 260
    bankName = Field(String(256))
261
    tenureDescription = Field(String(256))
6389 rajveer 262
    minAmount = Field(Integer)
263
    chargeType = Field(Integer)
6409 rajveer 264
    chargeValue = Field(Float)
8942 rajveer 265
    interestRate = Field(Float)
6389 rajveer 266
    using_options(shortnames=True)
267
    using_table_options(mysql_engine="InnoDB")
268
 
269
class MiscCharges(Entity):
270
    transaction = ManyToOne("Transaction", primary_key=True)
6396 amit.gupta 271
    chargeType = Field(Integer, primary_key=True, autoincrement=False)
6389 rajveer 272
    chargeAmount = Field(Float)
273
    using_options(shortnames=True)
6580 anupam.sin 274
    using_table_options(mysql_engine="InnoDB")
275
 
6591 anupam.sin 276
class BlockedIpRange(Entity):
6580 anupam.sin 277
    id = Field(Integer, primary_key=True, autoincrement=True)
6594 anupam.sin 278
    start = Field(BigInteger)
279
    end = Field(BigInteger)
6591 anupam.sin 280
    expiredOn = Field(DateTime)
6580 anupam.sin 281
    using_options(shortnames=True)
6591 anupam.sin 282
    using_table_options(mysql_engine="InnoDB")
283
 
284
class DeniedIpAddress(Entity):
285
    id = Field(Integer, primary_key=True, autoincrement=True)
286
    ip = Field(String(256))
287
    deniedOn = Field(DateTime)
288
    rechargeType = Field(Integer)
289
    deviceNumber = Field(String(128))
290
    using_options(shortnames=True)
6903 anupam.sin 291
    using_table_options(mysql_engine="InnoDB")
292
 
293
class InsuranceDetailForOrder(Entity):
294
    id = Field(Integer, primary_key=True, autoincrement=True)
295
    dob = Field(String(64))
296
    guardianName = Field(String(255))
297
    startDate = Field(DateTime)
298
    expiryDate = Field(DateTime)
6915 anupam.sin 299
    isDeclared = Field(Boolean, default=0)
6903 anupam.sin 300
    order = ManyToOne("Order")
301
    using_options(shortnames=True)
6906 rajveer 302
    using_table_options(mysql_engine="InnoDB")
303
 
6915 anupam.sin 304
    def __init__(self):
305
        self.isDeclared = 0
306
 
9575 kshitij.so 307
class DataInsuranceDetailForOrder(Entity):
308
    id = Field(Integer, primary_key=True, autoincrement=True)
309
    startDate = Field(DateTime)
310
    expiryDate = Field(DateTime)
9608 kshitij.so 311
    isDeclared = Field(Boolean, default=0, server_default="0")
9575 kshitij.so 312
    order = ManyToOne("Order")
313
    using_options(shortnames=True)
314
    using_table_options(mysql_engine="InnoDB")
315
 
6906 rajveer 316
class DocumentStore(Entity):
317
    docType = Field(Integer, primary_key=True, autoincrement=False)
318
    docSource = Field(Integer, primary_key=True, autoincrement=False)
319
    document  = Field(LargeBinary)
320
    using_options(shortnames=True)
7073 anupam.sin 321
    using_table_options(mysql_engine="InnoDB")
322
 
323
class Company(Entity):
324
    id = Field(Integer, primary_key=True, autoincrement=True)
325
    name = Field(String(255))
326
    Address = Field(String(255))
327
    using_options(shortnames=True)
328
    using_table_options(mysql_engine="InnoDB")
329
 
330
class WalletForCompany(Entity):
331
    id = Field(Integer, primary_key=True, autoincrement=True)
332
    companyId = Field(Integer)
7102 rajveer 333
    amount = Field(Integer)
7073 anupam.sin 334
    using_options(shortnames=True)
335
    using_table_options(mysql_engine="InnoDB")
336
 
337
class WalletHistoryForCompany(Entity):
338
    id = Field(Integer, primary_key=True, autoincrement=True)
339
    walletId = Field(Integer)
7102 rajveer 340
    amount = Field(Integer)
7073 anupam.sin 341
    transactionTime = Field(DateTime)
7102 rajveer 342
    openingBal = Field(Integer)
343
    closingBal = Field(Integer)
7073 anupam.sin 344
    referenceNumber = Field(Integer)
345
    description = Field(String(255))
346
    using_options(shortnames=True)
347
    using_table_options(mysql_engine="InnoDB")
348
 
349
class RechargeTransaction(Entity):
350
    id = Field(Integer, primary_key=True, autoincrement=True)
351
    storeId = Field(Integer)
7102 rajveer 352
    amount = Field(Integer)
7073 anupam.sin 353
    transactionTime = Field(DateTime)
7075 rajveer 354
    responseTime = Field(DateTime)
355
    description = Field(String(255))
356
    spiceTID = Field(String(255))
7369 rajveer 357
    aggTID = Field(String(255))
358
    providerTID = Field(String(255))
7075 rajveer 359
    plan = Field(String(255))
7073 anupam.sin 360
    deviceNum = Field(String(64))
361
    deviceType = Field(Integer)
362
    isFrc = Field(Boolean)
363
    email = Field(String(255))
7102 rajveer 364
    discount = Field(Integer)
365
    paymentAmount = Field(Integer)
7145 rajveer 366
    payMethod = Field(Integer, default=0, server_default="0")
7073 anupam.sin 367
    status = Field(Integer)
368
    invoiceNumber = Field(Integer)
369
    circleId = Field(Integer)
7075 rajveer 370
    operatorId = Field(Integer)
7073 anupam.sin 371
    name = Field(String(255))
372
    simNum = Field(String(255))
373
    cafNum = Field(String(255))
7080 anupam.sin 374
    ipAddress = Field(String(255))
375
    alternateNumber = Field(String(255))
7073 anupam.sin 376
    using_options(shortnames=True)
7075 rajveer 377
    using_table_options(mysql_engine="InnoDB")
7076 rajveer 378
 
7120 rajveer 379
class OperatorSeries(Entity):
380
    series = Field(Integer, primary_key=True, autoincrement=False)
381
    operatorId = Field(Integer)
382
    circleId = Field(Integer)
383
    using_options(shortnames=True)
384
    using_table_options(mysql_engine="InnoDB")
385
 
7076 rajveer 386
class FRC(Entity):
387
    id = Field(Integer, primary_key=True)
388
    operatorId = Field(Integer)
389
    circleId = Field(Integer)
390
    denomination = Field(Integer)
391
    maxDiscount = Field(Integer)
392
    using_options(shortnames=True)
393
    using_table_options(mysql_engine="InnoDB")
7120 rajveer 394
 
7075 rajveer 395
class HotspotStore(Entity):
396
    id = Field(Integer, primary_key=True)
397
    hotspotId = Field(String(3))
398
    companyId = Field(Integer)
399
    name = Field(String(100))
400
    city = Field(String(100))
7076 rajveer 401
    collectedAmount = Field(Integer)
7075 rajveer 402
    availableLimit = Field(Integer)
403
    creditLimit = Field(Integer)
404
    salt = Field(String(100))
405
    password = Field(String(100))
406
    isActive = Field(Boolean)
7096 anupam.sin 407
    circleId = Field(Integer)
7169 anupam.sin 408
    email = Field(String(100))
7308 rajveer 409
    line1 = Field(String(100))
410
    line2 = Field(String(100))
411
    state = Field(String(100))
412
    pin = Field(String(10))
413
    phone = Field(String(20))
7423 anupam.sin 414
    tin = Field(String(100))
7308 rajveer 415
    approvalEmail = Field(String(255))
7967 anupam.sin 416
    clusterEmail = Field(String(100))
7075 rajveer 417
    using_options(shortnames=True)
7251 rajveer 418
    using_table_options(mysql_engine="InnoDB")
419
 
420
class RechargeCollection(Entity):
421
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
422
    reconDate = Field(Integer, primary_key=True, autoincrement=False)
423
    cash = Field(Integer)
424
    hdfc = Field(Integer)
425
    grossAmount = Field(Integer)
426
    discount = Field(Integer)
427
    netCollection = Field(Integer)
428
    addedAt = Field(DateTime)
429
    pushedAt = Field(DateTime)
430
    pushedToOcr = Field(Boolean)
431
    using_options(shortnames=True)
432
    using_table_options(mysql_engine="InnoDB")
7406 rajveer 433
 
434
class StoreOrderCollection(Entity):
435
    hotspotId = Field(String(3), primary_key=True, autoincrement=False)
436
    orderId = Field(Integer, primary_key=True, autoincrement=False)
437
    collectionType = Field(String(255), primary_key=True, autoincrement=False)
438
    productName = Field(String(255))
439
    advanceAmount = Field(Integer)
440
    cash = Field(Integer)
441
    card = Field(Integer)
442
    addedAt = Field(DateTime)
443
    pushedAt = Field(DateTime)
444
    pushedToOcr = Field(Boolean)
445
    using_options(shortnames=True)
446
    using_table_options(mysql_engine="InnoDB")
7263 anupam.sin 447
 
448
class SourceDetail(Entity):
449
    id = Field(Integer, primary_key=True, autoincrement=False)
450
    name = Field(String(255))
451
    email = Field(String(255))
7410 amar.kumar 452
    tinNumber = Field(String(255))
7530 kshitij.so 453
    lastUpdatedOn = Field(DateTime)
7263 anupam.sin 454
    using_options(shortnames=True)
7311 kshitij.so 455
    using_table_options(mysql_engine="InnoDB")
456
 
457
class AmazonOrder(Entity):
458
    orderId = Field(Integer, primary_key=True, autoincrement=False)
7322 vikram.rag 459
    amazonOrderCode = Field(String(255))
460
    amazonOrderItemCode = Field(String(255))
7311 kshitij.so 461
    transactionId = Field(Integer)
462
    item_id = Field(Integer)
7322 vikram.rag 463
    status = Field(String(50))
7715 vikram.rag 464
    purchaseDateOnAmazon = Field(DateTime)
7311 kshitij.so 465
    using_options(shortnames=True)
7386 anupam.sin 466
    using_table_options(mysql_engine="InnoDB")
467
 
468
class StoreOrderDetail(Entity):
469
    orderId = Field(Integer, primary_key=True, autoincrement=False)
470
    storeId = Field(Integer, primary_key=True, autoincrement=False)
471
    advanceAmount = Field(Float)
472
    cashAmount = Field(Float)
473
    cardAmount = Field(Float)
474
    payStatus = Field(Integer)
7393 anupam.sin 475
    edcBank = Field(String(100))
476
    cashRefundAmount = Field(Float)
477
    cardRefundAmount = Field(Float)
7423 anupam.sin 478
    approvalCode = Field(String(100))
7611 anupam.sin 479
    cardType = Field(String(100))
7386 anupam.sin 480
    using_options(shortnames=True)
481
    using_table_options(mysql_engine="InnoDB")
482
 
483
class EdcBank(Entity):
484
    id = Field(Integer, primary_key=True, autoincrement=True)
485
    name = Field(String(255))
486
    using_options(shortnames=True)
7967 anupam.sin 487
    using_table_options(mysql_engine="InnoDB")
488
 
489
class HotspotServiceMatrix(Entity): 
490
    storeId = Field(Integer, primary_key=True)
491
    hotspotId = Field(String(3))
492
    rechargeService = Field(Boolean, default=0, server_default="0")
493
    storeWebsiteService = Field(Boolean, default=0, server_default="0")
494
    pickupFromStoreService = Field(Boolean, default=0, server_default="0")
495
    using_options(shortnames=True)
8182 amar.kumar 496
    using_table_options(mysql_engine="InnoDB")
497
 
498
class  EbayOrder(Entity):
499
    orderId = Field(Integer, primary_key=True, autoincrement=False)
500
    salesRecordNumber = Field(Integer)
501
    paisaPayId = Field(String(32))
502
    ebayListingId = Field(String(32))
503
    subsidyAmount = Field(Float)
504
    ebayTxnDate = Field(DateTime)
505
    transactionId = Field(String(16))
506
    listingName = Field(String(128))
507
    listingPrice = Field(Float)
8247 amar.kumar 508
    bluedartPaisaPayRef = Field(String(16))
8182 amar.kumar 509
    using_options(shortnames=True)
510
    using_table_options(mysql_engine="InnoDB")
8488 amar.kumar 511
 
512
class  SnapdealOrder(Entity):
11423 vikram.rag 513
    orderId = Field(Integer)
11422 vikram.rag 514
    subOrderId = Field(String(32), primary_key=True, autoincrement=False)
515
    referenceCode = Field(String(32),primary_key=True, autoincrement=False)
8488 amar.kumar 516
    snapdealTxnDate = Field(DateTime)
517
    productName = Field(String(128))
518
    listingPrice = Field(Float)
9456 vikram.rag 519
    maxNlc = Field(Float)
8488 amar.kumar 520
    using_options(shortnames=True)
521
    using_table_options(mysql_engine="InnoDB")
8282 kshitij.so 522
 
523
class AmazonFbaSalesSnapshot(Entity):
524
    dateOfSale = Field(Date, primary_key=True)
8363 vikram.rag 525
    item_id = Field(Integer, primary_key=True,autoincrement=False)
526
    totalOrderCount = Field(Integer)
8282 kshitij.so 527
    amazonFbaInventory = Field(Integer)
528
    isOutOfStock = Field(Boolean)
529
    salePrice = Field(Float)
8445 vikram.rag 530
    ourPrice = Field(Float)
8282 kshitij.so 531
    minFbaPrice = Field(Float)
8363 vikram.rag 532
    minMfnPrice = Field(Float)
8542 vikram.rag 533
    totalSale = Field(Numeric(precision=11, scale=3, asdecimal=False))
534
    promotionSale =  Field(Numeric(precision=11, scale=3, asdecimal=False))
8363 vikram.rag 535
    promotionOrderCount = Field(Integer)
8532 vikram.rag 536
    ourPriceSnapshotDate  =  Field(DateTime)
537
    salePriceSnapshotDate  = Field(DateTime)
538
    minMfnPriceSnapshotDate = Field(DateTime)
539
    minFbaPriceSnapshotDate = Field(DateTime)
11173 vikram.rag 540
    fcLocation = Field(Integer, primary_key=True,autoincrement=False)
8282 kshitij.so 541
    using_options(shortnames=True)
8921 anupam.sin 542
    using_table_options(mysql_engine="InnoDB")
543
 
544
class SpiceTransactionHistory(Entity):
545
    orderId = Field(Integer, primary_key=True, autoincrement=False)
546
    spiceTID = Field(String(32))
547
    reponseCode = Field(String(32))
548
    rechargeTime = Field(DateTime)
8923 anupam.sin 549
    reconciliationTime = Field(DateTime)
8922 anupam.sin 550
    using_options(shortnames=True)
8961 vikram.rag 551
    using_table_options(mysql_engine="InnoDB")
552
 
553
class FlipkartOrder(Entity):   
11423 vikram.rag 554
    orderId = Field(Integer)
11422 vikram.rag 555
    flipkartSubOrderId = Field(String(30),primary_key=True, autoincrement=False)
556
    flipkartOrderId = Field(String(30),primary_key=True, autoincrement=False)
8961 vikram.rag 557
    flipkartTxnDate = Field(DateTime)
558
    shippingPrice = Field(Float)
559
    octroiFee = Field(Float)
560
    emiFee = Field(Float)
9456 vikram.rag 561
    maxNlc = Field(Float)
8961 vikram.rag 562
    using_options(shortnames=True)
563
    using_table_options(mysql_engine="InnoDB")
12103 manish.sha 564
 
565
class AmazonFbaOrderReturns(Entity):
566
    amazonOrderId = Field(String(30),primary_key=True, autoincrement=False)
567
    insertionTimestamp = Field(DateTime, primary_key=True, autoincrement=False)
568
    sku = Field(Integer, primary_key=True, autoincrement=False)
569
    creationTimestamp = Field(DateTime)    
570
    shippedQuantity = Field(Integer)
571
    sellableReturnQuantity = Field(Integer)
572
    nonSellableReturnQuantity = Field(Integer)
573
    using_options(shortnames=True)
574
    using_table_options(mysql_engine="InnoDB")
12772 manish.sha 575
 
576
class FlipkartAdvantageOrder(Entity):
577
    fkOrderId = Field(String(30),primary_key=True, autoincrement=False)
578
    fkOrderItemId = Field(String(30),primary_key=True, autoincrement=False)
579
    sku = Field(Integer)
580
    creationTimestamp = Field(DateTime)
581
    customerName = Field(String(50))
582
    customerAddress = Field(String(500))
583
    pincode = Field(String(10))
584
    customerCity = Field(String(30))
585
    customerState = Field(String(30))
586
    customerPhone = Field(String(30))
587
    status = Field(String(20))
588
    quantity = Field(Integer)
589
    totalPrice = Field(Float)
590
    listPrice = Field(Float)
591
    modifiedDate = Field(DateTime)
592
    listingId = Field(String(50))
593
    cancelReason = Field(String(100))
594
    returnReason = Field(String(100))
12779 manish.sha 595
    freebieItemId = Field(String(20))
12772 manish.sha 596
    productTitle = Field(String(200))
597
    using_options(shortnames=True)
598
    using_table_options(mysql_engine="InnoDB")