Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
9947 vikram.rag 1
package in.shop2020;
2
 
3
import in.shop2020.logistics.DeliveryType;
4
import in.shop2020.logistics.LogisticsInfo;
5
import in.shop2020.logistics.LogisticsServiceException;
6
import in.shop2020.model.v1.catalog.CatalogService.Client;
7
import in.shop2020.model.v1.catalog.FlipkartItem;
8
import in.shop2020.model.v1.catalog.Item;
10174 vikram.rag 9
import in.shop2020.model.v1.catalog.SnapdealItemDetails;
9947 vikram.rag 10
import in.shop2020.model.v1.catalog.status;
10049 vikram.rag 11
import in.shop2020.model.v1.inventory.FlipkartInventorySnapshot;
9947 vikram.rag 12
import in.shop2020.model.v1.inventory.InventoryType;
13
import in.shop2020.model.v1.inventory.ItemInventory;
14
import in.shop2020.model.v1.inventory.Warehouse;
15
import in.shop2020.model.v1.inventory.WarehouseLocation;
16
import in.shop2020.model.v1.inventory.WarehouseType;
17
import in.shop2020.model.v1.order.OrderSource;
18
import in.shop2020.serving.model.Order;
19
import in.shop2020.serving.model.OrderItems;
20
import in.shop2020.thrift.clients.CatalogClient;
21
import in.shop2020.thrift.clients.InventoryClient;
22
import in.shop2020.thrift.clients.LogisticsClient;
23
import in.shop2020.thrift.clients.TransactionClient;
9983 vikram.rag 24
import in.shop2020.utils.GmailUtils;
9947 vikram.rag 25
import inventory.FlipkartInventoryItem;
26
 
27
import java.io.BufferedReader;
9983 vikram.rag 28
import java.io.File;
9947 vikram.rag 29
import java.io.IOException;
30
import java.io.InputStreamReader;
9968 vikram.rag 31
import java.io.UnsupportedEncodingException;
9947 vikram.rag 32
import java.util.ArrayList;
33
import java.util.HashMap;
34
import java.util.List;
35
import java.util.Map;
36
import java.util.Map.Entry;
37
 
9983 vikram.rag 38
import javax.mail.MessagingException;
39
 
9947 vikram.rag 40
import org.apache.http.HttpResponse;
41
import org.apache.http.NameValuePair;
42
import org.apache.http.auth.AuthScope;
43
import org.apache.http.auth.UsernamePasswordCredentials;
44
import org.apache.http.client.ClientProtocolException;
45
import org.apache.http.client.HttpClient;
46
import org.apache.http.client.entity.UrlEncodedFormEntity;
47
import org.apache.http.client.methods.HttpGet;
48
import org.apache.http.client.methods.HttpPost;
49
import org.apache.http.entity.StringEntity;
50
import org.apache.http.impl.client.DefaultHttpClient;
51
import org.apache.http.message.BasicNameValuePair;
52
import org.apache.thrift.TException;
53
import org.apache.thrift.transport.TTransportException;
54
 
55
import com.google.gson.Gson;
56
 
57
 
58
 
