Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
130 ashish 1
'''
2
Created on 28-Apr-2010
3
 
4
@author: ashish
5
'''
6
 
7
from elixir import *
8
from elixir.entity import Entity
9
from elixir.fields import Field
12696 amit.gupta 10
from elixir.relationships import OneToMany, ManyToOne
1122 chandransh 11
from sqlalchemy import create_engine
12696 amit.gupta 12
from sqlalchemy.types import Integer, Integer, String, Float, DateTime, Boolean, \
13
    Enum, Numeric, BigInteger, LargeBinary, Date
130 ashish 14
import datetime
746 rajveer 15
import elixir
130 ashish 16
 
17
class Address(Entity):
18
    id = Field(Integer, primary_key=True, autoincrement=True)
19
    line_1 = Field(String(100))
20
    line_2 = Field(String(100))
21
    landmark = Field(String(100))
22
    city = Field(String(100))
23
    state = Field(String(100))
24
    pin = Field(String(10))
25
    country = Field(String(100))
26
    enabled = Field(Boolean)
27
    type = Field(Integer)
28
    added_on = Field(DateTime)
414 ashish 29
    name = Field(String(100))
30
    phone = Field(String(20))
557 chandransh 31
    user = ManyToOne("User")
32
    using_options(shortnames=True)
746 rajveer 33
    using_table_options(mysql_engine="InnoDB")
557 chandransh 34
 
35
class User(Entity):
36
    id = Field(Integer, primary_key=True, autoincrement=True)
130 ashish 37
    email = Field(String(100))
38
    password = Field(String(50))
557 chandransh 39
    name = Field(String(150))
504 rajveer 40
    default_address_id = Field(Integer)
41
    communication_email = Field(String(100))
5326 rajveer 42
    active_cart = ManyToOne("Cart")
557 chandransh 43
    jsession_id = Field(String(64))
44
    is_anonymous = Field(Boolean)
567 rajveer 45
    date_of_birth = Field(String(20))
557 chandransh 46
    sex = Field(Integer)
567 rajveer 47
    mobile_number = Field(String(20))
2020 vikas 48
    source = Field(String(200))
2815 vikas 49
    source_start_time = Field(DateTime)
3499 mandeep.dh 50
    trust_level = Field(Float)
5326 rajveer 51
    last_login = Field(DateTime)
52
    last_logout = Field(DateTime)
53
    active_since = Field(DateTime)
7883 rajveer 54
    fbusers = OneToMany("FacebookUser")
55
    addresses = OneToMany("Address")
8201 rajveer 56
    sources = OneToMany("UserSource")
7883 rajveer 57
    using_options(shortnames=True)
58
    using_table_options(mysql_engine="InnoDB")
59
 
60
class FacebookUser(Entity):
61
    user = ManyToOne("User", primary_key=True)
7825 amar.kumar 62
    facebook_access_token = Field(String(200))
63
    facebook_id = Field(String(50))
557 chandransh 64
    using_options(shortnames=True)
746 rajveer 65
    using_table_options(mysql_engine="InnoDB")
557 chandransh 66
 
8201 rajveer 67
class UserSource(Entity):
68
    user = ManyToOne("User", primary_key=True)
69
    source_id = Field(Integer)
70
    using_options(shortnames=True)
71
    using_table_options(mysql_engine="InnoDB")
72
 
557 chandransh 73
class Line(Entity):
643 chandransh 74
    cart = ManyToOne("Cart", primary_key=True)
746 rajveer 75
    item_id = Field(Integer, primary_key=True, autoincrement=False)
557 chandransh 76
    quantity = Field(Float)
77
    line_status = Field(Integer)
612 chandransh 78
    estimate = Field(Integer)
557 chandransh 79
    created_on = Field(DateTime)
80
    updated_on = Field(DateTime)
1976 varun.gupt 81
    actual_price = Field(Float)
82
    discounted_price = Field(Float)
3554 varun.gupt 83
    discounts = OneToMany('Discount')
