Subversion Repositories SmartDukaan

Rev

Rev 15251 | Rev 18590 | 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")
557 chandransh 106
    using_options(shortnames=True)
746 rajveer 107
    using_table_options(mysql_engine="InnoDB")
130 ashish 108
 
3554 varun.gupt 109
class Discount(Entity):
110
    line = ManyToOne("Line", primary_key=True)
111
    discount = Field(Float, primary_key = True)
112
    quantity = Field(Float)
113
    using_options(shortnames = True)
114
    using_table_options(mysql_engine = 'InnoDB')
115
 
557 chandransh 116
#===============================================================================
1976 varun.gupt 117
# Entity generated from Promotion Service
118
#===============================================================================
119
class Promotion(Entity):
120
    id = Field(Integer, primary_key = True, autoincrement = True)
121
    name = Field(String(200))
122
    rule_execution_src = Field(String(100))
123
    start_on = Field(DateTime)
124
    end_on = Field(DateTime)
125
    coupons = OneToMany("Coupon")
126
    created_on = Field(DateTime)
6367 amit.gupta 127
    type = Field(Integer)
1976 varun.gupt 128
    using_options(shortnames = True)
129
    using_table_options(mysql_engine = "InnoDB")
11653 amit.gupta 130
 
131
class PrivateDealUser(Entity):
132
    id = Field(Integer, primary_key=True)
12696 amit.gupta 133
    counter = ManyToOne("Counter")
134
    tin = Field(String(20))
11653 amit.gupta 135
    created_on = Field(DateTime)
136
    isActive = Field(Boolean)
13400 manish.sha 137
    bulkShipmentAmountLimit = Field(Float, default=50000)
11657 amit.gupta 138
    using_options(shortnames = True)
139
    using_table_options(mysql_engine = "InnoDB")
1976 varun.gupt 140
 
141
class Coupon(Entity):
142
    coupon_code = Field(String(20))
143
    promotion = ManyToOne("Promotion")
144
    arguments = Field(String(200))
8707 manish.sha 145
    coupon_category = Field(Enum('CUSTOMER_SATISFACTION','MARKETING','REFUND'))
1976 varun.gupt 146
    using_options(shortnames = True)
147
    using_table_options(mysql_engine = "InnoDB")
148
 
149
class PromotionTracker(Entity):
150
    coupon_code = Field(String(20))
151
    transaction_id = Field(Integer)
152
    user_id = Field(Integer)
153
    applied_on = Field(DateTime)
7987 amit.gupta 154
    promotion_id = Field(Integer)
13521 amit.gupta 155
    amount = Field(Integer)
156
    is_digital  = Field(Boolean)
1976 varun.gupt 157
    using_options(shortnames = True)
158
    using_table_options(mysql_engine = "InnoDB")
5469 rajveer 159
 
160
class RechargeVoucher(Entity):
161
    id = Field(Integer, primary_key = True, autoincrement = True)
162
    voucherCode = Field(String(30))
163
    voucherType = Field(Integer)
164
    amount = Field(Numeric(precision=8, scale=2, asdecimal=False))
165
    available = Field(Boolean)
166
    issuedOn = Field(DateTime)
167
    expiredOn = Field(DateTime)
168
    redeemed = Field(Boolean)
169
    redeemedOn = Field(DateTime)
170
    email = Field(String(100))
171
    userId = Field(Integer)
172
    using_options(shortnames = True)
173
    using_table_options(mysql_engine = "InnoDB")
1976 varun.gupt 174
 
175
#===============================================================================
1273 varun.gupt 176
# Entity generated from Contact Us form
177
#===============================================================================
178
class UserCommunication(Entity):
179
    id = Field(Integer, primary_key = True, autoincrement = True)
180
    user_id = Field(Integer)
181
    communication_type = Field(Integer)
182
    order_id = Field(Integer)
183
    airwaybill_no = Field(String(50))
184
    reply_to = Field(String(50))
185
    product_name = Field(String(200))
186
    subject = Field(String(200))
187
    message = Field(String(600))
1301 varun.gupt 188
    communication_timestamp = Field(DateTime)
1273 varun.gupt 189
    using_options(shortnames = True)
190
    using_table_options(mysql_engine = "InnoDB")
191
 
192
#===============================================================================
557 chandransh 193
# Different entities for the Widget service
194
#===============================================================================
195
 
2981 rajveer 196
class UserWidgetItem(Entity):
197
    userId = Field(Integer, primary_key=True)
198
    widgetId = Field(Integer, primary_key=True)
199
    itemId = Field(Integer, primary_key=True)
200
    addedOn = Field(DateTime)
557 chandransh 201
    using_options(shortnames=True)    
746 rajveer 202
    using_table_options(mysql_engine="InnoDB")
130 ashish 203
 