59
public class CreateSubmitFlipkartInventoryFeed {
60
	private static Map<Long, FlipkartInventoryItem> flipkartItemsInventoryMap = new HashMap<Long, FlipkartInventoryItem>();
61
	private static List<FlipkartItem> flipkartItems;
62
	private static List<FlipkartItem> flipkartInventoryItems = new ArrayList<FlipkartItem>();
63
	private static Map<Long,Long> itemIdOrdersMap = new HashMap<Long,Long>();
9983 vikram.rag 64
	private static Map<Long,Item> aliveItemsMap = new HashMap<Long,Item>();
10057 vikram.rag 65
	private static Map<String,Long> heldOrdersMap = new HashMap<String,Long>();
10122 vikram.rag 66
	private static Map<Long,Long>  updatedFlipkartInventoryMap = new HashMap<Long,Long>();
9983 vikram.rag 67
	static java.text.SimpleDateFormat sdf;
68
	static String emailFromAddress;
69
	static String password;
70
	static GmailUtils mailer;
71
	static String sendTo[];
10174 vikram.rag 72
	private static List<SnapdealItemDetails> snapdealItems = new ArrayList<SnapdealItemDetails>();
73
	private static Map<Long,SnapdealItemDetails> snapdealItemsMap = new HashMap<Long,SnapdealItemDetails>();
9947 vikram.rag 74
	static
75
	{
9983 vikram.rag 76
		sdf = new java.text.SimpleDateFormat("yyyy-MM-dd-HH:mm:ss");
77
		emailFromAddress = "build@shop2020.in";
78
		password = "cafe@nes";
79
		mailer = new GmailUtils();
10450 vikram.rag 80
		sendTo = new String[]{"vikram.raghav@shop2020.in"};
11003 vikram.rag 81
		/*		sendTo = new String[]{ "sandeep.sachdeva@shop2020.in", "vikram.raghav@shop2020.in", "rajneesh.arora@shop2020.in",
9983 vikram.rag 82
				"khushal.bhatia@shop2020.in","manoj.kumar@saholic.com","chaitnaya.vats@saholic.com",
10030 vikram.rag 83
				"yukti.jain@shop2020.in","manoj.pal@shop2020.in","chandan.kumar@shop2020.in","ankush.dhingra@shop2020.in","amar.kumar@shop2020.in"};
11003 vikram.rag 84
		 */		List<String> flipkartorderids = null;
85
		 Client catalogServiceClient = null;
86
		 try {
87
			 catalogServiceClient = new CatalogClient("catalog_service_server_host_amazon","catalog_service_server_port").getClient();
88
		 } catch (TTransportException e) {
89
			 e.printStackTrace();
90
		 }
91
		 try {
92
			 flipkartItems = catalogServiceClient.getAllFlipkartItems();
93
			 snapdealItems = catalogServiceClient.getAllSnapdealItems();
94
		 } catch (TException e) {
95
			 e.printStackTrace();
96
		 }
97
		 for(FlipkartItem flipkartItem:flipkartItems){
98
			 if(flipkartItem.isIsListedOnFlipkart() && !flipkartItem.isSuppressInventoryFeed())
99
				 flipkartInventoryItems.add(flipkartItem);
100
		 }
101
		 for(SnapdealItemDetails snapdealItem:snapdealItems){
102
			 snapdealItemsMap.put(snapdealItem.getItem_id(),snapdealItem);
103
		 }
104
		 if(flipkartInventoryItems.size()==0){
105
			 String text = "";
106
			 try {
107
				 mailer.sendSSLMessage(sendTo,"No items to send inventory ", emailFromAddress, password, text);
108
				 System.exit(0);
109
			 } catch (MessagingException e) {
110
				 e.printStackTrace();
111
			 }
112
		 }
113
		 in.shop2020.model.v1.order.TransactionService.Client transactionClient = null;
114
		 try {
115
			 flipkartorderids = FetchOrders();
116
		 } catch (ClientProtocolException e1) {
117
			 e1.printStackTrace();
118
		 } catch (IOException e1) {
119
			 e1.printStackTrace();
120
		 }
121
		 try {
122
			 transactionClient = new TransactionClient().getClient();
123
			 if(flipkartorderids!=null && flipkartorderids.size()>0){
124
				 itemIdOrdersMap = transactionClient.getCreatedOrdersForFlipkart(flipkartorderids);
125
			 }
126
		 } catch (TTransportException e) {
127
			 try {
128
				 itemIdOrdersMap = transactionClient.getCreatedOrdersForFlipkart(flipkartorderids);
129
			 } catch (TException e1) {
130
				 e1.printStackTrace();
131
			 }
132
		 }catch (TException e) {
133
			 e.printStackTrace();
134
		 }
135
		 try {
136
			 List<FlipkartInventorySnapshot> updatedFlipkartInventoryList = new InventoryClient().getClient().getFlipkartInventorySnapshot();
137
			 for(FlipkartInventorySnapshot updatedFlipkartInventory:updatedFlipkartInventoryList){
138
				 updatedFlipkartInventoryMap.put(updatedFlipkartInventory.getItem_id(),updatedFlipkartInventory.getAvailability());
139
			 }
140
		 } catch (TException e) {
141
			 e.printStackTrace();
142
		 }
143
		 catch(Exception e){
144
			 List<FlipkartInventorySnapshot> updatedFlipkartInventoryList = null;
145
			 try {
146
				 updatedFlipkartInventoryList = new InventoryClient().getClient().getFlipkartInventorySnapshot();
147
			 } catch (TTransportException e1) {
148
				 e1.printStackTrace();
149
			 } catch (TException e1) {
150
				 e1.printStackTrace();
151
			 }
152
			 if(updatedFlipkartInventoryList != null){
153
				 for(FlipkartInventorySnapshot updatedFlipkartInventory:updatedFlipkartInventoryList){
154
					 updatedFlipkartInventoryMap.put(updatedFlipkartInventory.getItem_id(),updatedFlipkartInventory.getAvailability());
155
				 }
156
			 }
157
		 }
9947 vikram.rag 158
 
10122 vikram.rag 159
 
9947 vikram.rag 160
	}
161
 
9967 vikram.rag 162
	public static void main(String[] args) throws ClientProtocolException, TException{
9947 vikram.rag 163
		calculateinventory();
164
		DefaultHttpClient httpclient = new DefaultHttpClient();
9973 vikram.rag 165
		httpclient = (DefaultHttpClient) WebClientWrapper.wrapClient(httpclient);
10051 vikram.rag 166
		//httpclient.getCredentialsProvider().setCredentials(
167
		//		new AuthScope("sandbox-api.flipkart.net", 443),
168
		//		new UsernamePasswordCredentials("og3yg5994bxbxxc1", "8a137068-417c-4e4f-ae95-9295ab938d88"));/// Test Server Access Keys
10049 vikram.rag 169
		httpclient.getCredentialsProvider().setCredentials(
9975 vikram.rag 170
				new AuthScope("api.flipkart.net", 443),
9974 vikram.rag 171
				new UsernamePasswordCredentials("m2z93iskuj81qiid","0c7ab6a5-98c0-4cdc-8be3-72c591e0add4")); //Prod Server Access Keys
10051 vikram.rag 172
		HttpPost httppost = new HttpPost("https://api.flipkart.net/sellers/skus/listings/bulk"); // PROD
173
		//HttpPost httppost = new HttpPost("https://sandbox-api.flipkart.net/sellers/skus/listings/bulk"); // TEST
9947 vikram.rag 174
		StringBuffer jsonRequest = new StringBuffer();
9983 vikram.rag 175
		StringBuffer jsonStart = new StringBuffer();
176
		jsonStart = jsonStart.append("{\"listings\":[");
177
		StringBuffer jsonEnd = new StringBuffer();
178
		jsonEnd.append("]}");
9947 vikram.rag 179
		//System.out.println("JSON request  " + jsonRequest);
180
		LogisticsClient logisticsServiceClient;
181
		in.shop2020.logistics.LogisticsService.Client logisticsClient=null;
182
		LogisticsInfo logisticinfo = null;
183
		try {
10154 vikram.rag 184
			logisticsServiceClient = new LogisticsClient();
9947 vikram.rag 185
			logisticsClient = logisticsServiceClient.getClient();
186
 
187
		} catch (TTransportException e) {
188
			e.printStackTrace();
189
		}
190
		long stock=0;
191
		int i=0;
10176 vikram.rag 192
		long available,reserve,heldforsource,totalheld,allocable,holdinventory,defaultinventory,actualstock = 0,orders,heldorders;
193
		float allocation;
9983 vikram.rag 194
		StringBuffer inventoryItems =new StringBuffer();
10122 vikram.rag 195
		StringBuffer backInStockItems =new StringBuffer();
196
		StringBuffer outOfStockItems =new StringBuffer();
9983 vikram.rag 197
		String tableHeader = "<html><table border=\"1\" align=\"center\"><tr>" 
198
			+ "<td><b>" + "Product Name" +"</b></td>"
199
			+"<td><b>" + "Item ID" + "</b></td>"
200
			+"<td><b>" + "Inventory" + "</b></td>"
201
			+"<td><b>" + "Orders Added to Inventory" + "</b></td>"
202
			+"<td><b>" + "Sent Inventory" + "</b></td>"
10049 vikram.rag 203
			+"<td><b>" + "Procurement SLA" + "</b></td>"
204
			+"<td><b>" + "Orders on Hold" + "</b></td>"
9983 vikram.rag 205
			+"</tr>";
10159 vikram.rag 206
 
9983 vikram.rag 207
		String tableFooter = "</table></html>";
208
		Item item;
10027 vikram.rag 209
		StringBuffer feedResponse=  new StringBuffer();
10049 vikram.rag 210
		List<FlipkartInventorySnapshot> inventorysnapshotlist = new ArrayList<FlipkartInventorySnapshot>();
10450 vikram.rag 211
		long timestamp = System.currentTimeMillis();
9947 vikram.rag 212
		for(Entry<Long, FlipkartInventoryItem> entry:flipkartItemsInventoryMap.entrySet()){
10174 vikram.rag 213
			if(snapdealItemsMap.containsKey(entry.getKey()) && snapdealItemsMap.get(entry.getKey()).isIsListedOnSnapdeal()){
10306 vikram.rag 214
				allocation = (float) 0.33;
10174 vikram.rag 215
			}
216
			else{
10306 vikram.rag 217
				allocation = (float) 0.67;
10174 vikram.rag 218
			}
9985 vikram.rag 219
			actualstock=0;
220
			orders=0;
221
			stock=0;
10049 vikram.rag 222
			heldorders=0;
9947 vikram.rag 223
			available = entry.getValue().getAvailability();
224
			reserve = entry.getValue().getReserve();
225
			heldforsource = entry.getValue().getHeldForSource();
226
			totalheld = entry.getValue().getTotalHeldInventory();
227
			holdinventory = entry.getValue().getHoldInventory();
228
			defaultinventory = entry.getValue().getDefaultInventory();
9987 vikram.rag 229
			System.out.println("Item ID  " + entry.getKey());
230
			System.out.println("Available " + available);
231
			System.out.println("Reserve " + reserve);
232
			System.out.println("Held For Source " + heldforsource);
233
			System.out.println("Total Held " + totalheld);
234
			System.out.println("General Hold " + holdinventory );
235
			System.out.println("Default Inventory " + defaultinventory);
9947 vikram.rag 236
			if(!entry.getValue().getStatus().equals(status.PAUSED)){
237
				if(entry.getValue().getRisky()){
238
					if((available - reserve) < totalheld && totalheld!=0){
239
						stock = (long) Math.floor(((available - reserve)*heldforsource/totalheld));
240
					}
241
					else{
242
						allocable = available - reserve - totalheld - holdinventory;
243
						if(allocable < 0){
244
							allocable = 0;
245
						}
10174 vikram.rag 246
						stock = Math.round(allocable*allocation) + heldforsource;
9947 vikram.rag 247
					}
248
 
249
				}
250
				else{
251
					allocable = available - reserve - totalheld;
252
					if(allocable < 0){
253
						allocable = 0;
254
					}
255
					if((allocable + heldforsource ) > defaultinventory){
10174 vikram.rag 256
						stock = Math.round(allocable*allocation) +  heldforsource;
9947 vikram.rag 257
					}
258
					else{
259
						stock = defaultinventory;
260
					}
261
				}
262
				System.out.println("Item ID " + entry.getKey()+" Stock "+stock +" Orders " + itemIdOrdersMap.get(entry.getKey()));
9992 vikram.rag 263
				actualstock = stock;
9971 vikram.rag 264
				if(itemIdOrdersMap!=null && itemIdOrdersMap.containsKey(entry.getKey())){
9977 vikram.rag 265
					stock = stock + itemIdOrdersMap.get(entry.getKey());  
9983 vikram.rag 266
					orders = itemIdOrdersMap.get(entry.getKey());
9947 vikram.rag 267
				}
268
				if(stock<0){
269
					stock =0;
270
				}
9977 vikram.rag 271
				else{
272
					if(stock > 25){
273
						stock=25;
274
					}
275
				}
9947 vikram.rag 276
			}
277
			else{
278
				stock =0;
279
			}
280
			try {
281
				logisticinfo = logisticsClient.getLogisticsEstimation(entry.getValue().getId(),"110001",DeliveryType.COD);
282
			} catch (LogisticsServiceException e) {
283
				e.printStackTrace();
284
				continue;
285
			}
10029 vikram.rag 286
			catch (TTransportException e) {
10154 vikram.rag 287
				logisticsServiceClient = new LogisticsClient();
10029 vikram.rag 288
				logisticsClient = logisticsServiceClient.getClient();
289
			} 
10107 vikram.rag 290
			System.out.println("sku at flipkart " + entry.getValue().getSkuAtflipkart());
291
			System.out.println("shipping time " + logisticinfo.getShippingTime());
292
			System.out.println("stock " + stock);
9947 vikram.rag 293
			jsonRequest.append("{\"skuId\":"+"\""+entry.getValue().getSkuAtflipkart()+
294
					"\","+"\"attributeValues\""+":"+
295
					"{\"procurement_sla\""+":"+"\""+logisticinfo.getShippingTime()+
296
					"\","+"\"stock_count\""+":"+"\""+stock+"\""+"}}");
10049 vikram.rag 297
			FlipkartInventorySnapshot inventorySnapshot = new FlipkartInventorySnapshot();
298
			inventorySnapshot.setItem_id(entry.getKey());
299
			inventorySnapshot.setAvailability(stock);
10450 vikram.rag 300
			if(stock > 0){
301
				inventorySnapshot.setIs_oos(false);
302
			}
303
			else{
304
				inventorySnapshot.setIs_oos(true);
305
			}
10049 vikram.rag 306
			if(heldOrdersMap.containsKey(entry.getValue().getSkuAtflipkart())){
307
				inventorySnapshot.setHeldOrders(heldOrdersMap.get(entry.getValue().getSkuAtflipkart()));
10060 vikram.rag 308
				heldorders = heldOrdersMap.get(entry.getValue().getSkuAtflipkart());
10049 vikram.rag 309
			}
310
			else{
311
				inventorySnapshot.setHeldOrders(0);
312
			}
313
			inventorySnapshot.setCreatedOrders(orders);
314
			inventorysnapshotlist.add(inventorySnapshot);
9983 vikram.rag 315
			item = aliveItemsMap.get(entry.getValue().getId());
11004 vikram.rag 316
			System.out.println("++++++++++++++++++Before checking > 5 SLA+++++++++++++++++++++++++++++");
11000 vikram.rag 317
			if(logisticinfo.getShippingTime() > 5 && stock > 0){
11005 vikram.rag 318
				System.out.println("Product : "+getProductName(item)+" Item ID : " + item.getId() + " Stock : " +  stock +" "+ "  SLA : " + logisticinfo.getShippingTime());
319
				stock = 0;
11000 vikram.rag 320
			}
11004 vikram.rag 321
			System.out.println("++++++++++++++++++++After checking > 5 SLA++++++++++++++++++++++++");
322
 
10160 vikram.rag 323
			if(!updatedFlipkartInventoryMap.containsKey(entry.getKey())){
10122 vikram.rag 324
				inventoryItems.append("<tr>" 
325
						+ "<td>" +getProductName(item)+"</td>"
326
						+"<td>" + item.getId() + "</td>"
327
						+"<td>" + actualstock + "</td>"
328
						+"<td>" + orders + "</td>"
329
						+"<td>" + stock + "</td>"
330
						+"<td>" + logisticinfo.getShippingTime() + "</td>"
331
						+"<td>" + heldorders + "</td>"
332
						+"</tr>");
333
			}
10160 vikram.rag 334
			else if(updatedFlipkartInventoryMap.containsKey(entry.getKey()) && updatedFlipkartInventoryMap.get(entry.getKey()) != stock){
335
				inventoryItems.append("<tr>" 
336
						+ "<td>" +getProductName(item)+"</td>"
337
						+"<td>" + item.getId() + "</td>"
338
						+"<td>" + actualstock + "</td>"
339
						+"<td>" + orders + "</td>"
340
						+"<td>" + stock + "</td>"
341
						+"<td>" + logisticinfo.getShippingTime() + "</td>"
342
						+"<td>" + heldorders + "</td>"
343
						+"</tr>");
344
			}
10122 vikram.rag 345
			if(updatedFlipkartInventoryMap.containsKey(entry.getKey()) && updatedFlipkartInventoryMap.get(entry.getKey()) == 0 && stock!=0){
346
				backInStockItems.append("<tr>" 
347
						+ "<td>" +getProductName(item)+"</td>"
348
						+"<td>" + item.getId() + "</td>"
349
						+"<td>" + actualstock + "</td>"
350
						+"<td>" + orders + "</td>"
351
						+"<td>" + stock + "</td>"
352
						+"<td>" + logisticinfo.getShippingTime() + "</td>"
353
						+"<td>" + heldorders + "</td>"
354
						+"</tr>");
355
			}
356
			if(updatedFlipkartInventoryMap.containsKey(entry.getKey()) && updatedFlipkartInventoryMap.get(entry.getKey()) != 0 && stock==0){
357
				outOfStockItems.append("<tr>" 
358
						+ "<td>" +getProductName(item)+"</td>"
359
						+"<td>" + item.getId() + "</td>"
360
						+"<td>" + actualstock + "</td>"
361
						+"<td>" + orders + "</td>"
362
						+"<td>" + stock + "</td>"
363
						+"<td>" + logisticinfo.getShippingTime() + "</td>"
364
						+"<td>" + heldorders + "</td>"
365
						+"</tr>");
366
			}
10028 vikram.rag 367
			i++;
368
			if(flipkartItemsInventoryMap.entrySet().size()!=1 && (i!=flipkartItemsInventoryMap.entrySet().size()) ){
10026 vikram.rag 369
				if(i%10!=0){
370
					jsonRequest.append(",");
371
				}
9947 vikram.rag 372
			}
373
			if(i%10==0 || i==flipkartItemsInventoryMap.entrySet().size()){
9968 vikram.rag 374
				StringEntity input = null;
375
				try {
9983 vikram.rag 376
					input = new StringEntity(jsonStart+jsonRequest.toString()+jsonEnd);
377
					System.out.println("Json input " + jsonStart+jsonRequest.toString()+jsonEnd);
378
					jsonRequest = new StringBuffer();
9968 vikram.rag 379
				} catch (UnsupportedEncodingException e) {
380
					e.printStackTrace();
381
				}
9947 vikram.rag 382
				input.setContentType("application/json");
10049 vikram.rag 383
 
9947 vikram.rag 384
				httppost.setEntity(input);
9968 vikram.rag 385
				HttpResponse response = null;
386
				try {
9970 vikram.rag 387
					System.out.println("Before send " );
9968 vikram.rag 388
					response = httpclient.execute(httppost);
9970 vikram.rag 389
					System.out.println("After send " );
9968 vikram.rag 390
				} catch (IOException e) {
391
					e.printStackTrace();
392
				}
9969 vikram.rag 393
				BufferedReader rd = null;
9968 vikram.rag 394
				try {
395
					rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
396
				} catch (IllegalStateException e) {
397
					e.printStackTrace();
398
				} catch (IOException e) {
399
					e.printStackTrace();
400
				}
9947 vikram.rag 401
				String line;
10049 vikram.rag 402
				in.shop2020.model.v1.inventory.InventoryService.Client inventoryServiceClient;
9969 vikram.rag 403
				try {
404
					while ((line = rd.readLine()) != null) {
405
						System.out.println("Response " + line);
9983 vikram.rag 406
						if(line.equalsIgnoreCase("{\"status\":\"success\"}")){
10154 vikram.rag 407
							inventoryServiceClient = new InventoryClient().getClient();
10158 vikram.rag 408
							try{
10450 vikram.rag 409
								inventoryServiceClient.addOrUpdateFlipkartInventorySnapshot(inventorysnapshotlist,timestamp);
10158 vikram.rag 410
							}
411
							catch(TTransportException e){
412
								inventoryServiceClient = new InventoryClient().getClient();
10450 vikram.rag 413
								inventoryServiceClient.addOrUpdateFlipkartInventorySnapshot(inventorysnapshotlist,timestamp);
10158 vikram.rag 414
							}
10049 vikram.rag 415
							inventorysnapshotlist = new ArrayList<FlipkartInventorySnapshot>();
9983 vikram.rag 416
						}
417
						else{
418
							feedResponse.append(line);
419
						}
10049 vikram.rag 420
 
9969 vikram.rag 421
					}
422
				} catch (IOException e) {
423
					e.printStackTrace();
9947 vikram.rag 424
				}
425
			}
426
		}
9983 vikram.rag 427
		System.out.println("Before sending email");
10179 vikram.rag 428
		if(feedResponse.toString().length()>0){
429
			try {
430
				mailer.sendSSLMessage(sendTo, "Flipkart Inventory could not be updated " + sdf.format(System.currentTimeMillis()), feedResponse.toString(), emailFromAddress, password,new ArrayList<File>());
10181 vikram.rag 431
			} catch (Exception e) {
10183 vikram.rag 432
				emailFromAddress = "build-staging@shop2020.in"; 
433
				password = "shop2020";
10179 vikram.rag 434
				try {
435
					mailer.sendSSLMessage(sendTo, "Flipkart Inventory could not be updated " + sdf.format(System.currentTimeMillis()), feedResponse.toString(), emailFromAddress, password,new ArrayList<File>());
436
				} catch (MessagingException e1) {
437
					e1.printStackTrace();
438
				}
439
				e.printStackTrace();
440
			}
441
		}
442
		else{
443
			try {
444
				mailer.sendSSLMessage(sendTo, "Flipkart Inventory updated successfully " + sdf.format(System.currentTimeMillis()), feedResponse.toString(), emailFromAddress, password,new ArrayList<File>());
445
			} catch (MessagingException e) {
10183 vikram.rag 446
				emailFromAddress = "build-staging@shop2020.in"; 
447
				password = "shop2020";
10179 vikram.rag 448
				try {
449
					mailer.sendSSLMessage(sendTo, "Flipkart Inventory updated successfully " + sdf.format(System.currentTimeMillis()), feedResponse.toString(), emailFromAddress, password,new ArrayList<File>());
450
				} catch (MessagingException e1) {
451
					e1.printStackTrace();
452
				}
453
				e.printStackTrace();
454
			}
455
		}
456
 
457
		String text;
10159 vikram.rag 458
		if(inventoryItems.toString().length()>0){
10179 vikram.rag 459
			text = tableHeader+inventoryItems.toString()+tableFooter;
10159 vikram.rag 460
			try {
461
				mailer.sendSSLMessage(sendTo,"Flipkart Inventory Sent Details " + sdf.format(System.currentTimeMillis()), emailFromAddress, password, text);
462
			} catch (MessagingException e) {
463
				e.printStackTrace();
464
			}
9983 vikram.rag 465
		}
10122 vikram.rag 466
		if(backInStockItems.toString().length()>0){
467
			try {
468
				text = tableHeader+backInStockItems.toString()+tableFooter;
10123 vikram.rag 469
				mailer.sendSSLMessage(sendTo,"Flipkart Inventory Back in Stock " + sdf.format(System.currentTimeMillis()), emailFromAddress, password, text);
10122 vikram.rag 470
			} catch (MessagingException e) {
471
				e.printStackTrace();
472
			}
10159 vikram.rag 473
 
10122 vikram.rag 474
		}
475
		if(outOfStockItems.toString().length()>0){
476
			try {
477
				text = tableHeader+outOfStockItems.toString()+tableFooter;
10123 vikram.rag 478
				mailer.sendSSLMessage(sendTo,"Flipkart Inventory Out of Stock " + sdf.format(System.currentTimeMillis()), emailFromAddress, password, text);
10122 vikram.rag 479
			} catch (MessagingException e) {
480
				e.printStackTrace();
481
			}
10159 vikram.rag 482
 
10122 vikram.rag 483
		}
9947 vikram.rag 484
	}
9983 vikram.rag 485
 
9947 vikram.rag 486
	private static void calculateinventory(){
487
		CatalogClient catalogServiceClient = null;
488
		Map<Long,ItemInventory> availability= new HashMap<Long,ItemInventory>();
489
		try {
10154 vikram.rag 490
			catalogServiceClient = new CatalogClient("catalog_service_server_host_amazon","catalog_service_server_port");
9947 vikram.rag 491
		} catch (TTransportException e) {
492
			e.printStackTrace();
493
		}
494
		in.shop2020.model.v1.catalog.CatalogService.Client catalogClient = catalogServiceClient.getClient();
495
		try {
496
			List<Item> aliveItems = catalogClient.getAllAliveItems();
497
			for(in.shop2020.model.v1.catalog.Item thriftItem:aliveItems){
498
				aliveItemsMap.put(thriftItem.getId(), thriftItem);
499
 
500
			}
501
			InventoryClient inventoryServiceClient = new InventoryClient();
502
			try {
503
				inventoryServiceClient = new InventoryClient();
504
			} catch (TTransportException e) {
505
				e.printStackTrace();
506
			}
507
			in.shop2020.model.v1.inventory.InventoryService.Client inventoryClient = inventoryServiceClient.getClient();
508
			List<in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems> ignoreItems = inventoryClient.getIgnoredWarehouseidsAndItemids();
509
			availability = inventoryClient.getInventorySnapshot(0);
510
			List<Warehouse> allwarehouses = inventoryClient.getWarehouses(null,null,0,0,0);
511
			Map<Long,Warehouse> allWarehousesMap = new HashMap<Long,Warehouse>();
512
			for(Warehouse warehouse:allwarehouses){
513
				allWarehousesMap.put(warehouse.getId(),warehouse);
514
			}
515
			List<Warehouse> warehouses = inventoryClient.getWarehouses(WarehouseType.OURS_THIRDPARTY,null,0,0,0);
516
			List<Warehouse> ours_warehouses = inventoryClient.getWarehouses(WarehouseType.OURS, InventoryType.GOOD, 0, 0, 0);
517
			List<Long> thirdpartywarehouseids = new ArrayList<Long>();
518
			List<Long> oursGoodWarehouse = new ArrayList<Long>();
519
			for(Warehouse warehouse:warehouses){
520
				thirdpartywarehouseids.add(warehouse.getId());
521
			}
522
			for (Warehouse warehouse:ours_warehouses){
523
				oursGoodWarehouse.add(warehouse.getId());
524
			}
525
			long available=0;
526
			long reserve=0;
527
			long total_warehouse_held=0;
528
			long heldForSource=0;
529
			long total_held=0;
530
			double nlc=0;
531
			double maxnlc=0;
532
			Item thriftItem;
533
			for(FlipkartItem flipkartItem:flipkartInventoryItems){
534
				if(aliveItemsMap.get(flipkartItem.getItem_id()) != null){
535
					thriftItem = aliveItemsMap.get(flipkartItem.getItem_id());	
536
				}
537
				else{
538
					continue;
539
				}
540
				available=0;
541
				reserve=0;
542
				total_warehouse_held=0;
543
				heldForSource=0;
544
				total_held=0;
545
				nlc=0;
546
				List<Warehouse> vendor_warehouses=null;
547
				FlipkartInventoryItem item;
548
				if(availability.get(thriftItem.getId())!=null){ 
549
					ItemInventory iteminventory = availability.get(thriftItem.getId());
550
					Map<Long,Long> itemavailability = new HashMap<Long,Long>();
551
					itemavailability = iteminventory.getAvailability();
552
					if (thriftItem.isIsWarehousePreferenceSticky() && thriftItem.getPreferredVendor()!=0){
553
						//System.out.println("Item id "+thriftItem.getId()+".Found prefered vendor and warehouse is marked sticky (Calculating availability)"+thriftItem.getPreferredVendor());						
554
						vendor_warehouses = inventoryClient.getWarehouses(WarehouseType.THIRD_PARTY,InventoryType.GOOD , thriftItem.getPreferredVendor(), 0, 0);
555
						vendor_warehouses.addAll(ours_warehouses);
556
						for (Warehouse warehouse:vendor_warehouses){
557
							if(warehouse.getBillingWarehouseId()!=7){
558
								if(warehouse.getLogisticsLocation().equals(WarehouseLocation.Delhi) && warehouse.getWarehouseType().equals(WarehouseType.THIRD_PARTY) && warehouse.getVendor().getId()!=1){
559
 
560
								}
561
								else{
562
									continue;
563
								}
564
							}
565
							in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems ignoredItem = new in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems();
566
							ignoredItem.setItemId(thriftItem.getId());
567
							ignoredItem.setWarehouseId(warehouse.getId());
568
							if (itemavailability.get(warehouse.getId())!=null && !thirdpartywarehouseids.contains(warehouse.getId()) && !ignoreItems.contains(ignoredItem)){
569
								try{
570
									nlc = inventoryClient.getNlcForWarehouse(warehouse.getId(),thriftItem.getId());
571
								}
572
								catch(TTransportException e){
573
									inventoryClient = inventoryServiceClient.getClient(); 
574
									nlc = inventoryClient.getNlcForWarehouse(warehouse.getId(),thriftItem.getId());
575
								}
576
								maxnlc = flipkartItem.getMaxNlc();
577
 
578
								//System.out.println("itemId:" + thriftItem.getId() + "\tmaxnlc: " + maxnlc + "\tnlc:" + nlc + "\twid:" + warehouse.getId() );
579
								if(nlc !=0 && (maxnlc >= nlc)){
580
									total_warehouse_held = inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), warehouse.getId(), 0);
581
									heldForSource = heldForSource + total_warehouse_held - inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), warehouse.getId(), 8);
582
									available = available + itemavailability.get(warehouse.getId());
583
									total_held = total_held + total_warehouse_held; 
584
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\tavailable:" + available);
585
								}
586
								else if(maxnlc==0){
587
									total_warehouse_held = inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), warehouse.getId(), 0);
588
									heldForSource = heldForSource + total_warehouse_held - inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), warehouse.getId(), 8);
589
									available = available + itemavailability.get(warehouse.getId());
590
									total_held = total_held + total_warehouse_held;
591
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\tavailable:" + available);
592
								}