6903 anupam.sin 84
    insurer = Field(Integer)
85
    insuranceAmount = Field(Float)
9300 kshitij.so 86
    dataProtectionInsurer =Field(Integer, default=0, server_default="0")
87
    dataProtectionAmount = Field(Float, default=0, server_default="0")
11653 amit.gupta 88
    dealText=Field(String(200))
89
    freebieId=Field(Integer)
557 chandransh 90
    using_options(shortnames=True)
746 rajveer 91
    using_table_options(mysql_engine="InnoDB")
504 rajveer 92
 
557 chandransh 93
class Cart(Entity):
130 ashish 94
    id = Field(Integer, primary_key=True, autoincrement=True)
557 chandransh 95
    cart_status = Field(Integer)
96
    address_id = Field(Integer)
5555 rajveer 97
    pickupStoreId = Field(Integer)
690 chandransh 98
    checked_out_on = Field(DateTime)
557 chandransh 99
    created_on = Field(DateTime)
100
    updated_on = Field(DateTime)
564 chandransh 101
    lines = OneToMany("Line")
1976 varun.gupt 102
    total_price = Field(Float)
103
    discounted_price = Field(Float)
104
    coupon_code = Field(String(20))
13139 amit.gupta 105
    user = OneToMany("User")
20873 kshitij.so 106
    wallet_amount = Field(Float, default=0, server_default="0")
557 chandransh 107
    using_options(shortnames=True)
746 rajveer 108
    using_table_options(mysql_engine="InnoDB")
130 ashish 109
 
3554 varun.gupt 110
class Discount(Entity):
111
    line = ManyToOne("Line", primary_key=True)
112
    discount = Field(Float, primary_key = True)
113
    quantity = Field(Float)
114
    using_options(shortnames = True)
115
    using_table_options(mysql_engine = 'InnoDB')
116
 
557 chandransh 117
#===============================================================================
1976 varun.gupt 118
# Entity generated from Promotion Service
119
#===============================================================================
120
class Promotion(Entity):
121
    id = Field(Integer, primary_key = True, autoincrement = True)
122
    name = Field(String(200))
123
    rule_execution_src = Field(String(100))
124
    start_on = Field(DateTime)
125
    end_on = Field(DateTime)
126
    coupons = OneToMany("Coupon")
127
    created_on = Field(DateTime)
6367 amit.gupta 128
    type = Field(Integer)
1976 varun.gupt 129
    using_options(shortnames = True)
130
    using_table_options(mysql_engine = "InnoDB")
11653 amit.gupta 131
 
132
class PrivateDealUser(Entity):
133
    id = Field(Integer, primary_key=True)
12696 amit.gupta 134
    counter = ManyToOne("Counter")
135
    tin = Field(String(20))
11653 amit.gupta 136
    created_on = Field(DateTime)
137
    isActive = Field(Boolean)
13400 manish.sha 138
    bulkShipmentAmountLimit = Field(Float, default=50000)
18590 manish.sha 139
    creditorAssigned = Field(Boolean)
18735 manish.sha 140
    tinVerified = Field(Boolean)
11657 amit.gupta 141
    using_options(shortnames = True)
142
    using_table_options(mysql_engine = "InnoDB")
1976 varun.gupt 143
 
144
class Coupon(Entity):
145
    coupon_code = Field(String(20))
146
    promotion = ManyToOne("Promotion")
147
    arguments = Field(String(200))
8707 manish.sha 148
    coupon_category = Field(Enum('CUSTOMER_SATISFACTION','MARKETING','REFUND'))
1976 varun.gupt 149
    using_options(shortnames = True)
150
    using_table_options(mysql_engine = "InnoDB")
151
 
152
class PromotionTracker(Entity):
153
    coupon_code = Field(String(20))
154
    transaction_id = Field(Integer)
155
    user_id = Field(Integer)
156
    applied_on = Field(DateTime)
7987 amit.gupta 157
    promotion_id = Field(Integer)
