Subversion Repositories SmartDukaan

Rev

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