593
							}
594
						}
595
					}
596
					else{
597
						for (Map.Entry<Long,Long> entry :  itemavailability.entrySet()) {
598
							if(allWarehousesMap.get(entry.getKey()).getBillingWarehouseId()!=7){
599
								if(allWarehousesMap.get(entry.getKey()).getLogisticsLocation().equals(WarehouseLocation.Delhi) && allWarehousesMap.get(entry.getKey()).getWarehouseType().equals(WarehouseType.THIRD_PARTY) && allWarehousesMap.get(entry.getKey()).getVendor().getId()!=1){
600
 
601
								}
602
								else{
603
									continue;
604
								}
605
							}
606
							in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems ignoredItem = new in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems();
607
							ignoredItem.setItemId(thriftItem.getId());
608
							ignoredItem.setWarehouseId(entry.getKey());
609
							if(!thirdpartywarehouseids.contains(entry.getKey()) && !ignoreItems.contains(ignoredItem)){
610
 
611
								nlc = inventoryClient.getNlcForWarehouse(entry.getKey(),thriftItem.getId());
612
								maxnlc = flipkartItem.getMaxNlc();
613
								//System.out.println("itemId:" + thriftItem.getId() + "\tmaxnlc: " + maxnlc + "\tnlc:" + nlc + "\twid:" + entry.getKey() );
614
								if(nlc !=0 && (maxnlc >= nlc)){
615
									total_warehouse_held = inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), entry.getKey(), 0);
616
									heldForSource = heldForSource + total_warehouse_held - inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), entry.getKey(), 8);
