Subversion Repositories SmartDukaan

Rev

Rev 13587 | Rev 13611 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 13587 Rev 13602
Line 106... Line 106...
106
			post.setEntity(new UrlEncodedFormEntity(nameValuePairs,"utf-8"));
106
			post.setEntity(new UrlEncodedFormEntity(nameValuePairs,"utf-8"));
107
			HttpResponse response = client.execute(post);
107
			HttpResponse response = client.execute(post);
108
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
108
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
109
			String line = "";
109
			String line = "";
110
			int i=1;
110
			int i=1;
111
			
111
 
112
			while ((line = rd.readLine()) != null) {
112
			while ((line = rd.readLine()) != null) {
113
				System.out.println(line);
113
				System.out.println(line);
114
			}
114
			}
115
			HttpPost post_1;
115
			HttpPost post_1;
116
			HttpGet get_new;
116
			HttpGet get_new;
117
			String csrfVal= getCsrfValue();
117
			String csrfVal= getCsrfValue();
118
			
118
 
119
			Thread.sleep(5000);			
119
			Thread.sleep(5000);			
120
			
120
 
121
			get_new = new HttpGet("https://seller.flipkart.com/sfx/inventory/stock/download?inventoryType=all&sellerId=m2z93iskuj81qiid&warehouse_id=del");
121
			get_new = new HttpGet("https://seller.flipkart.com/sfx/inventory/stock/download?inventoryType=all&sellerId=m2z93iskuj81qiid&warehouse_id=del");
122
			get_new.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
122
			get_new.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
123
			get_new.addHeader("Connection","keep-alive");
123
			get_new.addHeader("Connection","keep-alive");
124
 
124
 
125
			response = client.execute(get_new);
125
			response = client.execute(get_new);
126
 
126
 
127
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
127
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
128
			
128
 
129
			CSVReader csvInventoryReader = new CSVReader(rd);
129
			CSVReader csvInventoryReader = new CSVReader(rd);
130
			String[] values;
130
			String[] values;
131
			
131
 
132
			CSVWriter writer = new CSVWriter(new FileWriter("/home/FAInventory.csv", true));
132
			CSVWriter writer = new CSVWriter(new FileWriter("/home/FAInventory.csv", true));
133
			while ((values = csvInventoryReader.readNext()) != null) {
133
			while ((values = csvInventoryReader.readNext()) != null) {
134
				writer.writeNext(values);
134
				writer.writeNext(values);
135
				if(i==1){
135
				if(i==1){
136
					i++;
136
					i++;
Line 138... Line 138...
138
				}
138
				}
139
				skuInventoryPriceMap.put(Long.parseLong(values[0]),Double.parseDouble(values[2]));
139
				skuInventoryPriceMap.put(Long.parseLong(values[0]),Double.parseDouble(values[2]));
140
				i++;
140
				i++;
141
			}
141
			}
142
			writer.close();
142
			writer.close();
143
			
143
 
144
			String paramVal = "{\"fromDate\":\""+startDate+"\",\"toDate\":\""+endDate+"\",\"warehouseId\":\"del\",\"type\":\"InvoiceReport\",\"_csrf\":\""+csrfVal+"\"}";
144
			String paramVal = "{\"fromDate\":\""+startDate+"\",\"toDate\":\""+endDate+"\",\"warehouseId\":\"del\",\"type\":\"InvoiceReport\",\"_csrf\":\""+csrfVal+"\"}";
145
			System.out.println(paramVal);
145
			System.out.println(paramVal);
146
			StringEntity entity = new StringEntity(paramVal, "utf-8");
146
			StringEntity entity = new StringEntity(paramVal, "utf-8");
147
			
147
 
148
			
148
 
149
			post_1 = new HttpPost("https://seller.flipkart.com/sfx/reports/submit?sellerId=m2z93iskuj81qiid");
149
			post_1 = new HttpPost("https://seller.flipkart.com/sfx/reports/submit?sellerId=m2z93iskuj81qiid");
150
			post_1.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
150
			post_1.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
151
			post_1.addHeader("fk-csrf-token",csrfVal);
