Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21561 ashik.ali 1
package com.spice.profitmandi.web.controller;
21555 kshitij.so 2
 
30289 amit.gupta 3
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
4
import com.spice.profitmandi.common.model.ProfitMandiConstants;
30694 amit.gupta 5
import com.spice.profitmandi.common.model.ScanSerializedRequest;
30289 amit.gupta 6
import com.spice.profitmandi.common.web.client.RestClient;
30694 amit.gupta 7
import com.spice.profitmandi.common.web.util.ResponseSender;
8
import com.spice.profitmandi.dao.entity.fofo.InventoryItem;
30289 amit.gupta 9
import com.spice.profitmandi.dao.entity.transaction.Order;
30694 amit.gupta 10
import com.spice.profitmandi.dao.model.ImeiInoviceModel;
11
import com.spice.profitmandi.dao.repository.fofo.InventoryItemRepository;
30715 amit.gupta 12
import com.spice.profitmandi.dao.repository.fofo.PurchaseRepository;
30289 amit.gupta 13
import com.spice.profitmandi.dao.repository.transaction.OrderRepository;
14
import com.spice.profitmandi.service.authentication.RoleManager;
15
import com.spice.profitmandi.service.inventory.PurchaseService;
30380 amit.gupta 16
import com.spice.profitmandi.service.transaction.invoicing.InvoiceService;
30289 amit.gupta 17
import com.spice.profitmandi.web.model.LoginDetails;
18
import com.spice.profitmandi.web.util.CookiesProcessor;
30394 amit.gupta 19
import org.apache.commons.io.IOUtils;
30289 amit.gupta 20
import org.apache.http.HttpResponse;
30394 amit.gupta 21
import org.apache.http.entity.ContentType;
30289 amit.gupta 22
import org.apache.logging.log4j.LogManager;
23569 govind 23
import org.apache.logging.log4j.Logger;
21574 ashik.ali 24
import org.springframework.beans.factory.annotation.Autowired;
30289 amit.gupta 25
import org.springframework.core.io.InputStreamResource;
26
import org.springframework.http.HttpHeaders;
27
import org.springframework.http.HttpStatus;
30380 amit.gupta 28
import org.springframework.http.MediaType;
30289 amit.gupta 29
import org.springframework.http.ResponseEntity;
21555 kshitij.so 30
import org.springframework.stereotype.Controller;
21636 ashik.ali 31
import org.springframework.transaction.annotation.Transactional;
21574 ashik.ali 32
import org.springframework.ui.Model;
30694 amit.gupta 33
import org.springframework.web.bind.annotation.*;
21555 kshitij.so 34
 
30289 amit.gupta 35
import javax.servlet.http.HttpServletRequest;
30394 amit.gupta 36
import java.io.ByteArrayInputStream;
30380 amit.gupta 37
import java.io.ByteArrayOutputStream;
30289 amit.gupta 38
import java.io.File;
30394 amit.gupta 39
import java.io.InputStream;
30289 amit.gupta 40
import java.time.LocalDateTime;
30380 amit.gupta 41
import java.util.*;
30387 amit.gupta 42
import java.util.stream.Collectors;
30380 amit.gupta 43
import java.util.zip.ZipEntry;
44
import java.util.zip.ZipOutputStream;
21555 kshitij.so 45
 
30395 amit.gupta 46
import static org.springframework.util.FileCopyUtils.BUFFER_SIZE;
47
 