617
									available =  available + entry.getValue();
618
									total_held = total_held + total_warehouse_held;
619
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\tavailable:" + available);
620
								}
621
								else if(maxnlc==0){
622
									total_warehouse_held = inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), entry.getKey(), 0);
623
									heldForSource = heldForSource + total_warehouse_held - inventoryClient.getHoldInventoryDetailForItemForWarehouseIdExceptSource(thriftItem.getId(), entry.getKey(), 8);
624
									available = available + itemavailability.get(entry.getKey());
625
									total_held = total_held + total_warehouse_held;
626
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\tavailable:" + available);
627
								}
628
 
629
							}
630
						}
631
					}
632
					Map<Long,Long> itemreserve = new HashMap<Long,Long>();
633
					itemreserve = iteminventory.getReserved();
634
					if (thriftItem.isIsWarehousePreferenceSticky() && thriftItem.getPreferredVendor()!=0){
635
						//System.out.println("Item id "+thriftItem.getId()+".Found prefered vendor and warehouse is marked sticky (Calculating Reserve)"+thriftItem.getPreferredVendor());
636
						for (Warehouse warehouse:vendor_warehouses){
637
							if(warehouse.getBillingWarehouseId()!=7){
638
								if(warehouse.getLogisticsLocation().equals(WarehouseLocation.Delhi) && warehouse.getWarehouseType().equals(WarehouseType.THIRD_PARTY) && warehouse.getVendor().getId()!=1){
639
 
640
								}
641
								else{
642
									continue;
643
								}
644
							}
645
							in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems ignoredItem = new in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems();
646
							ignoredItem.setItemId(thriftItem.getId());
647
							ignoredItem.setWarehouseId(warehouse.getId());
648
							if (itemreserve.get(warehouse.getId())!=null && !thirdpartywarehouseids.contains(warehouse.getId()) && !ignoreItems.contains(warehouse.getId())){
649
								nlc = inventoryClient.getNlcForWarehouse(warehouse.getId(),thriftItem.getId());
650
								maxnlc = flipkartItem.getMaxNlc();
651
								//System.out.println("itemId:" + thriftItem.getId() + "\tmaxnlc: " + maxnlc + "\tnlc:" + nlc + "\twid:" + warehouse.getId() );
652
								if(nlc !=0 && (maxnlc >= nlc)){
653
									reserve = reserve + itemreserve.get(warehouse.getId());
654
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\treserve:" + reserve);
655
								}
656
								else if(maxnlc==0){
657
									reserve = reserve + itemreserve.get(warehouse.getId());
658
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\treserve:" + reserve);
659
								}
660
 
661
							}
662
						}
663
					}else{
664
						for (Map.Entry<Long,Long> entry : itemreserve.entrySet()) {
665
							if(allWarehousesMap.get(entry.getKey()).getBillingWarehouseId()!=7){
666
								if(allWarehousesMap.get(entry.getKey()).getLogisticsLocation().equals(WarehouseLocation.Delhi) && allWarehousesMap.get(entry.getKey()).getWarehouseType().equals(WarehouseType.THIRD_PARTY) && allWarehousesMap.get(entry.getKey()).getVendor().getId()!=1){
667
 
668
								}
669
								else{
670
									continue;
671
								}
672
							}
673
							in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems ignoredItem = new in.shop2020.model.v1.inventory.IgnoredInventoryUpdateItems();
674
							ignoredItem.setItemId(thriftItem.getId());
675
							ignoredItem.setWarehouseId(entry.getKey());
676
							if(!thirdpartywarehouseids.contains(entry.getKey()) && !ignoreItems.contains(ignoredItem)){
677
								nlc = inventoryClient.getNlcForWarehouse(entry.getKey(),thriftItem.getId());
678
								maxnlc = flipkartItem.getMaxNlc();
679
								//System.out.println("itemId:" + thriftItem.getId() + "\tmaxnlc: " + maxnlc + "\tnlc:" + nlc + "\twid:" + entry.getKey() );
680
								if(nlc !=0 && (maxnlc >= nlc)){
681
									reserve =  reserve + entry.getValue();
682
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\treserve:" + reserve);
683
								}
684
								else if(maxnlc==0){
685
									reserve =  reserve + entry.getValue();
686
									//System.out.println("itemId:" + thriftItem.getId() + "\ttotal_held: " + total_held + "\theldForSource:" + heldForSource + "\treserve:" + reserve);
687
								}
688
 
689
							}
690
 
691
							else{
692
								//System.out.println("skipping inventory for warehouse id " + entry.getKey());
693
							}
694
						}
695
					}
