Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
5944 mandeep.dh 1
'''
2
Created on 22-Mar-2010
3
 
4
@author: ashish
5
'''
6
from elixir import metadata, setup_all
7
from elixir.entity import Entity
8
from elixir.fields import Field
9
from elixir.options import using_options, using_table_options
10
from elixir.relationships import OneToMany, ManyToOne
11
from sqlalchemy import create_engine
8491 rajveer 12
from sqlalchemy.types import Integer, String, DateTime, Float, Boolean, Enum, Date
5944 mandeep.dh 13
import datetime
14
 
15
class Vendor(Entity):
16
    id = Field(Integer, primary_key=True, autoincrement=True)
17
    name = Field(String(50))
18
    warehouses = OneToMany('Warehouse')
19
    using_options(shortnames=True)
20
    using_table_options(mysql_engine="InnoDB")
6498 vikram.rag 21
 
6531 vikram.rag 22
class IgnoredInventoryUpdateItems(Entity):
6498 vikram.rag 23
    warehouse_id = Field(Integer,primary_key=True,autoincrement=False)
24
    item_id = Field(Integer,primary_key=True,autoincrement=False)
25
    using_options(shortnames=True)
26
    using_table_options(mysql_engine="InnoDB")
5944 mandeep.dh 27
 
7330 amit.gupta 28
class StateMaster(Entity):
29
    id = Field(Integer, primary_key=True, autoincrement=False)
30
    name= Field(String(100))
12280 amit.gupta 31
    vatType = Field(Integer)
7330 amit.gupta 32
    using_options(shortnames=True)
33
    using_table_options(mysql_engine="InnoDB")
34
 
5944 mandeep.dh 35
class Warehouse(Entity):
36
    id = Field(Integer, primary_key=True, autoincrement=True)
37
    displayName = Field(String(50))
38
    location = Field(String(200))
39
    status = Field(Integer)
40
    addedOn = Field(DateTime)
41
    lastCheckedOn = Field(DateTime)
42
    tinNumber = Field(String(50))
43
    pincode = Field(String(10))
44
    vendorString = Field(String(50))
45
    badInventory = OneToMany('BadInventorySnapshot')
46
    inventory = OneToMany('CurrentInventorySnapshot')
47
    inventoryHistory = OneToMany('ItemInventoryHistory')
7330 amit.gupta 48
    state = ManyToOne('StateMaster') 
5944 mandeep.dh 49
    logisticsLocation = Field(Integer)
50
    vendor = ManyToOne('Vendor')
51
    billingType = Field(Integer)
52
    inventoryType = Field(Enum('GOOD', 'BAD', 'VIRTUAL'))
53
    warehouseType = Field(Enum('OURS', 'THIRD_PARTY'))
54
    shippingWarehouseId = Field(Integer)
55
    billingWarehouseId = Field(Integer)
56
    transferDelayInHours = Field(Integer)
57
    isAvailabilityMonitored = Field(Boolean)
58
    using_options(shortnames=True)
59
    using_table_options(mysql_engine="InnoDB")
60
 
61
    def __repr__(self):
62
        return "<warehouse>%s</warehouse>" %(self.location)
63
 
64
class VendorItemMapping(Entity):
65
    vendor = ManyToOne('Vendor', primary_key=True)
66
    item_key = Field(String(200), primary_key=True)
67
    item_id = Field(Integer)
68
    using_options(shortnames=True)
69
    using_table_options(mysql_engine="InnoDB")
70
 
71
class VendorItemPricing(Entity):
72
    vendor = ManyToOne('Vendor', primary_key=True)
73
    item_id = Field(Integer, primary_key=True)
74
    mop = Field(Float)
75
    dealerPrice = Field(Float)
76
    transfer_price = Field(Float)
6751 amar.kumar 77
    nlc = Field(Float)
5944 mandeep.dh 78
    using_options(shortnames=True)
79
    using_table_options(mysql_engine="InnoDB")
80
 
81
class VendorHolidays(Entity):
82
    vendor = ManyToOne('Vendor', primary_key=True)
8491 rajveer 83
    date = Field(Date, primary_key=True)
5944 mandeep.dh 84
    occasion = Field(String(100))
85
    using_options(shortnames=True)
