Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
8616 vikram.rag 1
package in.shop2020;
2
 
3
import in.shop2020.model.v1.catalog.CatalogService;
4
import in.shop2020.model.v1.catalog.CatalogServiceException;
5
import in.shop2020.model.v1.catalog.Item;
6
import in.shop2020.model.v1.inventory.InventoryService;
7
import in.shop2020.model.v1.inventory.InventoryServiceException;
8
import in.shop2020.model.v1.inventory.VendorItemPricing;
9
import in.shop2020.model.v1.inventory.Warehouse;
10
import in.shop2020.model.v1.order.LineItem;
11
import in.shop2020.model.v1.order.OrderStatus;
12
import in.shop2020.model.v1.order.OrderType;
13
import in.shop2020.model.v1.order.SnapdealOrder;
14
import in.shop2020.model.v1.order.SourceDetail;
15
import in.shop2020.model.v1.order.Transaction;
16
import in.shop2020.model.v1.order.TransactionStatus;
17
import in.shop2020.model.v1.order.TransactionService.Client;
18
import in.shop2020.model.v1.user.User;
19
import in.shop2020.payments.PaymentException;
20
import in.shop2020.payments.PaymentStatus;
21
import in.shop2020.thrift.clients.CatalogClient;
22
import in.shop2020.thrift.clients.InventoryClient;
23
import in.shop2020.thrift.clients.PaymentClient;
24
import in.shop2020.thrift.clients.TransactionClient;
25
import in.shop2020.thrift.clients.UserClient;
26
 
27
import java.io.File;
28
import java.text.SimpleDateFormat;
29
import java.util.ArrayList;
30
import java.util.Calendar;
31
import java.util.Collections;
32
import java.util.Date;
33
import java.util.List;
34
import java.util.TimeZone;
35
 
36
import javax.xml.bind.JAXBContext;
37
import javax.xml.bind.JAXBException;
38
import javax.xml.bind.Marshaller;
39
import javax.xml.bind.Unmarshaller;
40
 
41
import org.apache.thrift.TException;
42
import org.apache.thrift.transport.TTransportException;
8645 vikram.rag 43
import org.slf4j.Logger;
44
import org.slf4j.LoggerFactory;
8616 vikram.rag 45
 
46
import order.SaholicAPI;
47
import order.ObjectFactory;
48
import order.SaholicAPI.Order;
49
 