151
			post_1.addHeader("fk-csrf-token",csrfVal);
152
			post_1.addHeader("Content-Type","application/json;charset=UTF-8");
152
			post_1.addHeader("Content-Type","application/json;charset=UTF-8");
153
			post_1.addHeader("Host","seller.flipkart.com");
153
			post_1.addHeader("Host","seller.flipkart.com");
Line 158... Line 158...
158
			post_1.addHeader("User-Agent","Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.104 Safari/537.36");
158
			post_1.addHeader("User-Agent","Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.104 Safari/537.36");
159
 
159
 
160
			post_1.setEntity(entity);
160
			post_1.setEntity(entity);
161
 
161
 
162
			response = client.execute(post_1);
162
			response = client.execute(post_1);
163
			
163
 
164
			response.getEntity().consumeContent();
164
			response.getEntity().consumeContent();
165
 
165
 
166
			Thread.sleep(120000);
166
			Thread.sleep(120000);
167
			
167
 
168
			//https://seller.flipkart.com/sfx/reports/download/?sellerId=m2z93iskuj81qiid&downloadurl=/reports/invoices/invoice_csv_m2z93iskuj81qiid_09-30-2014_10-30-2014/download_csv
168
			//https://seller.flipkart.com/sfx/reports/download/?sellerId=m2z93iskuj81qiid&downloadurl=/reports/invoices/invoice_csv_m2z93iskuj81qiid_09-30-2014_10-30-2014/download_csv
169
			get_new = new HttpGet("https://seller.flipkart.com/sfx/reports/download/?sellerId=m2z93iskuj81qiid&downloadurl=/reports/invoices/invoice_csv_m2z93iskuj81qiid_"+repStartDate+"_"+repEndDate+"/download_csv");
169
			get_new = new HttpGet("https://seller.flipkart.com/sfx/reports/download/?sellerId=m2z93iskuj81qiid&downloadurl=/reports/invoices/invoice_csv_m2z93iskuj81qiid_"+repStartDate+"_"+repEndDate+"/download_csv");
170
			get_new.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
170
			get_new.addHeader("Cookie","__isReg=true;s_cc=true;pincode=110001;is_login=true;sellerId=m2z93iskuj81qiid;km_ai=m2z93iskuj81qiid;km_ni=m2z93iskuj81qiid");
171
			get_new.addHeader("Connection","keep-alive");
171
			get_new.addHeader("Connection","keep-alive");
172
 
172
 
173
			response = client.execute(get_new);
173
			response = client.execute(get_new);
174
			
174
 
175
			//Thread.sleep(10000);
-
 
176
 
175
 
177
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
176
			rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
178
			
177
 
179
			i=1;
178
			i=1;
180
			CSVReader csvReader = new CSVReader(rd);
179
			CSVReader csvReader = new CSVReader(rd);