86
    using_table_options(mysql_engine="InnoDB")
87
 
88
class CurrentInventorySnapshot(Entity):
89
    item_id = Field(Integer, primary_key=True)
90
    warehouse = ManyToOne("Warehouse", primary_key=True)
91
    availability = Field(Integer)
92
    reserved = Field(Integer)
8205 amar.kumar 93
    held = Field(Integer, default=0, server_default="0")
5944 mandeep.dh 94
    using_options(shortnames=True)
95
    using_table_options(mysql_engine="InnoDB")
5966 rajveer 96
 
8182 amar.kumar 97
class HoldInventoryDetail(Entity):
98
    item_id = Field(Integer, primary_key=True)
99
    warehouse = ManyToOne("Warehouse", primary_key=True)
100
    held = Field(Integer)
8718 amar.kumar 101
    source = Field(Integer, primary_key=True)
8182 amar.kumar 102
    using_options(shortnames=True)
103
    using_table_options(mysql_engine="InnoDB")
104
 
5966 rajveer 105
class CurrentReservationSnapshot(Entity):
106
    item_id = Field(Integer, primary_key=True)
107
    warehouse_id = Field(Integer, primary_key=True)
108
    source_id = Field(Integer, primary_key=True)
109
    order_id = Field(Integer, primary_key=True)
110
    created_timestamp = Field(DateTime)
111
    promised_shipping_timestamp = Field(DateTime)
112
    reserved = Field(Integer)
113
    using_options(shortnames=True)
114
    using_table_options(mysql_engine="InnoDB")
115
 
5944 mandeep.dh 116
class BadInventorySnapshot(Entity):
117
    item_id = Field(Integer, primary_key=True)
118
    warehouse = ManyToOne("Warehouse", primary_key=True)
119
    availability = Field(Integer)
120
    using_options(shortnames=True)
121
    using_table_options(mysql_engine="InnoDB")
122
 
123
class SupplierInventorySnapshot(Entity):
124
    item_id = Field(Integer, primary_key=True)
125
    warehouse = ManyToOne("Warehouse", primary_key=True)
126
    availability = Field(Integer)
127
    using_options(shortnames=True)
128
    using_table_options(mysql_engine="InnoDB")
129
 
130
class ItemInventoryHistory(Entity):
131
    id = Field(Integer, primary_key=True, autoincrement = True)    
132
    timestamp = Field(DateTime, default=datetime.datetime.now())
133
    availability = Field(Integer)
134
    item_id = Field(Integer)
135
    warehouse = ManyToOne("Warehouse")
136
    using_options(shortnames=True)
137
    using_table_options(mysql_engine="InnoDB")
138
 
139
    def __repr__(self):
140
        pass
141
 
142
class MissedInventoryUpdate(Entity):
143
    id = Field(Integer, primary_key=True, autoincrement=True)
144
    itemKey = Field(String(200))
145
    quantity = Field(Integer)
146
    warehouseId = Field(Integer)
147
    isIgnored = Field(Boolean)
148
    timestamp = Field(DateTime)
149
    using_options(shortnames=True)
150
    using_table_options(mysql_engine="InnoDB")
151
 
152
class ItemAvailabilityCache(Entity):
153
    itemId = Field(Integer, primary_key=True, autoincrement=False)
5978 rajveer 154
    sourceId = Field(Integer, primary_key=True, autoincrement=False)
5944 mandeep.dh 155
    warehouseId = Field(Integer)
156
    expectedDelay = Field(Integer)
157
    billingWarehouseId = Field(Integer)
158
    sellingPrice = Field(Float) 
159
    totalAvailability = Field(Integer)
7589 rajveer 160
    weight = Field(Integer, default=300, server_default="300")
5944 mandeep.dh 161
    using_options(shortnames=True)
162
    using_table_options(mysql_engine="InnoDB")
163
 
6821 amar.kumar 164
class ItemStockPurchaseParams(Entity):
165
    item_id = Field(Integer, primary_key=True, autoincrement=False)
166
    numOfDaysStock = Field(Integer)
167
    minStockLevel = Field(Integer)
168
    using_options(shortnames=True)
169
    using_table_options(mysql_engine="InnoDB")
170
 
