Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
2674 vikas 1
package in.shop2020.serving.controllers;
2
 
4689 anupam.sin 3
import in.shop2020.crm.Activity;
4
import in.shop2020.crm.ActivityType;
3578 mandeep.dh 5
import in.shop2020.crm.SearchFilter;
6
import in.shop2020.crm.Ticket;
7
import in.shop2020.crm.TicketCategory;
4689 anupam.sin 8
import in.shop2020.crm.TicketPriority;
3578 mandeep.dh 9
import in.shop2020.crm.TicketStatus;
2674 vikas 10
import in.shop2020.model.v1.order.LineItem;
11
import in.shop2020.model.v1.order.Order;
3578 mandeep.dh 12
import in.shop2020.model.v1.order.OrderStatus;
4689 anupam.sin 13
import in.shop2020.model.v1.order.TransactionServiceException;
4142 mandeep.dh 14
import in.shop2020.model.v1.user.Address;
4689 anupam.sin 15
import in.shop2020.model.v1.user.UserContextException;
2728 vikas 16
import in.shop2020.payments.Attribute;
17
import in.shop2020.payments.Constants;
2674 vikas 18
import in.shop2020.payments.Payment;
2728 vikas 19
import in.shop2020.payments.PaymentException;
4142 mandeep.dh 20
import in.shop2020.payments.PaymentService.Client;
4689 anupam.sin 21
import in.shop2020.serving.auth.CRMAuthorizingRealm;
3090 mandeep.dh 22
import in.shop2020.serving.model.ShipmentUpdate;
23
import in.shop2020.serving.services.BlueDartTrackingService;
4710 anupam.sin 24
import in.shop2020.serving.services.AramexTrackingService;
3578 mandeep.dh 25
import in.shop2020.thrift.clients.CRMClient;
3128 rajveer 26
import in.shop2020.thrift.clients.PaymentClient;
27
import in.shop2020.thrift.clients.TransactionClient;
4142 mandeep.dh 28
import in.shop2020.thrift.clients.UserClient;
3546 mandeep.dh 29
import in.shop2020.utils.ModelUtils;
2674 vikas 30
 
31
import java.util.ArrayList;
4416 mandeep.dh 32
import java.util.Collections;
4689 anupam.sin 33
import java.util.HashSet;
2674 vikas 34
import java.util.List;
4689 anupam.sin 35
import java.util.Set;
4416 mandeep.dh 36
import java.util.concurrent.Callable;
37
import java.util.concurrent.Executors;
38
import java.util.concurrent.TimeUnit;
2674 vikas 39
 
4689 anupam.sin 40
import net.htmlparser.jericho.Source;
41
 
2674 vikas 42
import org.apache.log4j.Logger;
2728 vikas 43
import org.apache.thrift.TException;
4142 mandeep.dh 44
import org.apache.thrift.transport.TTransportException;
2674 vikas 45
 
46
/**
47
 * @author vikas
3578 mandeep.dh 48
 * 
2674 vikas 49
 */