181
			while ((values = csvReader.readNext()) != null) {
180
			while ((values = csvReader.readNext()) != null) {
182
				if(i==1){
181
				if(i==1){
183
					i++;
182
					i++;
184
					continue;
183
					continue;
185
				}
184
				}
186
				System.out.println(values[0]);
185
				System.out.println(values[0]);
187
				Date date = flipkartRepFormat.parse(values[4]);
186
				Date date = flipkartRepFormat.parse(values[5]);
188
				Date date_key = sdf.parse(sdf.format(date));
187
				Date date_key = sdf.parse(sdf.format(date));
-
 
188
				if(!(values[12].equalsIgnoreCase("SalesInvoice")||values[12].equalsIgnoreCase("CourierReturnInvoice")||values[12].equalsIgnoreCase("CustomerReturnInvoice"))){
-
 
189
					i++;
-
 
190
					continue;
189
				
191
				}
190
					if(orderDateItemIdFbaSaleSnapshotMap.containsKey(date_key)){
192
				if(orderDateItemIdFbaSaleSnapshotMap.containsKey(date_key)){
191
						FlipkartFaSalesSnapshot faSalesSnapshot;
193
					FlipkartFaSalesSnapshot faSalesSnapshot;
192
						if(orderDateItemIdFbaSaleSnapshotMap.get(date_key).containsKey(values[7])){
194
					if(orderDateItemIdFbaSaleSnapshotMap.get(date_key).containsKey(values[7])){
193
							faSalesSnapshot = orderDateItemIdFbaSaleSnapshotMap.get(date_key).get(values[7]);
195
						faSalesSnapshot = orderDateItemIdFbaSaleSnapshotMap.get(date_key).get(values[7]);
194
							if(values[12].equalsIgnoreCase("SalesInvoice")){
196
						if(values[12].equalsIgnoreCase("SalesInvoice")){
195
								faSalesSnapshot.setTotalOrderCount(faSalesSnapshot.getTotalOrderCount()+Integer.parseInt(values[13]));
197
							faSalesSnapshot.setTotalOrderCount(faSalesSnapshot.getTotalOrderCount()+Integer.parseInt(values[13]));
196
								faSalesSnapshot.setTotalSale(faSalesSnapshot.getTotalSale()+ Double.parseDouble(values[9]));
198
							faSalesSnapshot.setTotalSale(faSalesSnapshot.getTotalSale()+ Double.parseDouble(values[9]));
197
							}else{
-
 
198
								faSalesSnapshot.setTotalOrderCount(faSalesSnapshot.getTotalOrderCount()+0);
-
 
199
								faSalesSnapshot.setTotalSale(faSalesSnapshot.getTotalSale()+ 0);
-
 
200
								faSalesSnapshot.setReturnQuantity(faSalesSnapshot.getReturnQuantity()+Integer.parseInt(values[13]));
-
 
201
								faSalesSnapshot.setReturnValue(faSalesSnapshot.getReturnValue()+Double.parseDouble(values[9]));
-
 
202
							}
-
 
203
							Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(date_key);
-
 
204
							itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
-
 
205
							orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
-
 
206
						} else{
-
 
207
							faSalesSnapshot = new FlipkartFaSalesSnapshot();
-
 
208
							faSalesSnapshot.setDateOfSale(date_key.getTime());
-
 
209
							faSalesSnapshot.setItem_id(Long.parseLong(values[7]));
-
 
210
							faSalesSnapshot.setOurPrice(Double.parseDouble(values[9])/Double.parseDouble(values[13]));
-
 
211
							if(values[12].equalsIgnoreCase("SalesInvoice")){
-
 
212
								faSalesSnapshot.setTotalOrderCount(Integer.parseInt(values[13]));
-
 
213
								faSalesSnapshot.setTotalSale(Double.parseDouble(values[9]));
-
 
214
							}else{
-
 
215
								faSalesSnapshot.setTotalOrderCount(0);
-
 
216
								faSalesSnapshot.setTotalSale(0.0);
-
 
217
								faSalesSnapshot.setReturnQuantity(Integer.parseInt(values[13]));
-
 
218
								faSalesSnapshot.setReturnValue(Double.parseDouble(values[9]));
-
 
219
							}
-
 
220
							faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
-
 
221
							faSalesSnapshot.setIsOutOfStock(false);
-
 
222
							Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(date_key);
-
 
223
							itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
-
 
224
							orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
-
 
225
						}
199
						}
-
 
200
						if(values[12].equalsIgnoreCase("CourierReturnInvoice")||values[12].equalsIgnoreCase("CustomerReturnInvoice")){
-
 
201
							faSalesSnapshot.setTotalOrderCount(faSalesSnapshot.getTotalOrderCount()+0);
-
 
202
							faSalesSnapshot.setTotalSale(faSalesSnapshot.getTotalSale()+0.0);
-
 
203
							faSalesSnapshot.setReturnQuantity(faSalesSnapshot.getReturnQuantity()+Integer.parseInt(values[13]));
-
 
204
							faSalesSnapshot.setReturnValue(faSalesSnapshot.getReturnValue()+Double.parseDouble(values[9]));
-
 
205
						}
-
 
206
						Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(date_key);
-
 
207
						itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
-
 
208
						orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
226
					} else {
209
					} else{
227
						FlipkartFaSalesSnapshot faSalesSnapshot = new FlipkartFaSalesSnapshot();
210
						faSalesSnapshot = new FlipkartFaSalesSnapshot();
228
						faSalesSnapshot.setDateOfSale(date_key.getTime());
211
						faSalesSnapshot.setDateOfSale(date_key.getTime());
229
						faSalesSnapshot.setItem_id(Long.parseLong(values[7]));
212
						faSalesSnapshot.setItem_id(Long.parseLong(values[7]));
230
						faSalesSnapshot.setOurPrice(Double.parseDouble(values[9])/Double.parseDouble(values[13]));
213
						faSalesSnapshot.setOurPrice(Double.parseDouble(values[9])/Double.parseDouble(values[13]));
231
						if(values[12].equalsIgnoreCase("SalesInvoice")){
214
						if(values[12].equalsIgnoreCase("SalesInvoice")){
232
							faSalesSnapshot.setTotalOrderCount(Integer.parseInt(values[13]));
215
							faSalesSnapshot.setTotalOrderCount(Integer.parseInt(values[13]));
233
							faSalesSnapshot.setTotalSale(Double.parseDouble(values[9]));
216
							faSalesSnapshot.setTotalSale(Double.parseDouble(values[9]));
234
						}else{
217
						}
-
 
218
						if(values[12].equalsIgnoreCase("CourierReturnInvoice")||values[12].equalsIgnoreCase("CustomerReturnInvoice")){
235
							faSalesSnapshot.setTotalOrderCount(0);
219
							faSalesSnapshot.setTotalOrderCount(0);
236
							faSalesSnapshot.setTotalSale(0.0);
220
							faSalesSnapshot.setTotalSale(0.0);
237
							faSalesSnapshot.setReturnQuantity(Integer.parseInt(values[13]));
221
							faSalesSnapshot.setReturnQuantity(Integer.parseInt(values[13]));
238
							faSalesSnapshot.setReturnValue(Double.parseDouble(values[9]));
222
							faSalesSnapshot.setReturnValue(Double.parseDouble(values[9]));
239
						}
223
						}
240
						faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
224
						faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
241
						faSalesSnapshot.setIsOutOfStock(false);
225
						faSalesSnapshot.setIsOutOfStock(false);
242
						Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = new HashMap<String,FlipkartFaSalesSnapshot>();
226
						Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(date_key);
243
						itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
227
						itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
244
						orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
228
						orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
245
					}
229
					}
-
 
230
				} else {
-
 
231
					FlipkartFaSalesSnapshot faSalesSnapshot = new FlipkartFaSalesSnapshot();
-
 
232
					faSalesSnapshot.setDateOfSale(date_key.getTime());
-
 
233
					faSalesSnapshot.setItem_id(Long.parseLong(values[7]));
-
 
234
					faSalesSnapshot.setOurPrice(Double.parseDouble(values[9])/Double.parseDouble(values[13]));
-
 
235
					if(values[12].equalsIgnoreCase("SalesInvoice")){
-
 
236
						faSalesSnapshot.setTotalOrderCount(Integer.parseInt(values[13]));
-
 
237
						faSalesSnapshot.setTotalSale(Double.parseDouble(values[9]));
-
 
238
					}
-
 
239
					if(values[12].equalsIgnoreCase("CourierReturnInvoice")||values[12].equalsIgnoreCase("CustomerReturnInvoice")){
-
 
240
						faSalesSnapshot.setTotalOrderCount(0);
-
 
241
						faSalesSnapshot.setTotalSale(0.0);
-
 
242
						faSalesSnapshot.setReturnQuantity(Integer.parseInt(values[13]));
-
 
243
						faSalesSnapshot.setReturnValue(Double.parseDouble(values[9]));
-
 
244
					}
-
 
245
					faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
-
 
246
					faSalesSnapshot.setIsOutOfStock(false);
-
 
247
					Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = new HashMap<String,FlipkartFaSalesSnapshot>();
-
 
248
					itemIdFaSnapshotMap.put(values[7], faSalesSnapshot);
-
 
249
					orderDateItemIdFbaSaleSnapshotMap.put(date_key, itemIdFaSnapshotMap);
-
 
250
				}
246
					i++;
251
				i++;
247
			}
252
			}