171
class OOSStatus(Entity):
172
    item_id = Field(Integer, primary_key=True, autoincrement=False)
9665 rajveer 173
    sourceId = Field(Integer, primary_key=True, autoincrement=False)
6821 amar.kumar 174
    date = Field(DateTime, primary_key=True, autoincrement=False)
175
    is_oos = Field(Boolean)
176
    num_orders = Field(Integer)
8182 amar.kumar 177
    rto_orders = Field(Integer)
6821 amar.kumar 178
    using_options(shortnames=True)
179
    using_table_options(mysql_engine="InnoDB")
180
 
7281 kshitij.so 181
class AmazonInventorySnapshot(Entity):
10452 vikram.rag 182
    item_id = Field(Integer, primary_key=True,autoincrement=False)
7281 kshitij.so 183
    availability = Field(Integer)
184
    reserved = Field(Integer)
10450 vikram.rag 185
    is_oos = Field(Boolean)
186
    lastUpdatedOnAmazon =  Field(DateTime)
7281 kshitij.so 187
    using_options(shortnames=True)
188
    using_table_options(mysql_engine="InnoDB")
8282 kshitij.so 189
 
190
class AmazonFbaInventorySnapshot(Entity):
8374 vikram.rag 191
    item_id = Field(Integer, primary_key=True,autoincrement=False)
8282 kshitij.so 192
    availability = Field(Integer)
11173 vikram.rag 193
    inbound = Field(Integer)
194
    reserved = Field(Integer)
195
    unfulfillable = Field(Integer)
196
    location = Field(Integer,primary_key=True,autoincrement=False)
8282 kshitij.so 197
    using_options(shortnames=True)
198
    using_table_options(mysql_engine="InnoDB")
7281 kshitij.so 199
 
9404 vikram.rag 200
class SnapdealInventorySnapshot(Entity):
201
    item_id = Field(Integer, primary_key=True,autoincrement=False)
202
    availability = Field(Integer)
203
    lastUpdatedOnSnapdeal = Field(DateTime)
9495 vikram.rag 204
    pendingOrders = Field(Integer)
10450 vikram.rag 205
    is_oos = Field(Boolean)
9404 vikram.rag 206
    using_options(shortnames=True)
207
    using_table_options(mysql_engine="InnoDB")
10450 vikram.rag 208
 
10050 vikram.rag 209
class FlipkartInventorySnapshot(Entity):
210
    item_id = Field(Integer, primary_key=True,autoincrement=False)
211
    availability = Field(Integer)
212
    createdOrders = Field(Integer)
213
    heldOrders = Field(Integer)
10450 vikram.rag 214
    is_oos = Field(Boolean)
215
    lastUpdatedOnFlipkart =  Field(DateTime)
10050 vikram.rag 216
    using_options(shortnames=True)
217
    using_table_options(mysql_engine="InnoDB")
218
 
10544 vikram.rag 219
class SnapdealStockAtEOD(Entity):
220
    item_id = Field(Integer, primary_key=True,autoincrement=False)
10567 vikram.rag 221
    availability = Field(Integer)
222
    date =  Field(DateTime, primary_key=True,autoincrement=False)
10544 vikram.rag 223
    using_options(shortnames=True)
224
    using_table_options(mysql_engine="InnoDB")
225
 
226
class FlipkartStockAtEOD(Entity):
227
    item_id = Field(Integer, primary_key=True,autoincrement=False)
10567 vikram.rag 228
    availability = Field(Integer)
229
    date =  Field(DateTime, primary_key=True,autoincrement=False)
10544 vikram.rag 230
    using_options(shortnames=True)
231
    using_table_options(mysql_engine="InnoDB")
232
 
233
 
5944 mandeep.dh 234
def initialize(dbname='inventory', db_hostname="localhost"):
235
    #metadata.bind = "sqlite:///inventory-new.sqlite" #need to read it from configserver.
236
    #metadata.bind = 'mysql://root:shop2020@localhost/inventory'
6532 amit.gupta 237
    iengine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200)
238
    metadata.bind = iengine
5944 mandeep.dh 239
    metadata.bind.echo = True
240
    setup_all(True)
241
 
242
if __name__=="__main__":
243
    initialize()