50
@SuppressWarnings("serial")
51
public class UserOrderInfoController extends BaseController {
3578 mandeep.dh 52
    private static Logger                  log                     = Logger.getLogger(Class.class);
3090 mandeep.dh 53
    private static BlueDartTrackingService blueDartTrackingService = new BlueDartTrackingService();
4710 anupam.sin 54
    private static AramexTrackingService aramexTrackingService     = new AramexTrackingService();
3090 mandeep.dh 55
 
4142 mandeep.dh 56
    private long                 orderId;
57
    private Order                order;
58
    private List<Payment>        payments;
4416 mandeep.dh 59
    private List<ShipmentUpdate> shipmentUpdates = new ArrayList<ShipmentUpdate>();
4142 mandeep.dh 60
    private Long                 codTicketId;
61
    private List<Address>        addresses;
4689 anupam.sin 62
    private Set<OrderStatus>     setOfcancellableStates;
63
    private String               cancellationInitiator;
64
    private String               cancelReason;
65
    private String               body;
2674 vikas 66
 
3578 mandeep.dh 67
    public UserOrderInfoController() {
2674 vikas 68
        super();
4689 anupam.sin 69
        setOfcancellableStates = new HashSet<OrderStatus>();
70
        setOfcancellableStates.add(OrderStatus.SUBMITTED_FOR_PROCESSING);
71
        setOfcancellableStates.add(OrderStatus.INVENTORY_LOW);
72
        setOfcancellableStates.add(OrderStatus.LOW_INV_PO_RAISED);
73
        setOfcancellableStates.add(OrderStatus.LOW_INV_REVERSAL_IN_PROCESS);
74
        setOfcancellableStates.add(OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT);
75
        setOfcancellableStates.add(OrderStatus.ACCEPTED);
76
        setOfcancellableStates.add(OrderStatus.BILLED);
77
        setOfcancellableStates.add(OrderStatus.PAYMENT_FLAGGED);
2674 vikas 78
    }
79
 
4689 anupam.sin 80
    public String index() {
81
        try {
82
            PaymentClient paymentServiceClient = new PaymentClient();
83
            TransactionClient transactionServiceClient = new TransactionClient();
3090 mandeep.dh 84
 
3499 mandeep.dh 85
            order = transactionServiceClient.getClient().getOrder(orderId);
2674 vikas 86
 
4689 anupam.sin 87
            payments = paymentServiceClient.getClient()
88
            .getPaymentForTxnId(order.getTransactionId());
3090 mandeep.dh 89
 
3578 mandeep.dh 90
 
4689 anupam.sin 91
 
92
            // Spawning a thread to capture shipment updates from Bluedart
93
            // This is done to ensure that response from Crm web app is sent
94
            // within given time limits. Also, we wont be affected in the cases 
95
            // where bluedart site is down or slow
96
            Executors.newSingleThreadExecutor().invokeAll(Collections.singletonList(new Callable<Boolean>() {
97
                public Boolean call() throws Exception {
4710 anupam.sin 98
                    if (order.getLogistics_provider_id() == 1)
99
                        shipmentUpdates = blueDartTrackingService.getUpdates(order.getAirwaybill_no());
100
                    else if (order.getLogistics_provider_id() == 2) {
101
                        shipmentUpdates = aramexTrackingService.getUpdates(order.getAirwaybill_no());
102
                    }
103
                    else {
104
                        log.error("Error : providerId = " + order.getLogistics_provider_id() + "for orderId : " + order.getId());
105
                    }
4689 anupam.sin 106
                    return true;
107
                }
108
            }), 5, TimeUnit.SECONDS);
109
 
110
            if (order.isCod() && OrderStatus.COD_VERIFICATION_PENDING.equals(order.getStatus())) {
111
                populateCODTicketId(order.getCustomer_id());
4416 mandeep.dh 112
            }
113
 
4689 anupam.sin 114
            if (canEditOrderAddress()) {
115
                userContextServiceClient = new UserClient().getClient();
116
                addresses = userContextServiceClient.getAllAddressesForUser(order.getCustomer_id());
117
            }
3578 mandeep.dh 118
 
4689 anupam.sin 119
        } catch (TTransportException e) {
120
            log.error("Unable to create thrift Client", e);
121
        } catch (TransactionServiceException e) {
122
            addActionError("Invalid order id or no order selected.");
123
        } catch (TException e) {
124
            log.error("Unable to get thrift Client", e);
125
        } catch (PaymentException e) {
126
            log.error("Unable to get payments for transctionId : " + order.getTransactionId(), e);
127
        } catch (InterruptedException e) {
128
            log.error("Thread was interrupted", e);
129
        } catch (UserContextException e) {
130
            log.error("Unable to get addresses for user : " + order.getCustomer_id(), e);
4142 mandeep.dh 131
        }
132
        return INDEX;
2674 vikas 133
    }
134
 
4142 mandeep.dh 135
    private boolean canEditOrderAddress() {
136
        return false;
137
    }
138
 
3578 mandeep.dh 139
    private void populateCODTicketId(long customerId) {
140
        try {
141
            SearchFilter searchFilter = new SearchFilter();
142
            searchFilter.setTicketCategory(TicketCategory.COD_VERIFICATION);
143
            searchFilter.setTicketStatuses(new ArrayList<TicketStatus>());
144
            searchFilter.getTicketStatuses().add(TicketStatus.OPEN);
145
            searchFilter.getTicketStatuses().add(TicketStatus.REOPEN);
146
            searchFilter.setCustomerId(customerId);
147
            crmServiceClient = new CRMClient().getClient();
148
            List<Ticket> tickets = crmServiceClient.getTickets(searchFilter);
149
            if (tickets != null && !tickets.isEmpty()) {
150
                codTicketId = tickets.get(0).getId();
151
            }
152
        } catch (TException e) {
153
            log.error("Error fetching tickets for customerId: " + customerId, e);
154
        }
155
    }
156
 
4689 anupam.sin 157
    public String markOrderForCancellation() {
158
        try{
159
            TransactionClient transactionServiceClient = new TransactionClient();
160
            log.info("URL = " + request.getRequestURI());
161
            log.info("Initiator = " + request.getParameter("cancellationInitiator"));
162
            log.info("orderId = " + request.getParameter("orderId"));
163
            if (cancellationInitiator.equals("CUSTOMER")) {
164
                order = transactionServiceClient.getClient().getOrder(orderId);
165
                transactionServiceClient.getClient().markOrderCancellationRequestReceived(orderId);
166
                long creatorId = CRMAuthorizingRealm.getAgent(currentAgentEmailId).getId();
167
                Ticket ticket = new Ticket();
168
                String plainTextbody = "";
169
                if(body!=null && !body.isEmpty()){
170
                    plainTextbody = new Source(body).getTextExtractor().toString();
171
                }
172
                ticket.setDescription("Creating ticket for Cancellation Request Received, Reason : " + cancelReason + " : " + plainTextbody);
173
                ticket.setCreatorId(creatorId);
174
                ticket.setStatus(TicketStatus.OPEN);
175
                ticket.setPriority(TicketPriority.HIGH);
176
                ticket.setCategory(TicketCategory.ORDER_CANCELLATION);
177
                ticket.setOrderId(orderId);
178
 
179
                Activity activity = new Activity();
180
                activity.setDescription("Creating Ticket");
181
                activity.setType(ActivityType.OTHER);
182
                activity.setTicketPriority(TicketPriority.HIGH);
183
                activity.setTicketStatus(TicketStatus.OPEN);
184
                activity.setCreatorId(creatorId);
185
                activity.setTicketDescription("Creating ticket for Cancellation Request Received, Reason : " + cancelReason + " : " + plainTextbody);
186
                activity.setTicketCategory(TicketCategory.ORDER_CANCELLATION);
187
 
188
                ticket.setCustomerId(order.getCustomer_id());
189
                activity.setCustomerId(order.getCustomer_id());
190
                ticket.setCustomerName(order.getCustomer_name());
191
                activity.setCustomerName(order.getCustomer_name());
192
                ticket.setCustomerEmailId(order.getCustomer_email());
193
                activity.setCustomerEmailId(order.getCustomer_email());
194
                ticket.setCustomerMobileNumber(order.getCustomer_mobilenumber());
195
                activity.setCustomerMobileNumber(order.getCustomer_mobilenumber());
196
 
197
                crmServiceClient = new CRMClient().getClient();
198
                crmServiceClient.insertTicket(ticket, activity);
199
            } 
200
            else if (cancellationInitiator.equals("INTERNAL")) {
201
                String plainTextbody = "";
202
                if(body!=null && !body.isEmpty()){
203
                    plainTextbody = new Source(body).getTextExtractor().toString();
204
                }
205
                transactionServiceClient.getClient().refundOrder(orderId, currentAgentEmailId, cancelReason + " : " + plainTextbody);
206
                long creatorId = CRMAuthorizingRealm.getAgent(currentAgentEmailId).getId();
207
                Ticket ticket = new Ticket();
208
                ticket.setDescription("Creating ticket for Order Cancellation due to Low inventory");
209
                ticket.setCreatorId(creatorId);
210
                ticket.setStatus(TicketStatus.CLOSED);
211
                ticket.setPriority(TicketPriority.MEDIUM);
212
                ticket.setCategory(TicketCategory.ORDER_CANCELLATION);
213
                ticket.setOrderId(orderId);
214
 
215
                Activity activity = new Activity();
216
                activity.setDescription("Creating Ticket");
217
                activity.setType(ActivityType.OTHER);
218
                activity.setTicketPriority(TicketPriority.MEDIUM);
219
                activity.setTicketStatus(TicketStatus.CLOSED);
220
                activity.setCreatorId(creatorId);
221
                activity.setTicketCategory(TicketCategory.ORDER_CANCELLATION);
222
                activity.setTicketDescription("Creating ticket for Order Cancellation due to Low inventory");
223
 
224
                ticket.setCustomerId(order.getCustomer_id());
225
                activity.setCustomerId(order.getCustomer_id());
226
                ticket.setCustomerName(order.getCustomer_name());
227
                activity.setCustomerName(order.getCustomer_name());
228
                ticket.setCustomerEmailId(order.getCustomer_email());
229
                activity.setCustomerEmailId(order.getCustomer_email());
230
                ticket.setCustomerMobileNumber(order.getCustomer_mobilenumber());
231
                activity.setCustomerMobileNumber(order.getCustomer_mobilenumber());
232
 
233
                crmServiceClient = new CRMClient().getClient();
234
                crmServiceClient.insertTicket(ticket, activity);
235
            }
236
        } catch(Exception e) {
237
            log.error("Could not mark order for Cancellation, OrderId : " + orderId, e);
238
        }
239
        return index();
240
    }
241
 
242
    public boolean canOrderBeCancelled() {
243
        if (setOfcancellableStates.contains(order.getStatus())) {
244
            return true;
245
        }
246
        return false;
247
    }
248
 
4142 mandeep.dh 249
    public String getPaymentGateway(Payment payment) {
250
        String gatewayName = "";
3578 mandeep.dh 251
 
4142 mandeep.dh 252
        try {
253
            Client paymentServiceClient = new PaymentClient().getClient();
254
            gatewayName = paymentServiceClient.getPaymentGateway(payment.getGatewayId()).getName();
255
        } catch (TTransportException e) {
256
        } catch (PaymentException e) {
257
        } catch (TException e) {
2674 vikas 258
        }
4142 mandeep.dh 259
 
260
        return gatewayName;
2674 vikas 261
    }
262
 
4142 mandeep.dh 263
    public String getProductName(LineItem lineItem) {
264
        String name = ModelUtils.extractProductNameFromLineItem(lineItem);
265
 
4146 mandeep.dh 266
        if (lineItem.getColor() != null && !lineItem.getColor().isEmpty()) {
4142 mandeep.dh 267
            name += "(" + lineItem.getColor() + ")";
2674 vikas 268
        }
4142 mandeep.dh 269
 
270
        return name;
2674 vikas 271
    }
272
 
4142 mandeep.dh 273
    public int convertDouble(double value) {
274
        return (int)value;
2674 vikas 275
    }
3578 mandeep.dh 276
 
4142 mandeep.dh 277
    public String getAddress(Order order) {
278
        return ModelUtils.extractAddressFromOrder(order);
279
    }
280
 
2728 vikas 281
    public String getPaymentMethod(List<Attribute> paymentAttributes) {
282
        String paymentMethod = null;
3578 mandeep.dh 283
        if (paymentAttributes == null || paymentAttributes.isEmpty()) {
2728 vikas 284
            return "N/A";
285
        }
3578 mandeep.dh 286
        for (Attribute a : paymentAttributes) {
287
            if ("payMethod".equals(a.getName())) {
2728 vikas 288
                paymentMethod = Constants.PAYMENT_METHOD.get(a.getValue());
289
                break;
290
            }
291
        }
292
        return paymentMethod != null ? paymentMethod : "N/A";
293
    }
2674 vikas 294
 
295
    public void setOrderId(String orderId) {
296
        try {
297
            this.orderId = Long.parseLong(orderId);
3578 mandeep.dh 298
        } catch (NumberFormatException e) {
2674 vikas 299
            log.error(e);
300
        }
301
    }
302
 
4142 mandeep.dh 303
    public List<Payment> getPayments() {
304
        return payments;
2674 vikas 305
    }
306
 
3090 mandeep.dh 307
    public List<ShipmentUpdate> getShipmentUpdates() {
308
        return shipmentUpdates;
309
    }
310
 
311
    public void setShipmentUpdates(List<ShipmentUpdate> shipmentUpdates) {
312
        this.shipmentUpdates = shipmentUpdates;
313
    }
3499 mandeep.dh 314
 
315
    public Order getOrder() {
316
        return order;
317
    }
318
 
319
    public void setOrder(Order order) {
320
        this.order = order;
321
    }
3578 mandeep.dh 322
 
323
    public Long getCodTicketId() {
324
        return codTicketId;
325
    }
326
 
327
    public void setCodTicketId(Long codTicketId) {
328
        this.codTicketId = codTicketId;
329
    }
4142 mandeep.dh 330
 
331
    public List<Address> getAddresses() {
332
        return addresses;
333
    }
334
 
335
    public void setAddresses(List<Address> addresses) {
336
        this.addresses = addresses;
337
    }
4241 anupam.sin 338
 
339
    public String getOrderStatusDescription(Order order) {
340
        String status = order.getStatus().getDescription();
341
 
342
        if (order.getStatus() == OrderStatus.DELIVERY_SUCCESS) {
343
            status = "Completed";
344
        }
345
 
346
        return status;
347
    }
4689 anupam.sin 348
 
349
    public String getCancellationInitiator() {
350
        return cancellationInitiator;
351
    }
352
 
353
    public void setCancellationInitiator(String cancellationInitiator) {
354
        this.cancellationInitiator = cancellationInitiator;
355
    }
356
 
357
    public String getCancelReason() {
358
        return cancelReason;
359
    }
360
 
361
    public void setCancelReason(String cancelReason) {
362
        this.cancelReason = cancelReason;
363
    }
364
 
365
    public String getBody() {
366
        return body;
367
    }
368
 
369
    public void setBody(String body) {
370
        this.body = body;
371
    }
2674 vikas 372
}