248
			
253
 
249
			for(Long itemId : skuInventoryPriceMap.keySet()){
254
			for(Long itemId : skuInventoryPriceMap.keySet()){
250
				for(Date dateOfSale : orderDateItemIdFbaSaleSnapshotMap.keySet()){
255
				for(Date dateOfSale : orderDateItemIdFbaSaleSnapshotMap.keySet()){
251
					if(orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale).containsKey(itemId.toString())){
256
					if(orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale).containsKey(itemId.toString())){
252
						continue;
257
						continue;
253
					}else{
258
					}else{
Line 263... Line 268...
263
						faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
268
						faSalesSnapshot.setFcLocation(FlipkartFCWarehouseLocation.Delhi);
264
						orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale).put(itemId.toString(), faSalesSnapshot);
269
						orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale).put(itemId.toString(), faSalesSnapshot);
265
					}
270
					}
266
				}
271
				}
267
			}
272
			}
268
			
273
 
269
			for(Date dateOfSale : orderDateItemIdFbaSaleSnapshotMap.keySet()){
274
			for(Date dateOfSale : orderDateItemIdFbaSaleSnapshotMap.keySet()){
270
				Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale);
275
				Map<String,FlipkartFaSalesSnapshot> itemIdFaSnapshotMap = orderDateItemIdFbaSaleSnapshotMap.get(dateOfSale);
271
				for(String itemId : itemIdFaSnapshotMap.keySet()){
276
				for(String itemId : itemIdFaSnapshotMap.keySet()){
272
					flipkartFaSalesSnapshotList.add(itemIdFaSnapshotMap.get(itemId));
277
					flipkartFaSalesSnapshotList.add(itemIdFaSnapshotMap.get(itemId));
273
				}
278
				}
274
			}