1845 vikas 204
class MasterAffiliate(Entity):
205
    id = Field(Integer, primary_key=True, autoincrement=True)
206
    name = Field(String(100), unique=True)
1859 vikas 207
    added_on = Field(DateTime)
1845 vikas 208
    affiliates = OneToMany("Affiliate")
209
    using_options(shortnames=True)
210
    using_table_options(mysql_engine="InnoDB")
211
 
212
class Affiliate(Entity):
213
    id = Field(Integer, primary_key=True, autoincrement=True)
214
    master_affiliate = ManyToOne("MasterAffiliate")
215
    name = Field(String(100), unique=True)
216
    url = Field(String(200))
1859 vikas 217
    added_on = Field(DateTime)
1996 vikas 218
    tracklogs = OneToMany("TrackLog")
1845 vikas 219
    using_options(shortnames=True)
220
    using_table_options(mysql_engine="InnoDB")
221
 
222
class Tracker(Entity):
223
    id = Field(Integer, primary_key=True, autoincrement=True)
2004 vikas 224
    affiliate_id = Field(Integer)
225
    added_on = Field(DateTime)
1845 vikas 226
    using_options(shortnames=True)
227
    using_table_options(mysql_engine="InnoDB")
228
 
229
class TrackLog(Entity):
230
    id = Field(Integer, primary_key=True, autoincrement=True)
1859 vikas 231
    added_on = Field(DateTime)
1996 vikas 232
    affiliate = ManyToOne("Affiliate")
1845 vikas 233
    user_id = Field(Integer)
234
    event = Field(String(100))
3378 vikas 235
    event_id = Field(Integer)
1845 vikas 236
    url = Field(String(200))
237
    data = Field(String(200))
238
    using_options(shortnames=True)
239
    using_table_options(mysql_engine="InnoDB")
240
 
6903 anupam.sin 241
class InsuranceDetails(Entity):
242
    id = Field(Integer, primary_key=True, autoincrement=True)
243
    addressId = Field(Integer)
244
    dob = Field(String(64))
245
    guardianName = Field(String(255))
246
    using_options(shortnames=True)
247
    using_table_options(mysql_engine="InnoDB")
12696 amit.gupta 248
 
249
class Counter(Entity):
250
    id = Field(Integer, primary_key=True, autoincrement=True)
251
    code = Field(String(10),unique=True)
252
    dealUsers = OneToMany("PrivateDealUser")
253
    name = Field(String(128))
254
    ownerName = Field(String(100))
255
    email = Field(String(80))
256
    mobile = Field(String(10))
257
    alternateMobile = Field(String(10))
258
    addressId = Field(Integer)
259
    striker = Field(Boolean)
260
    tin = Field(String(20), unique=True)
261
    spCounterSize = Field(Integer)
262
    fpCounterSize = Field(Integer)
12722 amit.gupta 263
    dob = Field(String(20))
12696 amit.gupta 264
    createdOn = Field(DateTime)
12730 amit.gupta 265
    lastPurchasedOn = Field(DateTime)
18530 manish.sha 266
    documentVerified = Field(Boolean)
267
    verificationType = Field(Integer)
268
    verifiedOn = Field(DateTime)
12696 amit.gupta 269
    using_options(shortnames=True)
270
    using_table_options(mysql_engine="InnoDB")
15251 manish.sha 271
 
18530 manish.sha 272
class CounterOnlineInfo(Entity):
273
    counterId = Field(Integer, primary_key=True)
274
    tinNumber = Field(String(30))
275
    cstNumber = Field(String(30))
276
    dealerName = Field(String(100))
277
    dealerAddress = Field(Text)
278
    state = Field(String(20))
279
    pan = Field(String(20))
280
    registrationDate = Field(DateTime)
281
    registrationStatus = Field(Boolean)
282
    validatedTill = Field(DateTime)
283
    using_options(shortnames=True)
284
    using_table_options(mysql_engine="InnoDB")
285
 
15251 manish.sha 286
class AccessTokenizer(Entity):
287
    id = Field(Integer, primary_key=True, autoincrement=True)
288
    userId = Field(Integer)
289
    source = Field(String(50))
290
    tokenString = Field(String(50))
291
    expiredTime = Field(DateTime)
292
    expired = Field(Boolean)
293
    using_options(shortnames=True)
294
    using_table_options(mysql_engine="InnoDB")
6903 anupam.sin 295
 
3187 rajveer 296
def initialize(dbname='user', db_hostname="localhost"):
772 rajveer 297
    #metadata.bind = "sqlite:///user.sqlite" #need to read it from configserver.
5283 mandeep.dh 298
    engine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200, max_overflow=20)
1122 chandransh 299
    metadata.bind = engine
12730 amit.gupta 300
    metadata.bind.echo = True
772 rajveer 301
    setup_all(True)
302
 
303
if __name__=="__main__":
304
    initialize()