696
					item= new FlipkartInventoryItem(thriftItem.getId(),available,reserve,heldForSource,thriftItem.getHoldInventory(),thriftItem.getDefaultInventory(),total_held,thriftItem.isRisky(),thriftItem.getItemStatus(),flipkartItem.getSkuAtFlipkart());
697
					//System.out.println("itemId:" + thriftItem.getId() + "\tavailable: " + available + "\treserve" + reserve + "\theldForSource:" + heldForSource + "\twebsite_hold:" + thriftItem.getHoldInventory() + "\tdefault_inv:" +thriftItem.getDefaultInventory());
698
				}
699
				else{
700
					item = new FlipkartInventoryItem(thriftItem.getId(),0,0,0,thriftItem.getHoldInventory(),thriftItem.getDefaultInventory(),0,thriftItem.isRisky(),thriftItem.getItemStatus(),flipkartItem.getSkuAtFlipkart());
701
					//System.out.println("itemId:" + thriftItem.getId() + "\tavailable: " + available + "\treserve" + reserve + "\theldForSource:" + heldForSource + "\twebsite_hold:" + thriftItem.getHoldInventory() + "\tdefault_inv:" +thriftItem.getDefaultInventory());
702
				}
703
 
704
				//System.out.println(" Item details are " + thriftItem.getId() +" " + available + " " + reserve + " " + thriftItem.getHoldInventory() + " "+ thriftItem.getDefaultInventory() + " " + thriftItem.isRisky());
