Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
22866 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
22889 amit.gupta 3
import java.io.ByteArrayOutputStream;
4
import java.io.File;
5
import java.io.FileOutputStream;
6
import java.io.IOException;
7
import java.io.OutputStream;
8
import java.text.MessageFormat;
9
import java.time.LocalDate;
10
import java.time.format.DateTimeFormatter;
11
import java.util.Arrays;
12
import java.util.HashSet;
13
import java.util.List;
14
import java.util.Map;
15
import java.util.Set;
16
 
17
import javax.mail.internet.InternetAddress;
18
import javax.mail.internet.MimeMessage;
22866 ashik.ali 19
import javax.servlet.http.HttpServletRequest;
20
 
22889 amit.gupta 21
import org.apache.commons.io.FileUtils;
22866 ashik.ali 22
import org.slf4j.Logger;
23
import org.slf4j.LoggerFactory;
24
import org.springframework.beans.factory.annotation.Autowired;
25
import org.springframework.http.ResponseEntity;
22889 amit.gupta 26
import org.springframework.mail.javamail.JavaMailSender;
27
import org.springframework.mail.javamail.MimeMessageHelper;
22866 ashik.ali 28
import org.springframework.stereotype.Controller;
29
import org.springframework.transaction.annotation.Transactional;
22889 amit.gupta 30
import org.springframework.web.bind.annotation.RequestBody;
22866 ashik.ali 31
import org.springframework.web.bind.annotation.RequestMapping;
32
import org.springframework.web.bind.annotation.RequestMethod;
33
 
22889 amit.gupta 34
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
35
import com.spice.profitmandi.common.model.CustomAddress;
36
import com.spice.profitmandi.common.model.CustomCustomer;
37
import com.spice.profitmandi.common.model.CustomInsurancePolicy;
38
import com.spice.profitmandi.common.model.CustomOrderItem;
39
import com.spice.profitmandi.common.model.CustomRetailer;
40
import com.spice.profitmandi.common.model.GadgetCopsDocumentInsuranceModel;
41
import com.spice.profitmandi.common.model.PdfModel;
22866 ashik.ali 42
import com.spice.profitmandi.common.model.ProfitMandiConstants;
22889 amit.gupta 43
import com.spice.profitmandi.common.util.InsuranceUtils;
44
import com.spice.profitmandi.common.util.PdfUtils;
45
import com.spice.profitmandi.common.util.StringUtils;
46
import com.spice.profitmandi.common.util.Utils;
22866 ashik.ali 47
import com.spice.profitmandi.common.web.util.ResponseSender;
22889 amit.gupta 48
import com.spice.profitmandi.dao.entity.dtr.Document;
49
import com.spice.profitmandi.dao.entity.dtr.GadgetCopsInsuranceCalc;
50
import com.spice.profitmandi.dao.entity.dtr.InsurancePolicy;
51
import com.spice.profitmandi.dao.entity.dtr.InsuranceProvider;
52
import com.spice.profitmandi.dao.entity.dtr.PolicyNumberGenerationSequence;
53
import com.spice.profitmandi.dao.entity.dtr.ThirdPartyInvoiceSequence;
54
import com.spice.profitmandi.dao.enumuration.dtr.ThirdParty;
55
import com.spice.profitmandi.dao.model.UserCart;
56
import com.spice.profitmandi.dao.repository.dtr.DocumentRepository;
22866 ashik.ali 57
import com.spice.profitmandi.dao.repository.dtr.GadgetCopsInsuranceCalcRepository;
22889 amit.gupta 58
import com.spice.profitmandi.dao.repository.dtr.InsurancePolicyRepository;
59
import com.spice.profitmandi.dao.repository.dtr.InsuranceProviderRepository;
60
import com.spice.profitmandi.dao.repository.dtr.PolicyNumberGenerationSequenceRepository;
61
import com.spice.profitmandi.dao.repository.dtr.ThirdPartyInvoiceSequenceRepository;
62
import com.spice.profitmandi.dao.repository.dtr.UserAccountRepository;
63
import com.spice.profitmandi.dao.repository.fofo.InvoiceNumberGenerationSequenceRepository;
22898 amit.gupta 64
import com.spice.profitmandi.dao.repository.transaction.UserWalletRepository;
22889 amit.gupta 65
import com.spice.profitmandi.service.pricing.PricingService;
66
import com.spice.profitmandi.service.wallet.WalletService;
22866 ashik.ali 67
 