13521 amit.gupta 158
    amount = Field(Integer)
159
    is_digital  = Field(Boolean)
1976 varun.gupt 160
    using_options(shortnames = True)
161
    using_table_options(mysql_engine = "InnoDB")
5469 rajveer 162
 
163
class RechargeVoucher(Entity):
164
    id = Field(Integer, primary_key = True, autoincrement = True)
165
    voucherCode = Field(String(30))
166
    voucherType = Field(Integer)
167
    amount = Field(Numeric(precision=8, scale=2, asdecimal=False))
168
    available = Field(Boolean)
169
    issuedOn = Field(DateTime)
170
    expiredOn = Field(DateTime)
171
    redeemed = Field(Boolean)
172
    redeemedOn = Field(DateTime)
173
    email = Field(String(100))
174
    userId = Field(Integer)
175
    using_options(shortnames = True)
176
    using_table_options(mysql_engine = "InnoDB")
1976 varun.gupt 177
 
178
#===============================================================================
1273 varun.gupt 179
# Entity generated from Contact Us form
180
#===============================================================================
181
class UserCommunication(Entity):
182
    id = Field(Integer, primary_key = True, autoincrement = True)
183
    user_id = Field(Integer)
184
    communication_type = Field(Integer)
185
    order_id = Field(Integer)
186
    airwaybill_no = Field(String(50))
187
    reply_to = Field(String(50))
188
    product_name = Field(String(200))
189
    subject = Field(String(200))
190
    message = Field(String(600))
1301 varun.gupt 191
    communication_timestamp = Field(DateTime)
1273 varun.gupt 192
    using_options(shortnames = True)
193
    using_table_options(mysql_engine = "InnoDB")
194
 
195
#===============================================================================
557 chandransh 196
# Different entities for the Widget service
197
#===============================================================================
198
 
2981 rajveer 199
class UserWidgetItem(Entity):
200
    userId = Field(Integer, primary_key=True)
201
    widgetId = Field(Integer, primary_key=True)
202
    itemId = Field(Integer, primary_key=True)
203
    addedOn = Field(DateTime)
557 chandransh 204
    using_options(shortnames=True)    
746 rajveer 205
    using_table_options(mysql_engine="InnoDB")
130 ashish 206
 
1845 vikas 207
class MasterAffiliate(Entity):
208
    id = Field(Integer, primary_key=True, autoincrement=True)
209
    name = Field(String(100), unique=True)
1859 vikas 210
    added_on = Field(DateTime)
1845 vikas 211
    affiliates = OneToMany("Affiliate")
212
    using_options(shortnames=True)
213
    using_table_options(mysql_engine="InnoDB")
214
 
215
class Affiliate(Entity):
216
    id = Field(Integer, primary_key=True, autoincrement=True)
217
    master_affiliate = ManyToOne("MasterAffiliate")
218
    name = Field(String(100), unique=True)
219
    url = Field(String(200))
1859 vikas 220
    added_on = Field(DateTime)
1996 vikas 221
    tracklogs = OneToMany("TrackLog")
1845 vikas 222
    using_options(shortnames=True)
223
    using_table_options(mysql_engine="InnoDB")
224
 
225
class Tracker(Entity):
226
    id = Field(Integer, primary_key=True, autoincrement=True)
2004 vikas 227
    affiliate_id = Field(Integer)
228
    added_on = Field(DateTime)
1845 vikas 229
    using_options(shortnames=True)
230
    using_table_options(mysql_engine="InnoDB")
231
 
232
class TrackLog(Entity):
233
    id = Field(Integer, primary_key=True, autoincrement=True)
1859 vikas 234
    added_on = Field(DateTime)
1996 vikas 235
    affiliate = ManyToOne("Affiliate")
1845 vikas 236
    user_id = Field(Integer)
237
    event = Field(String(100))
3378 vikas 238
    event_id = Field(Integer)
1845 vikas 239
    url = Field(String(200))