50
public class ProcessSnapdealOrder {
8627 vikram.rag 51
	//private static final int SNAPDEAL_SOURCE_ID = 3;
8616 vikram.rag 52
	private static final int SNAPDEAL_SOURCE_ID = 7;
53
	private static final String FIRSTFLIGHT = "First Flight";
8627 vikram.rag 54
	private static final String DELHIVERY = "DELHIVERY";
55
	private static final String BLUEDART = "Bluedart";
8642 vikram.rag 56
	private static final String CHHOTU = "CHHOTU";
8627 vikram.rag 57
	private static String transactionId;
58
	private static final int SNAPDEAL_GATEWAY_ID = 18;
8645 vikram.rag 59
	private static Logger logger = LoggerFactory.getLogger(ProcessSnapdealOrder.class);
8627 vikram.rag 60
 
8616 vikram.rag 61
	public static void processSnapdealOrders(File file) throws JAXBException{
62
		JAXBContext jc = JAXBContext.newInstance(SaholicAPI.class);
63
		Unmarshaller unmarshaller = jc.createUnmarshaller();
64
		SaholicAPI orders = (SaholicAPI) unmarshaller.unmarshal(file);
65
		Marshaller marshaller = jc.createMarshaller();
66
		marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
67
		marshaller.marshal(orders, System.out);
68
		SourceDetail sourceDetail = null;
69
		User user = null;
70
		TransactionClient tsc = null;
71
		try {
72
			tsc = new TransactionClient();
73
			sourceDetail = tsc.getClient().getSourceDetail(SNAPDEAL_SOURCE_ID);
74
		} catch (Exception e) {
8645 vikram.rag 75
			logger.error("Unable to establish connection to the transaction service while getting Snapdeal Source Detail", e);
8616 vikram.rag 76
		}
77
		try {   
78
			in.shop2020.model.v1.user.UserContextService.Client userClient = new UserClient().getClient();
79
			user = userClient.getUserByEmail(sourceDetail.getEmail());
80
		} catch (Exception e) {
8645 vikram.rag 81
	        logger.error("Unable to establish connection to the User service", e);
8616 vikram.rag 82
		}
83
		for(Order order:orders.getOrder()){
8627 vikram.rag 84
			long subOrderId = (long) order.getSuborderId();
85
			Client transaction_client = null;
86
			try {
87
				transaction_client = new TransactionClient().getClient();
88
				//transaction_client.snapdealOrderExists(subOrderId);
89
				System.out.println("Suborder id " + subOrderId);
90
				if(transaction_client.snapdealOrderExists(subOrderId)) {
91
					System.out.println("Suborder id exists");
92
					continue;
93
				}
94
 
95
			} catch (TTransportException e1) {
96
				// TODO Auto-generated catch block
97
				e1.printStackTrace();
98
			} catch (TException e) {
99
				// TODO Auto-generated catch block
100
				e.printStackTrace();
101
			}
102
			System.out.println("Inside Order Parsing");
8616 vikram.rag 103
			Transaction txn = new Transaction();
8627 vikram.rag 104
			System.out.println("User details are " + user.getActiveCartId());
8616 vikram.rag 105
			txn.setShoppingCartid(user.getActiveCartId());
8627 vikram.rag 106
			System.out.println("transaction created");
8616 vikram.rag 107
			txn.setCustomer_id(user.getUserId());
8627 vikram.rag 108
			System.out.println("User Id is " + user.getUserId());
8616 vikram.rag 109
			txn.setCreatedOn(new Date().getTime());
110
			txn.setTransactionStatus(TransactionStatus.INIT);
111
			txn.setStatusDescription("Order for Snapdeal ");
112
			List<in.shop2020.model.v1.order.Order> orderlist = new ArrayList<in.shop2020.model.v1.order.Order>();
113
			LineItem lineItem = null;
114
			try {
115
				lineItem = createLineItem(order.getSKUCode(),order.getSellingPricePerItem());
8627 vikram.rag 116
				System.out.println("Line item created");
8616 vikram.rag 117
			} catch (CatalogServiceException e) {
8645 vikram.rag 118
				logger.error("Unable to create order for suborderid  " + order.getSuborderId());
8616 vikram.rag 119
				e.printStackTrace();
120
			} catch (TException e) {
8645 vikram.rag 121
				logger.error("Unable to create order for suborderid  " + order.getSuborderId());
8616 vikram.rag 122
				e.printStackTrace();
123
			}
124
			in.shop2020.model.v1.order.Order t_order = new in.shop2020.model.v1.order.Order();
8627 vikram.rag 125
			t_order.setCustomer_id(user.getUserId());
126
			t_order.setCustomer_email(sourceDetail.getEmail());
127
			t_order.setCustomer_name(order.getCustomerName());
128
			t_order.setCustomer_address1("");
129
			t_order.setCustomer_address2("");
130
			t_order.setCustomer_city(order.getCity());
131
			t_order.setCustomer_state(order.getState());
132
			t_order.setCustomer_pincode(String.valueOf(order.getPINCode()));
133
			t_order.setTotal_amount(lineItem.getTotal_price());            
134
			t_order.setTotal_weight(lineItem.getTotal_weight());
135
			t_order.setLineitems(Collections.singletonList(lineItem));            
136
			t_order.setStatus(OrderStatus.SUBMITTED_FOR_PROCESSING);
137
			t_order.setStatusDescription("In Process");
138
			t_order.setCreated_timestamp(new Date().getTime());
139
			t_order.setOrderType(OrderType.B2C);
140
			t_order.setCod(false);
141
			System.out.println("t order created");
142
			try {
143
				Calendar time = Calendar.getInstance();
144
				time.add(Calendar.DAY_OF_MONTH, 1);
145
				t_order.setPromised_shipping_time(time.getTimeInMillis());
146
				t_order.setExpected_shipping_time(time.getTimeInMillis());
147
				time.add(Calendar.DAY_OF_MONTH, 3);
148
				t_order.setPromised_delivery_time(time.getTimeInMillis());
149
				t_order.setExpected_delivery_time(time.getTimeInMillis());
150
				System.out.println("Dates set in transaction");
151
			} catch(Exception e) {
8645 vikram.rag 152
				logger.error("Error in updating Shipping or Delivery Time for suborderid  " + order.getSuborderId());
8627 vikram.rag 153
				continue;
154
			}
155
			/*InventoryService.Client inventoryClient = null;
156
            //Warehouse fulfillmentWarehouse= null; 
8616 vikram.rag 157
            try {
8627 vikram.rag 158
            	//inventoryClient = new InventoryClient().getClient();
159
        		//VendorItemPricing vendorItemPricing = inventoryClient.getItemPricing(lineItem.getItem_id(), fulfillmentWarehouse.getVendor().getId());
160
        		//t_order.getLineitems().get(0).setTransfer_price(vendorItemPricing.getTransferPrice());
161
        		//t_order.getLineitems().get(0).setNlc(vendorItemPricing.getNlc());
8616 vikram.rag 162
			} catch (InventoryServiceException e) {
163
            	continue;
164
			} catch (TTransportException e) {
165
				// TODO Auto-generated catch block
166
				e.printStackTrace();
167
			} catch (TException e) {
168
				// TODO Auto-generated catch block
169
				e.printStackTrace();
8627 vikram.rag 170
			}*/
8616 vikram.rag 171
			if(order.getCourier().equalsIgnoreCase(FIRSTFLIGHT)) {
172
				t_order.setLogistics_provider_id(12);
173
			} else if(order.getCourier().equalsIgnoreCase(DELHIVERY)) {
174
				t_order.setLogistics_provider_id(13);
175
			} else if(order.getCourier().equalsIgnoreCase(BLUEDART)) {
176
				t_order.setLogistics_provider_id(14);
8642 vikram.rag 177
			}else if(order.getCourier().equalsIgnoreCase(CHHOTU)) {
178
				t_order.setLogistics_provider_id(16);
8616 vikram.rag 179
			} else {
8645 vikram.rag 180
				logger.error("Error No Courier Match please add courier to our system");
8627 vikram.rag 181
				continue;
8616 vikram.rag 182
			}
8627 vikram.rag 183
 
8616 vikram.rag 184
			t_order.setAirwaybill_no(String.valueOf(order.getAWBNumber()));
185
			t_order.setTracking_id(String.valueOf(order.getAWBNumber()));
8627 vikram.rag 186
			t_order.setTotal_amount(order.getSellingPricePerItem());
187
			t_order.setOrderType(OrderType.B2C);
188
			t_order.setSource(SNAPDEAL_SOURCE_ID);
189
			t_order.setOrderType(OrderType.B2C);
190
			orderlist.add(t_order);
191
			txn.setOrders(orderlist);
8616 vikram.rag 192
			try {
8627 vikram.rag 193
				String referenceCode = order.getReferenceCode();
194
				String productName = order.getProduct();
195
				SimpleDateFormat istFormatter = new SimpleDateFormat("dd/mm/yyyy");
196
				//SimpleDateFormat istFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
197
				Date snapdealTxnDate = istFormatter.parse(order.getOrderPlacedDate());
198
				transactionId =  String.valueOf(transaction_client.createTransaction(txn));
199
				createPayment(user, (new Long(subOrderId)).toString(), lineItem.getTotal_price());
200
 
201
				Transaction transaction = transaction_client.getTransaction(Long.parseLong(transactionId));
202
				in.shop2020.model.v1.order.Order snapdealorder = transaction.getOrders().get(0);
203
 
204
				//inventoryClient.reserveItemInWarehouse(lineItem.getItem_id(), fulfillmentWarehouse.getId(), 1, 
205
				//		snapdealorder.getId(), snapdealorder.getCreated_timestamp(), snapdealorder.getPromised_shipping_time(), snapdealorder.getLineitems().get(0).getQuantity());
206
 
207
 
208
				SnapdealOrder snapdealOrder = new SnapdealOrder();
209
				snapdealOrder.setOrderId(snapdealorder.getId());
210
				snapdealOrder.setSubOrderId(subOrderId);
211
				snapdealOrder.setReferenceCode(referenceCode);
212
				snapdealOrder.setProductName(productName);
213
				snapdealOrder.setSnapdealTxnDate(snapdealTxnDate.getTime());
214
				snapdealOrder.setListingPrice(lineItem.getTotal_price());
215
				transaction_client.createSnapdealOrder(snapdealOrder);
216
 
8645 vikram.rag 217
			} catch (TException e) {
218
				logger.error("Error in creating payment  " + order.getSuborderId());
8627 vikram.rag 219
				continue;
8616 vikram.rag 220
			}
8645 vikram.rag 221
			catch (PaymentException e) {
222
				logger.error("Error in creating payment  " + order.getSuborderId());
223
				continue;
224
			}
225
			catch (Exception e) {
226
				logger.error("Error in creating transaction  " + order.getSuborderId());
227
				continue;
228
			}
8616 vikram.rag 229
		}
230
 
231
	}
232
 
233
	public static void createPayment(User user, String subOrderId, double amount) throws NumberFormatException, PaymentException, TException {
8627 vikram.rag 234
		in.shop2020.payments.PaymentService.Client client = new PaymentClient().getClient();
235
		long paymentId = client.createPayment(user.getUserId(), amount, SNAPDEAL_GATEWAY_ID, Long.valueOf(transactionId), false);
236
		client.updatePaymentDetails(paymentId, null, null, null, null, null, null, subOrderId, null, PaymentStatus.AUTHORIZED, null, null);
237
	}   
238
 
8616 vikram.rag 239
	public static LineItem createLineItem(long itemId, double amount) throws CatalogServiceException, TException {
8627 vikram.rag 240
		LineItem lineItem = new LineItem();
241
		CatalogService.Client catalogClient = new CatalogClient().getClient();
242
		Item item = catalogClient.getItem(itemId);
8616 vikram.rag 243
 
8627 vikram.rag 244
		lineItem.setProductGroup(item.getProductGroup());
245
		lineItem.setBrand(item.getBrand());
246
		lineItem.setModel_number(item.getModelNumber());
247
		lineItem.setModel_name(item.getModelName());
248
		lineItem.setExtra_info(item.getFeatureDescription());
249
		lineItem.setQuantity(1);
250
		lineItem.setItem_id(item.getId());
251
		lineItem.setUnit_weight(item.getWeight());
252
		lineItem.setTotal_weight(item.getWeight());
253
		lineItem.setUnit_price(amount);
254
		lineItem.setTotal_price(amount);
255
 
256
		if (item.getColor() == null || "NA".equals(item.getColor())) {
257
			lineItem.setColor("");
258
		} else {
259
			lineItem.setColor(item.getColor());
260
		}
261
		return lineItem;
8616 vikram.rag 262
	}
263
 
264
}