279
			}
275
			boolean valuesUpdated = FlipkartConsumer.bulkAddOrUpdateFlipkartFbaSalesSnapshot(flipkartFaSalesSnapshotList);
280
			boolean valuesUpdated = FlipkartConsumer.bulkAddOrUpdateFlipkartFbaSalesSnapshot(flipkartFaSalesSnapshotList);
276
			
281
 
277
			if(valuesUpdated){
282
			if(valuesUpdated){
278
				System.out.println("Values are updated");
283
				System.out.println("Values are updated");
279
			}
284
			}
280
 
285
 
281
		}
286
		}
282
		catch(Exception e){
287
		catch(Exception e){
283
			String[] sendTo = new String[] { "manish.sharma@shop2020.in","kshitij.sood@shop2020.in","amit.gupta@shop2020.in","anikendra.das@shop2020.in"};
288
			String[] sendTo = new String[] { "manish.sharma@shop2020.in","kshitij.sood@shop2020.in","amit.gupta@shop2020.in","anikendra.das@shop2020.in"};
284
	        String emailSubjectTxt = "Error while generating Flipkart Sale Snapshot";
289
			String emailSubjectTxt = "Error while generating Flipkart Sale Snapshot";
285
	        String message = "Run FlipkartFaSaleSnapshotGetter in Common Project. \nSend all Flipkart Reports Again. \nJobs are configured at Support-backup Machine";
290
			String message = "Run FlipkartFaSaleSnapshotGetter in Common Project. \nSend all Flipkart Reports Again. \nJobs are configured at Support-backup Machine";
286
	        try {
291
			try {
287
	            GmailUtils mailer = new GmailUtils();
292
				GmailUtils mailer = new GmailUtils();
288
	            mailer.sendSSLMessage(sendTo, emailSubjectTxt, message, "build-staging@shop2020.in", "shop2020", new ArrayList<File>());
293
				mailer.sendSSLMessage(sendTo, emailSubjectTxt, message, "build-staging@shop2020.in", "shop2020", new ArrayList<File>());
289
	        } catch (Exception ex) {
294
			} catch (Exception ex) {
290
	            ex.printStackTrace();
295
				ex.printStackTrace();
291
	            
296
 
292
	        }
297
			}
293
		}
298
		}
294
	}
299
	}
295
}
300
}
296
301