705
				//System.out.println("+++++++++++++++++++++++");
706
				flipkartItemsInventoryMap.put(thriftItem.getId(),item);
707
 
708
			}
709
 
710
		} catch (TException e) {
711
			e.printStackTrace();
712
		}
713
	}
714
 
715
	static List<String> FetchOrders() throws ClientProtocolException, IOException{
716
		HttpClient client = new DefaultHttpClient();
717
		HttpPost post = new HttpPost("https://seller.flipkart.com/login");
718
		BufferedReader rd= null;
719
		List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
720
		nameValuePairs.add(new BasicNameValuePair("authName",
721
		"flipkart"));
722
		nameValuePairs.add(new BasicNameValuePair("username",
723
		"flipkart-support@saholic.com"));
724
		nameValuePairs.add(new BasicNameValuePair("password",
725
		"076c27ee24d7596b06608a8ed2559f87"));
726
		post.setEntity(new UrlEncodedFormEntity(nameValuePairs,"utf-8"));
727
		HttpResponse response = client.execute(post);
728
		rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
729
		String line = "";
730
		Gson gson;
731
		List<Order> orders = new ArrayList<Order>(); 
732
		OrderItems new_orders;
733
		OrderItems conf_orders;
734
		HttpGet get_new;
735
		HttpGet get_conf; 
736
		long time;
737
		int i=1;
738
		while ((line = rd.readLine()) != null) {
739
			System.out.println(line);
740
		}
741
		time = System.currentTimeMillis();
742
		while(true){
743
			get_new = new HttpGet("https://seller.flipkart.com/dashboard/som/new_order_items?status=on_hold%2Capproved.payment_approved&sort=confirm_by_date&page="+i+"&page_size=100&_="+time);
744
			response = client.execute(get_new);
745
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
746
			line = "";
747
			gson = new Gson();
748
			new_orders = (OrderItems) gson.fromJson(rd, OrderItems.class);
749
			if(new_orders.getOrder_items().size()>0){
750
				orders.addAll(new_orders.getOrder_items());
751
			}
752
			else{
753
				break;
754
			}
755
			i++;
756
		}
757
		i=1;
758
		time = System.currentTimeMillis();
759
		while(true){
760
			get_conf = new HttpGet("https://seller.flipkart.com/dashboard/som/confirmed_order_items?status=approved.seller_approved&sort=confirm_by_date&page="+i+"&page_size=100&_="+time);
761
			response = client.execute(get_conf);
762
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
763
			line = "";
764
			gson = new Gson();
765
			conf_orders = (OrderItems) gson.fromJson(rd, OrderItems.class);
766
			if(conf_orders.getOrder_items().size()>0){
767
				orders.addAll(conf_orders.getOrder_items());
768
			}
769
			else{
770
				break;
771
			}
772
			i++;
773
		}
774
		List<String> orderIdList = new ArrayList<String>();
10054 vikram.rag 775
		Long heldOrders = 0L;
9947 vikram.rag 776
		for(Order order:orders){
10153 vikram.rag 777
			System.out.println("Order  " + order.getExternalId() +" "+order.getOrderItemId() + " : "+ order.getStatus() + " "+order.getStatusDateMessage() + " "
778
					+ order.getStatusLabel() + " " + order.getPickup_by_date() + " "+ order.getTrackingId());
9947 vikram.rag 779
			orderIdList.add(order.getExternalId());
10049 vikram.rag 780
			if(order.getStatus().equalsIgnoreCase("on_hold")){
10062 vikram.rag 781
				if(heldOrdersMap.containsKey(String.valueOf(order.getSku()))){
10057 vikram.rag 782
					heldOrders = heldOrdersMap.get(String.valueOf(order.getSku()))+order.getQuantity();
783
					heldOrdersMap.put(String.valueOf(order.getSku()),heldOrders);
10059 vikram.rag 784
					System.out.println("Item ID " + order.getSku() + " Held Orders " + heldOrdersMap.get(String.valueOf(order.getSku())));
10049 vikram.rag 785
				}
786
				else{
10054 vikram.rag 787
					heldOrders = (long) order.getQuantity();
10057 vikram.rag 788
					heldOrdersMap.put(String.valueOf(order.getSku()),heldOrders);
10059 vikram.rag 789
					System.out.println("Item ID " + order.getSku() + " Held Orders " + heldOrdersMap.get(String.valueOf(order.getSku())));
10049 vikram.rag 790
				}
791
			}
9947 vikram.rag 792
		}
793
		return orderIdList; 
794
	}
9983 vikram.rag 795
	static String getProductName(Item item){
796
		return getName(item.getBrand())+" " + getName(item.getModelName())+" " + getName(item.getModelNumber())+" " + getName(item.getColor()); 
797
 
798
	}
799
	static String getName(String name){
800
		if(name==null || name.length()==0){
801
			return "";
802
		}
803
		else{
804
			return name;
805
		}
806
	}
9947 vikram.rag 807
}