Subversion Repositories SmartDukaan

Rev

Rev 35293 | Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
35275 aman 1
package com.spice.profitmandi.web.controller;
2
import com.spice.profitmandi.common.model.ProfitMandiConstants;
3
import com.spice.profitmandi.common.web.util.ResponseSender;
4
import com.spice.profitmandi.dao.entity.trialUser.TrialOnBoarding;
5
import com.spice.profitmandi.dao.repository.trialOnboarding.TrialOnboardingRepository;
6
import com.spice.profitmandi.service.integrations.gstpro.GstProService;
7
import com.spice.profitmandi.service.integrations.gstpro.entity.GstDetails;
8
import org.apache.logging.log4j.LogManager;
9
import org.apache.logging.log4j.Logger;
10
import org.springframework.beans.factory.annotation.Autowired;
11
import org.springframework.http.ResponseEntity;
12
import org.springframework.stereotype.Controller;
13
import org.springframework.web.bind.annotation.RequestBody;
14
import org.springframework.web.bind.annotation.RequestMapping;
15
import org.springframework.web.bind.annotation.RequestMethod;
16
import org.springframework.web.bind.annotation.RequestParam;
17
 
18
import javax.servlet.http.HttpServletRequest;
19
import javax.transaction.Transactional;
20
import java.time.LocalDate;
21
import java.time.LocalDateTime;
22
import java.util.Collections;
23
import java.util.List;
24
 
25
 
26
 
27
@Controller
28
@Transactional
29
public class TrialUserController {
30
    private static final Logger logger = LogManager.getLogger(FileUploaderController.class);
31
    @Autowired
32
    GstProService gstProService;
33
 
34
    @Autowired
35
    TrialOnboardingRepository trialOnboardingRepository;
36
 
37
    @Autowired
38
    ResponseSender responseSender;
39
 
40
    private static final Logger LOGGER = LogManager.getLogger(DealsController.class);
41
 
42
 
43
    @RequestMapping(value = "/gstValidate", method = RequestMethod.GET)
44
    public ResponseEntity<?> gstValidate(HttpServletRequest request, @RequestParam String gstNo) throws Exception {
45
        LOGGER.info("gstNo -" + gstNo);
46
        GstDetails gstDetails = gstProService.getGstDetails(gstNo);
47
        LOGGER.info("gstDetails -" + gstDetails);
48
        if (gstDetails != null) {
49
            List<GstDetails.Pradr> adadr = gstDetails.getAdadr();
50
            adadr.add(gstDetails.getPradr());
51
            Collections.reverse(adadr);
52
            LOGGER.info("list_of_adadr-" + adadr);
53
        }
54
        return ResponseEntity.ok(gstDetails);
55
    }
56
 
57
 
58
    @RequestMapping(value = "/trial-registration", method = RequestMethod.POST)
59
    public ResponseEntity<?> createTrialUser(@RequestBody TrialOnBoarding trialOnBoarding) throws Exception {
60
        if (trialOnBoarding.getMobile() == null || trialOnBoarding.getMobile().isEmpty()) {
61
            return responseSender.badRequest("Mobile number is required");
62
        }
63
        try {
64
            TrialOnBoarding existingUser = trialOnboardingRepository.findByMobile(trialOnBoarding.getMobile());
65
            if (existingUser != null) {
66
                return responseSender.internalServerError("User already exists");
67
            }
68
            trialOnBoarding.setStatus(ProfitMandiConstants.Status.PENDING);
69
            trialOnBoarding.setCreatedOn(LocalDateTime.now());
70
            trialOnboardingRepository.persist(trialOnBoarding);
71
            return responseSender.ok(trialOnBoarding);
72
 
73
        } catch (Exception e) {
74
            e.printStackTrace();
75
            return responseSender.internalServerError("Registration failed: " + e.getMessage());
76
        }
77
    }
78
 
79
 
80
}