Subversion Repositories SmartDukaan

Rev

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