22889 amit.gupta 68
import in.shop2020.model.v1.order.WalletReferenceType;
69
 
22866 ashik.ali 70
@Controller
22889 amit.gupta 71
@Transactional(rollbackFor = Throwable.class)
22866 ashik.ali 72
public class InsuranceController {
22889 amit.gupta 73
	private static final Logger LOGGER = LoggerFactory.getLogger(InsuranceController.class);
74
	private static final String gadgetCopsFilePath = "/GadgetCops";
22866 ashik.ali 75
 
76
	@Autowired
22889 amit.gupta 77
	private GadgetCopsInsuranceCalcRepository gadgetCopsInsuranceCalcRepository;
78
 
79
	@RequestMapping(value = ProfitMandiConstants.URL_INSURANCE_GADGET_COPS_MAPPING, method = RequestMethod.GET)
80
	public ResponseEntity<?> getById(HttpServletRequest request) {
81
		LOGGER.info("requested url : " + request.getRequestURL().toString());
82
		return responseSender.ok(gadgetCopsInsuranceCalcRepository.selectAll());
83
	}
84
 
85
	@Autowired
22866 ashik.ali 86
	ResponseSender<?> responseSender;
22889 amit.gupta 87
 
88
	@Autowired
89
	ThirdPartyInvoiceSequenceRepository thirdPartyInvoiceSequenceRepository;
90
 
91
	@Autowired
92
	DocumentRepository documentRepository;
93
 
94
	@Autowired
95
	InvoiceNumberGenerationSequenceRepository invoiceNumberGenerationSequenceRepository;
22866 ashik.ali 96
 
22889 amit.gupta 97
	@Autowired
98
	InsurancePolicyRepository insurancePolicyRepository;
99
 
100
	@Autowired
101
	PricingService pricingService;
22866 ashik.ali 102
 
103
	@Autowired
22889 amit.gupta 104
	JavaMailSender mailSender;
105
 
106
	@Autowired
107
	InsuranceProviderRepository insuranceProviderRepository;
108
 
109
	@Autowired
110
	UserAccountRepository userAccountRepository;
22866 ashik.ali 111
 
22889 amit.gupta 112
	@Autowired
113
	WalletService walletService;
114
 
115
	@Autowired
22898 amit.gupta 116
	UserWalletRepository userWalletRepositoy;
117
 
118
	@Autowired
22889 amit.gupta 119
	PolicyNumberGenerationSequenceRepository policyNumberGenerationSequenceRepository;
120
 
121
	@RequestMapping(value = ProfitMandiConstants.URL_DAMAGE_INSURANCE, method = RequestMethod.POST)
122
	public ResponseEntity<?> createTheftProtection(HttpServletRequest request,
123
			@RequestBody GadgetCopsDocumentInsuranceModel insuranceModel) throws Throwable {
22894 amit.gupta 124
		insuranceModel.setCustomerDateOfBirth(StringUtils.fromHypendatedDate(insuranceModel.getCustomerDateOfBirthString()));
22896 amit.gupta 125
		insuranceModel.setInvoiceCreationDate(LocalDate.now());
22893 amit.gupta 126
		insuranceModel.validate();
127
		int userId = (int) request.getAttribute("userId");
128
		UserCart uc = userAccountRepository.getUserCart(userId);
129
		PolicyNumberGenerationSequence policyNumberGenerationSequence = null;
130
		try {
131
			policyNumberGenerationSequence = policyNumberGenerationSequenceRepository.select();
132
			policyNumberGenerationSequence.setSequence(policyNumberGenerationSequence.getSequence() + 1);
133
			policyNumberGenerationSequenceRepository.persist(policyNumberGenerationSequence);
134
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
135
			policyNumberGenerationSequence = new PolicyNumberGenerationSequence();
136
			policyNumberGenerationSequence.setSequence(1);
137
			policyNumberGenerationSequenceRepository.persist(policyNumberGenerationSequence);
138
		}
139
		String policyNumber = StringUtils.generatePolicyNumber(ProfitMandiConstants.POLICY_NUMBER_PREFIX,
140
				policyNumberGenerationSequence.getSequence());
22889 amit.gupta 141
 
22893 amit.gupta 142
		InsuranceProvider insuranceProvider = insuranceProviderRepository
143
				.selectByName(ProfitMandiConstants.GADGET_COPS);
144
		Set<Float> devicePriceSet = new HashSet<>();
145
		devicePriceSet.add(insuranceModel.getPrice());
146
		Map<Float, GadgetCopsInsuranceCalc> insurancePricesMap = pricingService.getInsurancePrices(devicePriceSet,
147
				ProfitMandiConstants.GADGET_COPS);
148
		InsurancePolicy insurancePolicy = new InsurancePolicy();
149
		insurancePolicy.setInvoiceNumber(insuranceModel.getInvoiceNumber());
150
		insurancePolicy.setRetailerId(uc.getUserId());
151
		insurancePolicy.setPurchaseAmount(insurancePricesMap.get(insuranceModel.getPrice()).getDealerPrice());
152
		insurancePolicy.setSaleAmount(insurancePricesMap.get(insuranceModel.getPrice()).getSellingPrice());
153
		insurancePolicy.setSellingPrice(insuranceModel.getPrice());
154
		insurancePolicy.setSerialNumber(insuranceModel.getSerialNumber());
155
		insurancePolicy.setModelName(insuranceModel.getModelName());
156
		insurancePolicy.setBrand(insuranceModel.getBrand());
157
		insurancePolicy.setPolicyNumber(policyNumber);
158
		insurancePolicy.setProviderId(insuranceProvider.getId());
159
		insurancePolicy.setCustomerFirstName(insuranceModel.getCustomerFirstName());
160
		insurancePolicy.setCustomerLastName(insuranceModel.getCustomerFirstName());
161
		insurancePolicy.setCustomerMobileNumber(insuranceModel.getCustomerMobileNumber());
162
		insurancePolicy.setCustomerEmailId(insuranceModel.getCustomerEmailId());
163
		insurancePolicy.setCustomerDateOfBirth(insuranceModel.getCustomerDateOfBirth());
164
		insurancePolicy.setCustomerAddress1(insuranceModel.getCustomerAddress1());
165
		insurancePolicy.setCustomerAddress2(insuranceModel.getCustomerAddress2());
166
		insurancePolicy.setCustomerCity(insuranceModel.getCustomerCity());
167
		insurancePolicy.setCustomerPinCode(insuranceModel.getCustomerPinCode());
168
		insurancePolicy.setCustomerState(insuranceModel.getCustomerState());
169
		insurancePolicyRepository.persist(insurancePolicy);
170
 
22898 amit.gupta 171
		walletService.consumeAmountFromWallet(uc.getUserId(), insurancePolicy.getId(), WalletReferenceType.DAMAGE_PROTECTION, 
172
				"Purchased Damage Protection policy for " + insurancePolicy.getCustomerFirstName() , insurancePolicy.getSaleAmount());
173
 
22893 amit.gupta 174
		try{
175
			InsuranceUtils.submitToGadgetCops(insuranceModel);
176
			insurancePolicy.setPosted(true);
177
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
178
			LOGGER.info("Unable to submit insurance policy details to {}", insuranceProvider.getName(), profitMandiBusinessException);
179
		}
180
		insurancePolicyRepository.persist(insurancePolicy);			
22889 amit.gupta 181
 
22893 amit.gupta 182
		PdfModel pdfModel = this.getInvoicePdfModel(insurancePolicy);
183
		ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
184
		PdfUtils.generateAndWrite(pdfModel, byteArrayOutputStream);
22889 amit.gupta 185
 
22893 amit.gupta 186
		Document deviceDocument = documentRepository.selectById(insuranceModel.getDeviceImageDocumentId());
187
		File deviceImg = new File(deviceDocument.getPath() + deviceDocument.getName());
188
		Document invoiceDocument = documentRepository.selectById(insuranceModel.getDeviceImageDocumentId());
189
		File deviceInvoiceImg = new File(invoiceDocument.getPath() + invoiceDocument.getName());
22889 amit.gupta 190
 
22893 amit.gupta 191
		String messageText = MessageFormat.format(
192
				"Dear {0}, Thank you for purchasing Damage Protection Plan. Your Policy number is {1}",
193
				insurancePolicy.getCustomerFirstName(), insurancePolicy.getPolicyNumber());
194
		Utils.sendSms(messageText, insurancePolicy.getCustomerMobileNumber());
195
		List<File> attachments = this.savePolicyDocs(insurancePolicy.getPolicyNumber(), byteArrayOutputStream, deviceImg, deviceInvoiceImg);
196
		messageText += "\n Please find your Invoice, and documents submitted by you.";
197
		String subject = "Your Gadget Cop damage Protection";
198
		this.sendMailWithAttachments(insuranceModel.getCustomerEmailId() , subject, messageText, attachments);
22889 amit.gupta 199
		LOGGER.info("requested url : " + request.getRequestURL().toString());
200
		return responseSender.ok(true);
22866 ashik.ali 201
	}
202
 
22889 amit.gupta 203
	private void sendMailWithAttachments(String email, String subject, String body, List<File> attachments) throws Exception {
204
 
205
    	MimeMessage message = mailSender.createMimeMessage();
206
    	MimeMessageHelper helper = new MimeMessageHelper(message);
207
    	helper.setSubject("New Contact Us message");
208
    	helper.setText(body);
209
    	String[] cc = {"amit.gupta@shop2020.in"};
210
    	//String[] cc = {"amit.gupta@shop2020.in"};
211
    	helper.setCc(cc);
212
    	InternetAddress senderAddress = new InternetAddress("noreply@profitmandi.com", "ProfitMandi Admin");
213
    	helper.setTo("help@profitmandi.com");
214
    	helper.setFrom(senderAddress);
215
    	for (File file : attachments) {
216
    		helper.addAttachment(file.getName(), file);
217
    	}
218
    	mailSender.send(message);
219
 
220
	}
221
 
222
	private List<File> savePolicyDocs(String policyNumber, ByteArrayOutputStream pdfInvoiceStream, File deviceImg,
223
			File deviceInvoiceImg) throws Exception {
224
		// save file to gadgetCops/policyname
225
		String policyFolderPath = gadgetCopsFilePath + File.separator + policyNumber;
226
		File destDeviceInvoiceImg = new File(policyFolderPath + File.separator + "deviceInvoice.jpg");
227
		File destDeviceImg = new File(policyFolderPath + File.separator + "device.jpg");
228
		FileUtils.copyFile(deviceImg, destDeviceImg);
229
		FileUtils.copyFile(deviceInvoiceImg, destDeviceInvoiceImg);
230
 
231
		OutputStream outStream = null;
232
		try {
233
			outStream = new FileOutputStream(policyFolderPath + File.separator + "invoice.pdf");
234
			pdfInvoiceStream.writeTo(outStream);
235
		} catch (IOException e) {
236
			e.printStackTrace();
237
		} finally {
238
			outStream.close();
239
			pdfInvoiceStream.close();
240
		}
241
 
242
		File pdfInvoice = new File(policyFolderPath + File.separator + "invoice.pdf");
243
		return Arrays.asList(pdfInvoice, destDeviceImg, destDeviceInvoiceImg);
244
	}
245
 
246
	public String getFormattedDate(LocalDate localDate) {
247
		DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd-MM-YYYY HH:mm");
248
		return localDate.format(formatter);
249
	}
250
 
251
	private PdfModel getInvoicePdfModel(InsurancePolicy insurancePolicy) throws ProfitMandiBusinessException {
252
 
253
		PdfModel pdfModel = new PdfModel();
254
		pdfModel.setAuther("profitmandi");
255
		pdfModel.setTitle("Retailer Invoice");
256
		pdfModel.setInvoiceDate(getFormattedDate(LocalDate.now()));
257
 
258
		// insurance calculation
259
		Set<CustomInsurancePolicy> customInsurancePolicies = new HashSet<>();
260
		final float totalInsuranceTaxRate = 18;
261
 
262
		float taxableInsurancePrice = insurancePolicy.getSaleAmount() / (1 + totalInsuranceTaxRate / 100);
263
		CustomInsurancePolicy customInsurancePolicy = new CustomInsurancePolicy();
264
		customInsurancePolicy.setDescription("Damage Protection Plan for device IMEI #"
265
				+ insurancePolicy.getSerialNumber() + "\n Certificate No. " + insurancePolicy.getPolicyNumber());
266
		customInsurancePolicy.setHsnCode("998716");
267
		customInsurancePolicy.setRate(taxableInsurancePrice);
268
		customInsurancePolicy.setIgstRate(18);
269
		customInsurancePolicy.setIgstAmount(taxableInsurancePrice * 18 / 100);
270
		customInsurancePolicy.setCgstRate(9);
271
		customInsurancePolicy.setCgstAmount(taxableInsurancePrice * 9 / 100);
272
		customInsurancePolicy.setSgstRate(9);
273
		customInsurancePolicy.setSgstAmount(taxableInsurancePrice * 9 / 100);
274
		customInsurancePolicy.setNetAmount(insurancePolicy.getSaleAmount());
275
		customInsurancePolicies.add(customInsurancePolicy);
276
 
277
		pdfModel.setInsurancePolicies(customInsurancePolicies);
278
		CustomCustomer customCustomer = new CustomCustomer();
279
		customCustomer.setFirstName(insurancePolicy.getCustomerFirstName());
280
		customCustomer.setLastName(insurancePolicy.getCustomerLastName());
281
		customCustomer.setEmailId(insurancePolicy.getCustomerEmailId());
282
		customCustomer.setMobileNumber(insurancePolicy.getCustomerMobileNumber());
283
 
284
		CustomAddress customAddress = new CustomAddress();
285
		customAddress.setName(insurancePolicy.getCustomerFirstName() + " " + insurancePolicy.getCustomerLastName());
286
		customAddress.setLine1(insurancePolicy.getCustomerAddress1());
287
		customAddress.setLine2(insurancePolicy.getCustomerAddress2());
288
		customAddress.setLandmark("");
289
		customAddress.setCity(insurancePolicy.getCustomerCity());
290
		customAddress.setPinCode(insurancePolicy.getCustomerPinCode());
291
		customAddress.setState(insurancePolicy.getCustomerState());
292
		customAddress.setPhoneNumber(insurancePolicy.getCustomerMobileNumber());
293
		customCustomer.setAddress(customAddress);
294
		pdfModel.setCustomer(customCustomer);
295
 
296
		// TODO get invoice number for damageProtection provider
297
		pdfModel.setInvoiceNumber(thirdPartyInvoiceSequenceRepository.getNextSequence(ThirdParty.GADGET_COP));
298
		pdfModel.setTotalAmount(gadgetCopsInsuranceCalcRepository.selectByPrice(insurancePolicy.getSellingPrice()));
299
 
300
		// Here bill is generated on behalf of GadgetCop
301
		ThirdPartyInvoiceSequence damageProtectionProvider = thirdPartyInvoiceSequenceRepository
302
				.selectByThirdParty(ThirdParty.GADGET_COP);
303
		// Gadget Cop
304
		// Gadget cop mobile
305
		CustomRetailer customRetailer = new CustomRetailer();
306
		customRetailer.setBusinessName(damageProtectionProvider.getName());
307
		customRetailer.setMobileNumber(damageProtectionProvider.getMobileNumber());
308
		customRetailer.setGstNumber(damageProtectionProvider.getGstNumber());
309
		CustomAddress providerAddress = new CustomAddress();
310
		providerAddress.setCity(damageProtectionProvider.getCity());
311
		providerAddress.setLine1(damageProtectionProvider.getLine1());
312
		providerAddress.setLine2(damageProtectionProvider.getLine2());
313
		providerAddress.setPinCode(damageProtectionProvider.getPin());
314
		providerAddress.setPhoneNumber(damageProtectionProvider.getMobileNumber());
315
		providerAddress.setState(damageProtectionProvider.getState());
316
		pdfModel.setRetailer(customRetailer);
317
 
318
		Set<CustomOrderItem> customerFofoOrderItems = new HashSet<>();
319
		pdfModel.setOrderItems(customerFofoOrderItems);
320
		return pdfModel;
321
	}
322
 
22866 ashik.ali 323
}