Subversion Repositories SmartDukaan

Rev

Rev 8282 | Rev 8491 | 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
12
from sqlalchemy.types import Integer, String, DateTime, Float, Boolean, Enum
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))
31
    using_options(shortnames=True)
32
    using_table_options(mysql_engine="InnoDB")
33
 
5944 mandeep.dh 34
class Warehouse(Entity):
35
    id = Field(Integer, primary_key=True, autoincrement=True)
36
    displayName = Field(String(50))
37
    location = Field(String(200))
38
    status = Field(Integer)
39
    addedOn = Field(DateTime)
40
    lastCheckedOn = Field(DateTime)
41
    tinNumber = Field(String(50))
42
    pincode = Field(String(10))
43
    vendorString = Field(String(50))
44
    badInventory = OneToMany('BadInventorySnapshot')
45
    inventory = OneToMany('CurrentInventorySnapshot')
46
    inventoryHistory = OneToMany('ItemInventoryHistory')
7330 amit.gupta 47
    state = ManyToOne('StateMaster') 
5944 mandeep.dh 48
    logisticsLocation = Field(Integer)
49
    vendor = ManyToOne('Vendor')
50
    billingType = Field(Integer)
51
    inventoryType = Field(Enum('GOOD', 'BAD', 'VIRTUAL'))
52
    warehouseType = Field(Enum('OURS', 'THIRD_PARTY'))
53
    shippingWarehouseId = Field(Integer)
54
    billingWarehouseId = Field(Integer)
55
    transferDelayInHours = Field(Integer)
56
    isAvailabilityMonitored = Field(Boolean)
57
    using_options(shortnames=True)
58
    using_table_options(mysql_engine="InnoDB")
59
 
60
    def __repr__(self):
61
        return "<warehouse>%s</warehouse>" %(self.location)
62
 
63
class VendorItemMapping(Entity):
64
    vendor = ManyToOne('Vendor', primary_key=True)
65
    item_key = Field(String(200), primary_key=True)
66
    item_id = Field(Integer)
67
    using_options(shortnames=True)
68
    using_table_options(mysql_engine="InnoDB")
69
 
70
class VendorItemPricing(Entity):
71
    vendor = ManyToOne('Vendor', primary_key=True)
72
    item_id = Field(Integer, primary_key=True)
73
    mop = Field(Float)
74
    dealerPrice = Field(Float)
75
    transfer_price = Field(Float)
6751 amar.kumar 76
    nlc = Field(Float)
5944 mandeep.dh 77
    using_options(shortnames=True)
78
    using_table_options(mysql_engine="InnoDB")
79
 
80
class VendorItemProcurementDelay(Entity):
81
    vendor = ManyToOne('Vendor', primary_key=True)
82
    item_id = Field(Integer, primary_key=True)
83
    procurementDelay = Field(Integer)
84
    using_options(shortnames=True)
85
    using_table_options(mysql_engine="InnoDB")
86
 
87
class VendorHolidays(Entity):
88
    vendor = ManyToOne('Vendor', primary_key=True)
89
    holidayType = Field(Integer, primary_key=True, autoincrement=False)
90
    holidayValue = Field(Integer, primary_key=True, autoincrement=False)
91
    occasion = Field(String(100))
92
    using_options(shortnames=True)
93
    using_table_options(mysql_engine="InnoDB")
94
 
95
class CurrentInventorySnapshot(Entity):
96
    item_id = Field(Integer, primary_key=True)
97
    warehouse = ManyToOne("Warehouse", primary_key=True)
98
    availability = Field(Integer)
99
    reserved = Field(Integer)
8205 amar.kumar 100
    held = Field(Integer, default=0, server_default="0")
5944 mandeep.dh 101
    using_options(shortnames=True)
102
    using_table_options(mysql_engine="InnoDB")
5966 rajveer 103
 
8182 amar.kumar 104
class HoldInventoryDetail(Entity):
105
    item_id = Field(Integer, primary_key=True)
106
    warehouse = ManyToOne("Warehouse", primary_key=True)
107
    held = Field(Integer)
108
    source = Field(Integer)
109
    using_options(shortnames=True)
110
    using_table_options(mysql_engine="InnoDB")
111
 
5966 rajveer 112
class CurrentReservationSnapshot(Entity):
113
    item_id = Field(Integer, primary_key=True)
114
    warehouse_id = Field(Integer, primary_key=True)
115
    source_id = Field(Integer, primary_key=True)