240
    data = Field(String(200))
241
    using_options(shortnames=True)
242
    using_table_options(mysql_engine="InnoDB")
243
 
6903 anupam.sin 244
class InsuranceDetails(Entity):
245
    id = Field(Integer, primary_key=True, autoincrement=True)
246
    addressId = Field(Integer)
247
    dob = Field(String(64))
248
    guardianName = Field(String(255))
249
    using_options(shortnames=True)
250
    using_table_options(mysql_engine="InnoDB")
12696 amit.gupta 251
 
252
class Counter(Entity):
253
    id = Field(Integer, primary_key=True, autoincrement=True)
254
    code = Field(String(10),unique=True)
255
    dealUsers = OneToMany("PrivateDealUser")
256
    name = Field(String(128))
257
    ownerName = Field(String(100))
258
    email = Field(String(80))
259
    mobile = Field(String(10))
260
    alternateMobile = Field(String(10))
261
    addressId = Field(Integer)
262
    striker = Field(Boolean)
263
    tin = Field(String(20), unique=True)
264
    spCounterSize = Field(Integer)
265
    fpCounterSize = Field(Integer)
12722 amit.gupta 266
    dob = Field(String(20))
12696 amit.gupta 267
    createdOn = Field(DateTime)
12730 amit.gupta 268
    lastPurchasedOn = Field(DateTime)
18530 manish.sha 269
    documentVerified = Field(Boolean)
270
    verificationType = Field(Integer)
271
    verifiedOn = Field(DateTime)
12696 amit.gupta 272
    using_options(shortnames=True)
273
    using_table_options(mysql_engine="InnoDB")
15251 manish.sha 274
 
18530 manish.sha 275
class CounterOnlineInfo(Entity):
276
    counterId = Field(Integer, primary_key=True)
277
    tinNumber = Field(String(30))
278
    cstNumber = Field(String(30))
279
    dealerName = Field(String(100))
280
    dealerAddress = Field(Text)
281
    state = Field(String(20))
282
    pan = Field(String(20))
283
    registrationDate = Field(DateTime)
284
    registrationStatus = Field(Boolean)
285
    validatedTill = Field(DateTime)
18634 manish.sha 286
    created = Field(DateTime,default = datetime.datetime.now)
18530 manish.sha 287
    using_options(shortnames=True)
288
    using_table_options(mysql_engine="InnoDB")
289
 
18735 manish.sha 290
class PrivateDealUserAddressMapping(Entity):
18736 manish.sha 291
    user_id = Field(Integer, primary_key=True, autoincrement=False)
292
    address_id = Field(Integer, primary_key=True, autoincrement=False)
18735 manish.sha 293
    taxInvoiceAvailable = Field(Boolean)
294
    creditOptionAvailable = Field(Boolean)
295
    createdAt = Field(DateTime,default = datetime.datetime.now)
296
    using_options(shortnames=True)
297
    using_table_options(mysql_engine="InnoDB")
298
 
15251 manish.sha 299
class AccessTokenizer(Entity):
300
    id = Field(Integer, primary_key=True, autoincrement=True)
301
    userId = Field(Integer)
302
    source = Field(String(50))
303
    tokenString = Field(String(50))
304
    expiredTime = Field(DateTime)
305
    expired = Field(Boolean)
306
    using_options(shortnames=True)
307
    using_table_options(mysql_engine="InnoDB")
6903 anupam.sin 308
 
19236 manish.sha 309
def initialize(dbname='user', db_hostname="localhost", setup=True):
772 rajveer 310
    #metadata.bind = "sqlite:///user.sqlite" #need to read it from configserver.
5283 mandeep.dh 311
    engine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200, max_overflow=20)
1122 chandransh 312
    metadata.bind = engine
12730 amit.gupta 313
    metadata.bind.echo = True
19236 manish.sha 314
    setup_all(setup)
772 rajveer 315
 
316
if __name__=="__main__":
317
    initialize()