Rev 12756 | Rev 13181 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
package in.shop2020.serving.services;import java.io.BufferedReader;import java.io.File;import java.io.IOException;import java.io.InputStreamReader;import java.util.ArrayList;import java.util.Calendar;import java.util.GregorianCalendar;import java.util.List;import in.shop2020.model.v1.order.FlipkartOrder;import in.shop2020.model.v1.order.TransactionServiceException;import in.shop2020.serving.model.Order;import in.shop2020.serving.model.OrderItems;import in.shop2020.thrift.clients.TransactionClient;import in.shop2020.utils.GmailUtils;import org.apache.http.HttpResponse;import org.apache.http.NameValuePair;import org.apache.http.client.HttpClient;import org.apache.http.client.entity.UrlEncodedFormEntity;import org.apache.http.client.methods.HttpGet;import org.apache.http.client.methods.HttpPost;import org.apache.http.impl.client.DefaultHttpClient;import org.apache.http.message.BasicNameValuePair;import org.apache.thrift.TException;import org.apache.thrift.transport.TTransportException;import org.json.JSONArray;import org.json.JSONException;import org.json.JSONObject;import com.google.gson.Gson;public class FlipkartHoldOrdersReconciliation{private static String sendTo[] = new String[]{ "sandeep.sachdeva@shop2020.in", "eng@shop2020.in" ,"khushal.bhatia@shop2020.in","manoj.kumar@saholic.com","chaitnaya.vats@saholic.com","yukti.jain@shop2020.in","chandan.kumar@shop2020.in","ankush.dhingra@shop2020.in"};private static java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd-HH:mm:ss");private static Calendar cal=GregorianCalendar.getInstance();private static String emailFromAddress = "build-staging@shop2020.in";private static String password = "shop2020";private static GmailUtils mailer = new GmailUtils();public static void main(String[] args) throws TException, TransactionServiceException, JSONException {HttpClient client = new DefaultHttpClient();HttpPost post = new HttpPost("https://seller.flipkart.com/login");BufferedReader rd= null;try {List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();nameValuePairs.add(new BasicNameValuePair("authName","flipkart"));nameValuePairs.add(new BasicNameValuePair("username","flipkart-support@saholic.com"));nameValuePairs.add(new BasicNameValuePair("password","076c27ee24d7596b06608a8ed2559f87"));post.addHeader("Cookie","T=TI141147280750274359991498309202525657388536723248248488328249492067; __sonar=16983180403917152637; __gads=ID=c15eba68f7f44861:T=1411472817:S=ALNI_MYyU0QfJ923BqkcDhqFlRpZxMcA8w; cmp_id=hp_dotd_4_DOTDOnBajajMixerGrinder_Sep23.|1414064820638; S=d1t16GpsIdt0JTsYuFF%2FMaE7jTGYozxMXM5a3ktJD24TBohceobkUv8l4GDr4KNLkLs5BOgnhsqkZNQRh2Lzrx%2B77zQ%3D%3D; km_lv=x; __utma=19769839.1065606807.1411472808.1411472808.1411624009.2; __utmc=19769839; __utmz=19769839.1411472808.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); s_cc=true; s_sq=%5B%5BB%5D%5D; prd_day=2|1411645620637; s_ppv=21; SN=2.VI89D3B4F7B5534B3C9EADE3BBD925875A.SI05ED43E07EAF40E9B4F265F5F2B1074D.VS141162400679268773093.1411624676; VID=2.VI89D3B4F7B5534B3C9EADE3BBD925875A.1411624676.VS141162400679268773093; NSID=2.SI05ED43E07EAF40E9B4F265F5F2B1074D.1411624676.VI89D3B4F7B5534B3C9EADE3BBD925875A; connect.sid=s%3AaUlfUN00goYPkqRHXtAbM6Nh.EBDDk9%2F0rQDXGb%2B23IEJ4QgrAgKFpXU%2FLOjuQyxJo44; is_login=true; sellerId=m2z93iskuj81qiid; __utma=143439159.1617147053.1411568832.1411568832.1411624688.2; __utmb=143439159.17.10.1411624688; __utmc=143439159; __utmz=143439159.1411568832.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); _ga=GA1.2.1617147053.1411568832; _gat=1; kvcd=1411627978463; km_ai=m2z93iskuj81qiid; km_ni=m2z93iskuj81qiid; km_vs=1; km_uq=");post.addHeader("User-agent", "Mozilla/4.0");post.addHeader("Referer", "seller.flipkart.com");post.setEntity(new UrlEncodedFormEntity(nameValuePairs,"utf-8"));HttpResponse response = client.execute(post);rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));String line = "";HttpGet get_new;List<FlipkartOrder> pendingOrderList = new ArrayList<FlipkartOrder>();List<FlipkartOrder> acceptedOrderList = new ArrayList<FlipkartOrder>();List<FlipkartOrder> cancelledOrderList = new ArrayList<FlipkartOrder>();List<FlipkartOrder> errorOrderList = new ArrayList<FlipkartOrder>();while ((line = rd.readLine()) != null) {System.out.println(line);}//https://seller.flipkart.com/order_management/search_order_items?order_id=OD40827062297&sellerId=m2z93iskuj81qiidTransactionClient transactionServiceClient = new TransactionClient();in.shop2020.model.v1.order.TransactionService.Client tClient = transactionServiceClient.getClient();List<FlipkartOrder> pendingFkOrdersList = tClient.getVerificationPendingOrdersFK();StringBuffer sb = new StringBuffer();StringBuffer resB = new StringBuffer();for(FlipkartOrder fkOrder : pendingFkOrdersList){get_new = new HttpGet("https://seller.flipkart.com/order_management/search_order_items?order_id="+fkOrder.getFlipkartOrderId()+"&sellerId=m2z93iskuj81qiid");get_new.addHeader("Cookie","T=TI141147280750274359991498309202525657388536723248248488328249492067; __sonar=16983180403917152637; __gads=ID=c15eba68f7f44861:T=1411472817:S=ALNI_MYyU0QfJ923BqkcDhqFlRpZxMcA8w; cmp_id=hp_dotd_4_DOTDOnBajajMixerGrinder_Sep23.|1414064820638; S=d1t16GpsIdt0JTsYuFF%2FMaE7jTGYozxMXM5a3ktJD24TBohceobkUv8l4GDr4KNLkLs5BOgnhsqkZNQRh2Lzrx%2B77zQ%3D%3D; km_lv=x; __utma=19769839.1065606807.1411472808.1411472808.1411624009.2; __utmc=19769839; __utmz=19769839.1411472808.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); s_cc=true; s_sq=%5B%5BB%5D%5D; prd_day=2|1411645620637; s_ppv=21; SN=2.VI89D3B4F7B5534B3C9EADE3BBD925875A.SI05ED43E07EAF40E9B4F265F5F2B1074D.VS141162400679268773093.1411624676; VID=2.VI89D3B4F7B5534B3C9EADE3BBD925875A.1411624676.VS141162400679268773093; NSID=2.SI05ED43E07EAF40E9B4F265F5F2B1074D.1411624676.VI89D3B4F7B5534B3C9EADE3BBD925875A; connect.sid=s%3AaUlfUN00goYPkqRHXtAbM6Nh.EBDDk9%2F0rQDXGb%2B23IEJ4QgrAgKFpXU%2FLOjuQyxJo44; is_login=true; sellerId=m2z93iskuj81qiid;__utma=143439159.1617147053.1411568832.1411568832.1411624688.2; __utmb=143439159.17.10.1411624688; __utmc=143439159; __utmz=143439159.1411568832.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); _ga=GA1.2.1617147053.1411568832; _gat=1; kvcd=1411627978463; km_ai=m2z93iskuj81qiid; km_ni=m2z93iskuj81qiid; km_vs=1; km_uq=");response = client.execute(get_new);rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));line = "";line = rd.readLine();JSONObject jsonDataObj = null;JSONArray jsonObjArr = null;if(line == null || line.isEmpty()){sb.append("Flipkart Order Id -"+ fkOrder.getFlipkartOrderId()+" Response - "+line);sb.append("\n");continue;} else if (!line.startsWith("{")){sb.append("Flipkart Order Id -"+ fkOrder.getFlipkartOrderId()+" Response - "+line);sb.append("\n");continue;}else{jsonDataObj = new JSONObject(line);}if(jsonDataObj!=null){jsonObjArr = new JSONArray(jsonDataObj.get("items").toString());}if(jsonObjArr!=null && jsonObjArr.length()>0){JSONObject jsonObj = null;jsonObj = jsonObjArr.getJSONObject(0);if(jsonObj!=null){if(jsonObj.get("status")!=null){String status = jsonObj.get("status").toString();String statusLabel = jsonObj.get("statusLabel").toString();if("on_hold".equalsIgnoreCase(status) || "On hold".equalsIgnoreCase(statusLabel)){pendingOrderList.add(fkOrder);}if("approved".equalsIgnoreCase(status) || "Approved".equalsIgnoreCase(statusLabel) || "confirmed".equalsIgnoreCase(statusLabel)){if(tClient ==null || !tClient.isAlive()){tClient = transactionServiceClient.getClient();}tClient.verifyOrder(fkOrder.getOrderId());tClient.acceptOrder(fkOrder.getOrderId());acceptedOrderList.add(fkOrder);}if("cancelled".equalsIgnoreCase(status) || "Cancelled".equalsIgnoreCase(statusLabel)){if(tClient ==null || !tClient.isAlive()){tClient = transactionServiceClient.getClient();}tClient.refundOrder(fkOrder.getOrderId(), "flipkart", "As per Buyer's Request");cancelledOrderList.add(fkOrder);}}else{errorOrderList.add(fkOrder);}}}}resB.append("Still Pending Orders:-\n");System.out.println("Still Pending Orders:-");for(FlipkartOrder order: pendingOrderList){resB.append(order.getOrderId()+" "+ order.getFlipkartOrderId()+"\n");System.out.println(order.getOrderId()+" "+ order.getFlipkartOrderId());}resB.append("Accepeted Orders:-\n");System.out.println("Accepeted Orders:-");for(FlipkartOrder order: acceptedOrderList){resB.append(order.getOrderId()+" "+ order.getFlipkartOrderId()+"\n");System.out.println(order.getOrderId()+" "+ order.getFlipkartOrderId());}resB.append("Cancelled Orders:-\n");System.out.println("Cancelled Orders:-");for(FlipkartOrder order: cancelledOrderList){resB.append(order.getOrderId()+" "+ order.getFlipkartOrderId()+"\n");System.out.println(order.getOrderId()+" "+ order.getFlipkartOrderId());}resB.append("Response not found Orders:-\n");System.out.println("Response not found Orders:-");for(FlipkartOrder order: errorOrderList){resB.append(order.getOrderId()+" "+ order.getFlipkartOrderId()+"\n");System.out.println(order.getOrderId()+" "+ order.getFlipkartOrderId());}String emailSubjectTxt = " Flipkart Hold Order Reconcilaition Process "+sdf.format(cal.getTime());mailer.sendSSLMessage(sendTo, emailSubjectTxt, resB.toString(), emailFromAddress, password, new ArrayList<File>());System.out.println(sb.toString());} catch (Exception e) {e.printStackTrace();}}}