Subversion Repositories SmartDukaan

Rev

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