116
    order_id = Field(Integer, primary_key=True)
117
    created_timestamp = Field(DateTime)
118
    promised_shipping_timestamp = Field(DateTime)
119
    reserved = Field(Integer)
120
    using_options(shortnames=True)
121
    using_table_options(mysql_engine="InnoDB")
122
 
5944 mandeep.dh 123
class BadInventorySnapshot(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 SupplierInventorySnapshot(Entity):
131
    item_id = Field(Integer, primary_key=True)
132
    warehouse = ManyToOne("Warehouse", primary_key=True)
133
    availability = Field(Integer)
134
    using_options(shortnames=True)
135
    using_table_options(mysql_engine="InnoDB")
136
 
137
class ItemInventoryHistory(Entity):
138
    id = Field(Integer, primary_key=True, autoincrement = True)    
139
    timestamp = Field(DateTime, default=datetime.datetime.now())
140
    availability = Field(Integer)
141
    item_id = Field(Integer)
142
    warehouse = ManyToOne("Warehouse")
143
    using_options(shortnames=True)
144
    using_table_options(mysql_engine="InnoDB")
145
 
146
    def __repr__(self):
147
        pass
148
 
149
class MissedInventoryUpdate(Entity):
150
    id = Field(Integer, primary_key=True, autoincrement=True)
151
    itemKey = Field(String(200))
152
    quantity = Field(Integer)
153
    warehouseId = Field(Integer)
154
    isIgnored = Field(Boolean)
155
    timestamp = Field(DateTime)
156
    using_options(shortnames=True)
157
    using_table_options(mysql_engine="InnoDB")
158
 
159
class ItemAvailabilityCache(Entity):
160
    itemId = Field(Integer, primary_key=True, autoincrement=False)
5978 rajveer 161
    sourceId = Field(Integer, primary_key=True, autoincrement=False)
5944 mandeep.dh 162
    warehouseId = Field(Integer)
163
    expectedDelay = Field(Integer)
164
    billingWarehouseId = Field(Integer)
165
    sellingPrice = Field(Float) 
166
    totalAvailability = Field(Integer)
7589 rajveer 167
    weight = Field(Integer, default=300, server_default="300")
5944 mandeep.dh 168
    using_options(shortnames=True)
169
    using_table_options(mysql_engine="InnoDB")
170
 
6821 amar.kumar 171
class ItemStockPurchaseParams(Entity):
172
    item_id = Field(Integer, primary_key=True, autoincrement=False)
173
    numOfDaysStock = Field(Integer)
174
    minStockLevel = Field(Integer)
175
    using_options(shortnames=True)
176
    using_table_options(mysql_engine="InnoDB")
177
 
178
class OOSStatus(Entity):
179
    item_id = Field(Integer, primary_key=True, autoincrement=False)
180
    date = Field(DateTime, primary_key=True, autoincrement=False)
181
    is_oos = Field(Boolean)
182
    num_orders = Field(Integer)
8182 amar.kumar 183
    rto_orders = Field(Integer)
6821 amar.kumar 184
    using_options(shortnames=True)
185
    using_table_options(mysql_engine="InnoDB")
186
 
7281 kshitij.so 187
class AmazonInventorySnapshot(Entity):
188
    item_id = Field(Integer, primary_key=True)
189
    availability = Field(Integer)
190
    reserved = Field(Integer)
191
    using_options(shortnames=True)
192
    using_table_options(mysql_engine="InnoDB")
8282 kshitij.so 193
 
194
class AmazonFbaInventorySnapshot(Entity):
8374 vikram.rag 195
    item_id = Field(Integer, primary_key=True,autoincrement=False)
8282 kshitij.so 196
    availability = Field(Integer)
197
    using_options(shortnames=True)
198
    using_table_options(mysql_engine="InnoDB")
7281 kshitij.so 199
 
8282 kshitij.so 200
 
5944 mandeep.dh 201
def initialize(dbname='inventory', db_hostname="localhost"):
202
    #metadata.bind = "sqlite:///inventory-new.sqlite" #need to read it from configserver.
203
    #metadata.bind = 'mysql://root:shop2020@localhost/inventory'
6532 amit.gupta 204
    iengine = create_engine('mysql://root:shop2020@' + db_hostname + '/' + dbname, pool_recycle=7200)
205
    metadata.bind = iengine
5944 mandeep.dh 206
    metadata.bind.echo = True
207
    setup_all(True)
208
 
209
if __name__=="__main__":
210
    initialize()