21555 kshitij.so 48
@Controller
30289 amit.gupta 49
@Transactional(rollbackFor = Throwable.class)
21582 kshitij.so 50
public class PurchaseController {
21555 kshitij.so 51
 
31437 amit.gupta 52
    private static final Logger LOGGER = LogManager.getLogger(PurchaseController.class);
53
    @Autowired
54
    RestClient restClient;
55
    @Autowired
56
    private PurchaseService purchaseService;
57
    @Autowired
58
    private PurchaseRepository purchaseRepository;
59
    @Autowired
60
    private InventoryItemRepository inventoryItemRepository;
61
    @Autowired
62
    private OrderRepository orderRepository;
63
    @Autowired
64
    private RoleManager roleManager;
30289 amit.gupta 65
 
31437 amit.gupta 66
    @Autowired
67
    private ResponseSender responseSender;
30289 amit.gupta 68
 
31437 amit.gupta 69
    @Autowired
70
    private CookiesProcessor cookiesProcessor;
30715 amit.gupta 71
 
31437 amit.gupta 72
    @Autowired
73
    private InvoiceService invoiceService;
30694 amit.gupta 74
 
31437 amit.gupta 75
    @RequestMapping(value = "/purchase", method = RequestMethod.GET)
76
    public String purchase(HttpServletRequest request) throws Exception {
77
        return "purchase";
78
    }
21640 kshitij.so 79
 
31437 amit.gupta 80
    @RequestMapping(value = "/pendingGrn", method = RequestMethod.GET)
81
    public String pendingGrn(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
82
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
83
        LOGGER.info("Request Received at url {}", request.getRequestURI());
84
        List<Order> pendingGrns = orderRepository.selectShipmentToDeliveredByRetailerId(fofoDetails.getFofoId());
85
        model.addAttribute("pendingGrns", pendingGrns);
86
        return "pending-grn";
87
    }
30289 amit.gupta 88
 
31437 amit.gupta 89
    @RequestMapping(value = "/purchase/validate-imeis", method = RequestMethod.POST)
90
    public ResponseEntity<?> validatePurchaseImeis(HttpServletRequest request, @RequestBody ImeiInoviceModel imeiInoviceModel, Model model) throws ProfitMandiBusinessException {
91
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
92
        return responseSender.ok(this.getImeiValidationMap(fofoDetails.getFofoId(), imeiInoviceModel));
93
    }
30694 amit.gupta 94
 
31437 amit.gupta 95
    private Map<String, Boolean> getImeiValidationMap(int fofoId, ImeiInoviceModel imeiInoviceModel) throws ProfitMandiBusinessException {
96
        LOGGER.info("serialNumbers - {}", imeiInoviceModel.getSerialNumbers());
97
        Set<String> serialNumbers = new HashSet<>(orderRepository.selectSerialNumbers(imeiInoviceModel.getInvoiceNumber(), fofoId, imeiInoviceModel.getSerialNumbers()));
98
        Map<String, Boolean> imeiValidationMap = new HashMap<>();
99
        imeiInoviceModel.getSerialNumbers().stream().forEach(x -> {
100
            imeiValidationMap.put(x, true);
101
        });
102
        if (serialNumbers.size() > 0) {
103
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(fofoId, new HashSet<>(serialNumbers), false);
104
            Set<String> grnedSerialNumberSet = inventoryItems.stream().filter(x -> x.getPurchase().getPurchaseReference().equals(imeiInoviceModel.getInvoiceNumber()))
105
                    .map(x -> x.getSerialNumber()).collect(Collectors.toSet());
106
            imeiInoviceModel.getSerialNumbers().stream().forEach(imei -> {
107
                if (grnedSerialNumberSet.contains(imei)) {
108
                    imeiValidationMap.put(imei, false);
109
                }
110
            });
21640 kshitij.so 111
 
31437 amit.gupta 112
        }
113
        return imeiValidationMap;
114
    }
21640 kshitij.so 115
 
31437 amit.gupta 116
    @RequestMapping(value = "/purchase/grn-imeis", method = RequestMethod.POST)
117
    public ResponseEntity<?> grnImeis(HttpServletRequest request, @RequestBody ImeiInoviceModel imeiInoviceModel, Model model) throws ProfitMandiBusinessException {
118
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
119
        Map<String, Boolean> imeiValidationMap = this.getImeiValidationMap(fofoDetails.getFofoId(), imeiInoviceModel);
120
        if (imeiValidationMap.values().stream().filter(x -> !x).findFirst().isPresent()) {
121
            throw new ProfitMandiBusinessException("Found invalid imeis cant proceed", "invalid imeis", "invalid imeis");
122
        }
30289 amit.gupta 123
 
31437 amit.gupta 124
        Map<Integer, List<String>> itemSerialNumberMap = orderRepository.selectItemSerialNumberMap(imeiInoviceModel.getInvoiceNumber(), fofoDetails.getFofoId(), imeiInoviceModel.getSerialNumbers());
125
        for (Map.Entry<Integer, List<String>> itemSerialNumberEntry : itemSerialNumberMap.entrySet()) {
126
            ScanSerializedRequest scanSerializedRequest = new ScanSerializedRequest();
127
            scanSerializedRequest.setSerialNumbers(itemSerialNumberEntry.getValue());
128
            scanSerializedRequest.setInvoiceNumber(imeiInoviceModel.getInvoiceNumber());
129
            scanSerializedRequest.setItemId(itemSerialNumberEntry.getKey());
130
            purchaseService.scanSerializedItems(scanSerializedRequest, fofoDetails.getFofoId());
131
        }
132
        return responseSender.ok(true);
133
    }
30289 amit.gupta 134
 
31437 amit.gupta 135
    @RequestMapping(value = "/purchase/get-imeis", method = RequestMethod.GET)
136
    public ResponseEntity<?> getImeis(HttpServletRequest request, @RequestParam String invoiceNumber, @RequestParam int itemId) throws ProfitMandiBusinessException {
137
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
138
        List<String> serialNumbers = orderRepository.selectSerialNumbersByInvoiceItem(invoiceNumber, itemId, fofoDetails.getFofoId());
139
        ImeiInoviceModel imeiInoviceModel = new ImeiInoviceModel();
140
        imeiInoviceModel.setInvoiceNumber(invoiceNumber);
141
        imeiInoviceModel.setSerialNumbers(serialNumbers);
142
        List<String> validSerialNumbers = this.getImeiValidationMap(fofoDetails.getFofoId(), imeiInoviceModel).entrySet().stream().filter(x -> x.getValue()).map(x -> x.getKey()).collect(Collectors.toList());
143
        return responseSender.ok(validSerialNumbers);
144
    }
30694 amit.gupta 145
 
30715 amit.gupta 146
 
31437 amit.gupta 147
    @RequestMapping(value = "/pendingGrnDetails", method = RequestMethod.GET)
148
    public String pendingGrnDetails(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId, Model model) throws ProfitMandiBusinessException {
149
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
150
        LOGGER.info("Request Received at url [{}] with orderId [{}]", request.getRequestURI(), orderId);
151
        model.addAttribute("pendingGrnDetails", purchaseService.getShippingDetailByOrderId(orderId, fofoDetails.getFofoId()));
152
        return "pending-grn-details";
153
    }
30694 amit.gupta 154
 
31437 amit.gupta 155
    @RequestMapping(value = "/purchaseByInvoiceNumber", method = RequestMethod.GET)
156
    public String purchaseByAirwayBillOrInvoiceNumber(HttpServletRequest request,
157
                                                      @RequestParam(name = ProfitMandiConstants.AIRWAY_BILL_OR_INVOICE_NUMBER)
158
                                                      String airwayBillOrInvoiceNumber, Model model) throws ProfitMandiBusinessException {
159
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
160
        LOGGER.info("Request Received at url {} with airwayBillOrInvoiceNumber {}", request.getRequestURI(), airwayBillOrInvoiceNumber);
161
        Map<String, Object> map = purchaseService.purchaseByInvoiceNumber(airwayBillOrInvoiceNumber, fofoDetails.getFofoId());
162
        model.addAllAttributes(map);
163
        return "purchase";
164
    }
30694 amit.gupta 165
 
31437 amit.gupta 166
    @RequestMapping(value = "/purchase-invoice/{invoiceNumber}", method = RequestMethod.GET)
167
    public ResponseEntity<?> downloadInvoice(HttpServletRequest request, @PathVariable String invoiceNumber, Model model) throws Exception {
168
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
169
        List<String> invoiceNumbers = Arrays.asList(invoiceNumber.replaceAll(" ", "").split(","));
170
        Map<String, List<Order>> invoiceOrdersMap = orderRepository.selectByInvoiceNumbers(invoiceNumbers).stream().collect(Collectors.groupingBy(x -> x.getInvoiceNumber()));
171
        if (invoiceOrdersMap.size() > 0) {
172
            if (roleManager.isAdmin(fofoDetails.getRoleIds()) || invoiceOrdersMap.get(invoiceNumbers.get(0)).get(0).getRetailerId() == fofoDetails.getFofoId()) {
30694 amit.gupta 173
 
31437 amit.gupta 174
                final HttpHeaders headers = new HttpHeaders();
30694 amit.gupta 175
 
30701 amit.gupta 176
 
31437 amit.gupta 177
                Map<String, String> headersMap = new HashMap<>();
178
                headersMap.put("Authorization", "Basic " + Base64.getEncoder().encodeToString("smartdukaan:$smart@123#".getBytes()));
179
                if (invoiceNumbers.size() == 1) {
180
                    String invoicePath = this.getInvoicePath(invoiceOrdersMap.get(invoiceNumbers.get(0)).get(0));
181
                    HttpResponse response = restClient.getResponse("http://45.79.106.95/" + invoicePath, null, headersMap);
182
                    headers.setContentType(MediaType.APPLICATION_PDF);
183
                    headers.set("Content-Type", "application/pdf");
184
                    headers.set("Content-disposition", "inline; filename=" + invoiceNumber + ".pdf");
185
                    InputStreamResource is = new InputStreamResource(response.getEntity().getContent());
186
                    return new ResponseEntity<>(is, headers, HttpStatus.OK);
30289 amit.gupta 187
 
31437 amit.gupta 188
                } else {
30380 amit.gupta 189
 
31437 amit.gupta 190
                    ByteArrayOutputStream fos = new ByteArrayOutputStream();
191
                    ZipOutputStream zipOut = new ZipOutputStream(fos);
30289 amit.gupta 192
 
31437 amit.gupta 193
                    for (String invoice : invoiceNumbers) {
194
                        List<Order> orders = invoiceOrdersMap.get(invoice);
195
                        String invoicePath = this.getInvoicePath(orders.get(0));
196
                        HttpResponse response = restClient.getResponse("http://45.79.106.95/" + invoicePath, null, headersMap);
197
                        this.addFileToZip(zipOut, response.getEntity().getContent(), invoice + ".pdf");
198
                    }
199
                    zipOut.close();
200
                    byte[] byteArray = fos.toByteArray();
201
                    headers.set("Content-Type", ContentType.APPLICATION_OCTET_STREAM.getMimeType());
202
                    headers.set("Content-disposition", "attachment; filename=invoices.zip");
203
                    headers.setContentLength(byteArray.length);
204
                    final InputStream inputStream = new ByteArrayInputStream(fos.toByteArray());
205
                    return new ResponseEntity<>(new InputStreamResource(inputStream), headers, HttpStatus.OK);
206
                }
30380 amit.gupta 207
 
31437 amit.gupta 208
            }
209
        } else {
210
            throw new ProfitMandiBusinessException("Invalid Invoice", invoiceNumber, "Please check with your manager");
211
        }
212
        return null;
213
    }
30380 amit.gupta 214
 
31437 amit.gupta 215
    private void addFileToZip(ZipOutputStream outZip, InputStream inputStream, String fileName) throws Exception {
216
        byte data[] = new byte[BUFFER_SIZE];
217
        ZipEntry entry = new ZipEntry(fileName);
218
        outZip.putNextEntry(entry);
219
        IOUtils.copy(inputStream, outZip);
220
        outZip.closeEntry();
221
    }
30380 amit.gupta 222
 
31437 amit.gupta 223
    private String getInvoicePath(Order order) {
224
        LocalDateTime billTime = order.getBillingTimestamp();
225
        String dirPath = billTime.getYear() + "-" + (billTime.getMonthValue() - 1) + File.separator + order.getRetailerId();
226
        String filename = dirPath + File.separator + order.getInvoiceNumber() + ".pdf";
227
        return filename;
228
    }
21636 ashik.ali 229
}