Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21248 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
26636 amit.gupta 3
import com.fasterxml.jackson.annotation.JsonProperty;
26646 amit.gupta 4
import com.fasterxml.jackson.databind.ObjectMapper;
21248 ashik.ali 5
import com.spice.profitmandi.common.ResponseCodeHolder;
6
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
30295 amit.gupta 7
import com.spice.profitmandi.common.model.*;
21282 ashik.ali 8
import com.spice.profitmandi.common.util.JWTUtil;
30295 amit.gupta 9
import com.spice.profitmandi.common.util.Utils;
21855 amit.gupta 10
import com.spice.profitmandi.common.web.client.RestClient;
21740 ashik.ali 11
import com.spice.profitmandi.common.web.util.ResponseSender;
25366 tejbeer 12
import com.spice.profitmandi.dao.entity.auth.AuthUser;
30295 amit.gupta 13
import com.spice.profitmandi.dao.entity.dtr.*;
29011 amit.gupta 14
import com.spice.profitmandi.dao.entity.fofo.FofoStore;
15
import com.spice.profitmandi.dao.entity.fofo.PartnerOnBoardingPanel;
25622 amit.gupta 16
import com.spice.profitmandi.dao.entity.fofo.PartnerType;
22355 ashik.ali 17
import com.spice.profitmandi.dao.entity.user.Address;
25458 tejbeer 18
import com.spice.profitmandi.dao.entity.user.Promoter;
19
import com.spice.profitmandi.dao.entity.user.Refferal;
25488 tejbeer 20
import com.spice.profitmandi.dao.enumuration.dtr.RefferalStatus;
21735 ashik.ali 21
import com.spice.profitmandi.dao.enumuration.dtr.RoleType;
29892 tejbeer 22
import com.spice.profitmandi.dao.enumuration.transaction.PartnerOnBoardingStatus;
25979 tejbeer 23
import com.spice.profitmandi.dao.model.CreateRefferalRequest;
25488 tejbeer 24
import com.spice.profitmandi.dao.model.DateRangeModel;
21643 ashik.ali 25
import com.spice.profitmandi.dao.model.UserCart;
25366 tejbeer 26
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
25619 amit.gupta 27
import com.spice.profitmandi.dao.repository.cs.CsService;
30295 amit.gupta 28
import com.spice.profitmandi.dao.repository.dtr.*;
25622 amit.gupta 29
import com.spice.profitmandi.dao.repository.fofo.PartnerTypeChangeService;
22355 ashik.ali 30
import com.spice.profitmandi.dao.repository.user.AddressRepository;
25458 tejbeer 31
import com.spice.profitmandi.dao.repository.user.PromoterRepository;
24491 amit.gupta 32
import com.spice.profitmandi.service.AuthService;
23798 amit.gupta 33
import com.spice.profitmandi.service.authentication.RoleManager;
25366 tejbeer 34
import com.spice.profitmandi.service.user.RetailerService;
29011 amit.gupta 35
import com.spice.profitmandi.service.user.StoreTimelineTatService;
23787 amit.gupta 36
import com.spice.profitmandi.service.user.UserService;
26870 amit.gupta 37
import com.spice.profitmandi.web.controller.checkout.OrderController;
21469 amit.gupta 38
import com.spice.profitmandi.web.enumuration.UserStatus;
21277 ashik.ali 39
import com.spice.profitmandi.web.processor.GoogleLoginProcessor;
25488 tejbeer 40
import com.spice.profitmandi.web.req.RefferalEarning;
41
import com.spice.profitmandi.web.req.RefferalEarningModel;
21366 kshitij.so 42
import com.spice.profitmandi.web.req.UserRequest;
25366 tejbeer 43
import com.spice.profitmandi.web.res.Partner;
21469 amit.gupta 44
import io.swagger.annotations.ApiImplicitParam;
45
import io.swagger.annotations.ApiImplicitParams;
30295 amit.gupta 46
import org.apache.http.client.ClientProtocolException;
47
import org.apache.logging.log4j.LogManager;
48
import org.apache.logging.log4j.Logger;
49
import org.springframework.beans.factory.annotation.Autowired;
50
import org.springframework.beans.factory.annotation.Value;
51
import org.springframework.http.MediaType;
52
import org.springframework.http.ResponseEntity;
53
import org.springframework.mail.javamail.JavaMailSender;
54
import org.springframework.mail.javamail.MimeMessageHelper;
55
import org.springframework.stereotype.Controller;
56
import org.springframework.transaction.annotation.Transactional;
57
import org.springframework.web.bind.annotation.*;
21469 amit.gupta 58
 
30295 amit.gupta 59
import javax.mail.MessagingException;
60
import javax.mail.internet.InternetAddress;
61
import javax.mail.internet.MimeMessage;
62
import javax.servlet.http.HttpServletRequest;
63
import java.io.IOException;
64
import java.io.UnsupportedEncodingException;
65
import java.time.LocalDate;
66
import java.time.LocalDateTime;
67
import java.time.YearMonth;
68
import java.time.ZoneOffset;
69
import java.util.*;
70
import java.util.stream.Collectors;
71
 
21248 ashik.ali 72
/**
73
 * @author ashikali
74
 */
75
@Controller
25366 tejbeer 76
@Transactional(rollbackFor = Throwable.class)
21248 ashik.ali 77
public class UserController {
21469 amit.gupta 78
 
21448 ashik.ali 79
	@Autowired
22930 ashik.ali 80
	private ResponseSender<?> responseSender;
21469 amit.gupta 81
 
23568 govind 82
	private static final Logger LOGGER = LogManager.getLogger(UserController.class);
21469 amit.gupta 83
 
21855 amit.gupta 84
	@Value("${notifications.api.host}")
85
	private String nodeHost;
25366 tejbeer 86
 
26640 amit.gupta 87
	@Autowired
26636 amit.gupta 88
	private MobileAppSettingsRepository mobileAppSettingsRepository;
89
 
21855 amit.gupta 90
	@Value("${notifications.api.port}")
91
	private int nodePort;
92
 
21414 kshitij.so 93
	@Value("${admin.token}")
94
	private String validAdminToken;
21469 amit.gupta 95
 
21278 ashik.ali 96
	@Autowired
22873 ashik.ali 97
	private UserRepository userRepository;
25366 tejbeer 98
 
22355 ashik.ali 99
	@Autowired
22873 ashik.ali 100
	private com.spice.profitmandi.dao.repository.user.UserRepository userUserRepository;
21469 amit.gupta 101
 
21278 ashik.ali 102
	@Autowired
22873 ashik.ali 103
	private RetailerRepository retailerRepository;
21485 amit.gupta 104
 
105
	@Autowired
22873 ashik.ali 106
	private UserRoleRepository userRoleRepository;
21469 amit.gupta 107
 
29892 tejbeer 108
	@Autowired
25622 amit.gupta 109
	private PartnerTypeChangeService partnerTypeChangeService;
110
 
111
	@Autowired
22873 ashik.ali 112
	private UserAccountRepository userAccountRepository;
25366 tejbeer 113
 
22355 ashik.ali 114
	@Autowired
24491 amit.gupta 115
	private AuthService authService;
25366 tejbeer 116
 
24491 amit.gupta 117
	@Autowired
22873 ashik.ali 118
	private AddressRepository addressRepository;
21469 amit.gupta 119
 
21426 ashik.ali 120
	@Autowired
22873 ashik.ali 121
	private GoogleLoginProcessor googleLoginProcessor;
21855 amit.gupta 122
 
21784 amit.gupta 123
	@Autowired
22873 ashik.ali 124
	private UserService userService;
25366 tejbeer 125
 
23786 amit.gupta 126
	@Autowired
25619 amit.gupta 127
	private CsService csService;
128
 
129
	@Autowired
23858 ashik.ali 130
	private RestClient restClient;
25366 tejbeer 131
 
23858 ashik.ali 132
	@Autowired
23798 amit.gupta 133
	private RoleManager roleManager;
25366 tejbeer 134
 
23786 amit.gupta 135
	@Autowired
136
	private RoleRepository roleRepository;
21469 amit.gupta 137
 
25366 tejbeer 138
	@Autowired
139
	private AuthRepository authRepository;
26792 tejbeer 140
 
25366 tejbeer 141
	@Autowired
26646 amit.gupta 142
	private ObjectMapper objectMapper;
26792 tejbeer 143
 
26646 amit.gupta 144
	@Autowired
25366 tejbeer 145
	private RetailerService retailerService;
146
 
25458 tejbeer 147
	@Autowired
148
	private RefferalRepository refferalRepository;
149
 
150
	@Autowired
151
	private PromoterRepository promoterRepository;
152
 
26792 tejbeer 153
	@Autowired
154
	JavaMailSender mailSender;
155
 
21469 amit.gupta 156
	@RequestMapping(value = ProfitMandiConstants.URL_USER_GOOGLE_LOGIN, method = RequestMethod.POST)
25366 tejbeer 157
	public ResponseEntity<?> googleLogin(HttpServletRequest request, @RequestBody GoogleLoginRequest googleLoginRequest)
30295 amit.gupta 158
			throws Exception {
159
		String email = googleLoginProcessor.process(googleLoginRequest.getToken());
160
		return responseSender.ok(getAuthTokenMap(email));
21277 ashik.ali 161
	}
26636 amit.gupta 162
 
30295 amit.gupta 163
	private Map<String, Object> getAuthTokenMap(String email) throws Exception {
164
		String name = authService.getNameByEmailId(email);
165
 
166
		Map<String, Object> responseMap = new HashMap<>(2);
167
		LOGGER.info("User Name from getNameByEmailId({}) is {}", email, name);
168
		if (name != null) {
169
			User registeredUser = null;
170
			AuthUser authUser = authRepository.selectByGmailId(email);
171
 
172
			if (authRepository.selectByGmailId(email) != null) {
173
				registeredUser = userRepository.selectByEmailId(authUser.getEmailId());
174
			} else if (promoterRepository.isExistByEmailId(email)) {
175
				Promoter promoter = promoterRepository.selectByEmailId(email);
176
				int userId = userAccountRepository.selectUserIdByRetailerId(promoter.getRetailerId());
177
				registeredUser = userRepository.selectById(userId);
178
			} else if (userRepository.isExistBySecondryEmailId(email)) {
179
				registeredUser = userRepository.selectBySecondryEmailId(email);
180
			}
181
			LOGGER.info("4");
182
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(registeredUser.getId());
183
			String[] roleTypes = new String[roleIds.size()];
184
			int index = 0;
185
			for (int roleId : roleIds) {
186
				roleTypes[index++] = String.valueOf(roleId);
187
			}
188
			int retailerId;
189
			try {
190
				retailerId = userAccountRepository.selectRetailerIdByUserId(registeredUser.getId());
191
			} catch (Exception e) {
192
				Set<Integer> authUserPartnerSet = csService.getAuthUserPartnerIdMapping().get(authUser.getEmailId());
193
				if (authUserPartnerSet != null && authUserPartnerSet.size() > 0) {
194
					retailerId = authUserPartnerSet.stream().findFirst().get();
195
					FofoStore fs = fofoStoreRepository.selectByRetailerId(retailerId);
196
					retailerId = ProfitMandiConstants.WAREHOUSE_NSSPL_PARTNER_MAP.get(fs.getWarehouseId());
197
				} else {
30546 tejbeer 198
					com.spice.profitmandi.dao.entity.user.User user = userUserRepository
199
							.selectByEmailId(Utils.SYSTEM_PARTNER);
30295 amit.gupta 200
					retailerId = user.getId();
201
				}
202
			}
203
			responseMap.put(ProfitMandiConstants.TOKEN,
204
					JWTUtil.create(email, registeredUser.getId(), retailerId, roleTypes));
30546 tejbeer 205
			LOGGER.info("Param value for email, registeredUser.getId(), retailerId, roleTypes are {}, {}, {} and {}",
30295 amit.gupta 206
					email, registeredUser.getId(), retailerId, Arrays.asList(roleTypes));
207
			responseMap.put(ProfitMandiConstants.REGISTERED, true);
208
			return responseMap;
209
		}
210
 
211
		User user = null;
212
		try {
213
			user = userRepository.selectByEmailId(email);
214
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
215
 
216
		}
217
		if (user == null) {
218
			try {
219
				user = userRepository.selectByEmailId(email);
220
			} catch (ProfitMandiBusinessException profitMandiBusinessException) {
221
				responseMap.put(ProfitMandiConstants.TOKEN, JWTUtil.create(email));
222
				responseMap.put(ProfitMandiConstants.REGISTERED, false);
223
			}
224
		} else {
225
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(user.getId());
226
			int retailerId = userAccountRepository.selectRetailerIdByUserId(user.getId());
227
			String[] roleTypes = new String[roleIds.size()];
228
			int index = 0;
229
			for (int roleId : roleIds) {
230
				roleTypes[index++] = String.valueOf(roleId);
231
			}
232
			responseMap.put(ProfitMandiConstants.TOKEN, JWTUtil.create(user.getId(), retailerId, roleTypes));
233
			responseMap.put(ProfitMandiConstants.REGISTERED, true);
234
		}
235
 
236
		return responseMap;
237
	}
238
 
26592 amit.gupta 239
	@RequestMapping(value = "/store/token/{storeCode}", method = RequestMethod.GET)
26590 amit.gupta 240
	public ResponseEntity<?> googleLogin(HttpServletRequest request, @PathVariable String storeCode)
241
			throws ProfitMandiBusinessException {
26597 amit.gupta 242
		LOGGER.info("StoreCode {}", storeCode);
26590 amit.gupta 243
		return responseSender.ok(googleLoginProcessor.processStore(storeCode));
244
	}
21469 amit.gupta 245
 
246
	@RequestMapping(value = ProfitMandiConstants.URL_USER_TOKEN_IS_EXPIRED, method = RequestMethod.GET)
25366 tejbeer 247
	public ResponseEntity<?> tokenIsExpired(HttpServletRequest request, @RequestParam(name = "token") String token)
248
			throws ProfitMandiBusinessException {
21469 amit.gupta 249
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 250
		return responseSender.ok(JWTUtil.isExpired(token));
21282 ashik.ali 251
	}
21469 amit.gupta 252
 
22355 ashik.ali 253
	@RequestMapping(value = ProfitMandiConstants.URL_USER_DETAIL_BY_TOKEN, method = RequestMethod.GET)
21469 amit.gupta 254
	@ApiImplicitParams({
30546 tejbeer 255
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
21469 amit.gupta 256
	public ResponseEntity<?> tokenInfo(HttpServletRequest request) throws Throwable {
257
		Map<String, Object> responseMap = new HashMap<>();
258
		UserInfo userInfo = (UserInfo) request.getAttribute("userInfo");
30547 tejbeer 259
		LOGGER.info("userinfo1 {}", userInfo);
21483 amit.gupta 260
		User user = null;
21855 amit.gupta 261
		if (userInfo.getUserId() > -1) {
21483 amit.gupta 262
			user = userRepository.selectById(userInfo.getUserId());
30548 tejbeer 263
			LOGGER.info("userinfo7 {}", userInfo);
26533 amit.gupta 264
			String city = user.getCity();
25366 tejbeer 265
			if (!(userInfo.getEmail() == null || user.getEmailId().equalsIgnoreCase(userInfo.getEmail()))) {
24491 amit.gupta 266
				String userName = null;
30547 tejbeer 267
				LOGGER.info("userinfo2 {}", userInfo);
25366 tejbeer 268
				if (user.getSecondryEmailId() != null && user.getSecondryEmailId().equals(userInfo.getEmail())) {
30547 tejbeer 269
 
270
					LOGGER.info("userinfo3 {}", user);
24491 amit.gupta 271
					userName = user.getFirstName() + " " + user.getLastName();
272
				} else {
28021 amit.gupta 273
					AuthUser authUser = authRepository.selectByGmailId(userInfo.getEmail());
30546 tejbeer 274
					LOGGER.info("authUser {}", authUser);
29878 tejbeer 275
					if (authUser == null || !authUser.isActive()) {
28021 amit.gupta 276
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_REGISTERED.getValue());
277
						responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
278
						return responseSender.ok(responseMap);
279
					}
280
					userName = authUser.getName();
24491 amit.gupta 281
				}
282
				responseMap.put(ProfitMandiConstants.USER_ID, userInfo.getUserId());
283
				responseMap.put(ProfitMandiConstants.USER_NAME, userName);
284
				responseMap.put(ProfitMandiConstants.USER_STATUS, "fofoAssociate");
285
				responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
26570 amit.gupta 286
				responseMap.put("storeUrl", "");
24491 amit.gupta 287
				return responseSender.ok(responseMap);
288
			}
30549 tejbeer 289
			LOGGER.info("userinfo10 {}", userInfo);
21483 amit.gupta 290
		} else {
291
			try {
30547 tejbeer 292
 
293
				LOGGER.info("userinfo4 {}", userInfo);
21483 amit.gupta 294
				user = userRepository.selectByEmailId(userInfo.getEmail());
295
			} catch (ProfitMandiBusinessException e1) {
296
			}
25366 tejbeer 297
			if (user == null) {
23204 ashik.ali 298
				try {
30548 tejbeer 299
					LOGGER.info("userinfo8 {}", userInfo);
23204 ashik.ali 300
					user = userRepository.selectBySecondryEmailId(userInfo.getEmail());
301
				} catch (ProfitMandiBusinessException e1) {
302
					LOGGER.info("Uneregistered user", userInfo.getEmail());
303
				}
304
			}
21483 amit.gupta 305
		}
306
		if (user != null) {
23858 ashik.ali 307
			int retailerId = userAccountRepository.selectRetailerIdByUserId(user.getId());
21491 amit.gupta 308
			responseMap.put(ProfitMandiConstants.EMAIL_ID, user.getEmailId());
21526 amit.gupta 309
			responseMap.put(ProfitMandiConstants.USER_ID, user.getId());
22017 amit.gupta 310
			responseMap.put(ProfitMandiConstants.USER_NAME, user.getFirstName() + " " + user.getLastName());
23786 amit.gupta 311
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(user.getId());
25366 tejbeer 312
			// LOGGER.info("userRoles {} ", userRoles);
22032 ashik.ali 313
 
314
			// generate new token if roles have been updated
23786 amit.gupta 315
			if (userInfo.getRoleIds() == null || roleIds.size() != userInfo.getRoleIds().size()) {
23858 ashik.ali 316
				String[] roleIdStrings = new String[roleIds.size()];
22603 amit.gupta 317
				int index = 0;
23786 amit.gupta 318
				for (int roleId : roleIds) {
23858 ashik.ali 319
					roleIdStrings[index++] = String.valueOf(roleId);
22603 amit.gupta 320
				}
23858 ashik.ali 321
				String newToken = JWTUtil.create(user.getId(), retailerId, roleIdStrings);
21483 amit.gupta 322
				responseMap.put("newAuthToken", newToken);
323
			}
23858 ashik.ali 324
			// if user is retailer
23786 amit.gupta 325
			Set<Integer> roleIdsSet = new HashSet<Integer>(roleIds);
23858 ashik.ali 326
			if (roleManager.isRetailer(roleIdsSet)) {
22032 ashik.ali 327
				UserCart uc = userAccountRepository.getUserCart(userInfo.getUserId());
328
				Retailer retailer = retailerRepository.selectById(uc.getUserId());
22370 amit.gupta 329
				com.spice.profitmandi.dao.entity.user.User saholicUser = userUserRepository.selectById(uc.getUserId());
25366 tejbeer 330
				if (saholicUser.getAddressId() != null) {
22370 amit.gupta 331
					Address address = addressRepository.selectById(saholicUser.getAddressId());
332
					responseMap.put(ProfitMandiConstants.ADDRESS, address);
333
				}
21485 amit.gupta 334
				// if retailer is activated 1 then verified retailer
335
				// else if migrated is 1 then old retailer
25366 tejbeer 336
				// also lets incoporte old process i.e is user is activated then also retailer
337
				// is verified retailer
21485 amit.gupta 338
				// else retailer is not verifed
22497 amit.gupta 339
				if (retailer.isActive() || user.isActivated()) {
23798 amit.gupta 340
					if (roleManager.isPartner(roleIdsSet)) {
22017 amit.gupta 341
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.FOFO.getValue());
26533 amit.gupta 342
						responseMap.put("storeUrl", retailerService.getAllFofoRetailerIdUrlMap().get(uc.getUserId()));
29011 amit.gupta 343
						responseMap.put("timelineStatus", this.getTimeLineStatus(uc.getUserId()));
22017 amit.gupta 344
					} else {
345
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.VERIFIED_RETAILER.getValue());
346
					}
22032 ashik.ali 347
				} else if (retailer.isMigrated()) {
21485 amit.gupta 348
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.RETAILER.getValue());
21469 amit.gupta 349
				} else {
21485 amit.gupta 350
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_VERIFIED_RETAILER.getValue());
21469 amit.gupta 351
				}
23798 amit.gupta 352
			} else if (roleManager.isUser(roleIdsSet)) {
22502 amit.gupta 353
				responseMap.put("userInfo", getRegisteredUserInfo(user));
21469 amit.gupta 354
				responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.REGISTERED.getValue());
22032 ashik.ali 355
			}
21491 amit.gupta 356
		} else {
357
			responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_REGISTERED.getValue());
358
			responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
21469 amit.gupta 359
		}
22032 ashik.ali 360
 
21469 amit.gupta 361
		return responseSender.ok(responseMap);
362
	}
25366 tejbeer 363
 
29011 amit.gupta 364
	@Autowired
365
	FofoStoreRepository fofoStoreRepository;
366
	@Autowired
367
	PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
368
	@Autowired
369
	StoreTimelineTatService storeTimelineTatService;
29878 tejbeer 370
 
29011 amit.gupta 371
	private boolean getTimeLineStatus(int fofoId) throws ProfitMandiBusinessException {
372
		FofoStore fs = fofoStoreRepository.selectByRetailerId(fofoId);
373
		PartnerOnBoardingPanel partnerOnBoardingPanel = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
374
		boolean status = true;
375
		if (partnerOnBoardingPanel != null) {
376
 
377
			status = storeTimelineTatService.getTimelineCompleted(partnerOnBoardingPanel.getId());
378
		}
379
 
380
		LOGGER.info("status" + status);
381
		return status;
382
	}
383
 
22502 amit.gupta 384
	private RegisteredUserInfo getRegisteredUserInfo(User user) throws Throwable {
22492 amit.gupta 385
		RegisteredUserInfo ri = new RegisteredUserInfo();
386
		ri.setCity(user.getCity());
387
		ri.setFirstName(user.getFirstName());
388
		ri.setLastName(user.getLastName());
22493 amit.gupta 389
		ri.setPhone(user.getMobileNumber());
22492 amit.gupta 390
		ri.setPinCode(user.getPinCode());
22845 amit.gupta 391
		ri.setState(user.getState());
22492 amit.gupta 392
		return ri;
393
	}
21469 amit.gupta 394
 
395
	@RequestMapping(value = ProfitMandiConstants.URL_USER, method = RequestMethod.POST)
21501 amit.gupta 396
	@ApiImplicitParams({
30546 tejbeer 397
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
22032 ashik.ali 398
	public ResponseEntity<?> createUser(HttpServletRequest request, @RequestBody UserRequest userRequest)
22930 ashik.ali 399
			throws ProfitMandiBusinessException {
21469 amit.gupta 400
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21368 kshitij.so 401
		User user = new User();
402
		user.setFirstName(userRequest.getFirstName());
403
		user.setLastName(userRequest.getLastName());
404
		user.setCity(userRequest.getCity());
405
		user.setPinCode(Integer.valueOf(userRequest.getPinCode()));
22845 amit.gupta 406
		user.setState(userRequest.getState());
21708 amit.gupta 407
		user.setMobileNumber(userRequest.getMobieNumber());
21368 kshitij.so 408
		user.setEmailId(userRequest.getEmailId());
409
		user.setUsername("");
410
		user.setPassword("");
411
		user.setMobile_verified(false);
412
		user.setReferral_url("");
413
		user.setGroup_id(1);
22504 amit.gupta 414
		user.setStatus(1);
21368 kshitij.so 415
		user.setActivated(false);
21501 amit.gupta 416
		user.setCreateTimestamp(LocalDateTime.now());
417
		user.setUpdateTimestamp(LocalDateTime.now());
22930 ashik.ali 418
		userRepository.persist(user);
23858 ashik.ali 419
		Role role = roleRepository.selectByName(RoleType.USER.toString());
22930 ashik.ali 420
		UserRole userRole = new UserRole();
23858 ashik.ali 421
		userRole.setRoleId(role.getId());
22930 ashik.ali 422
		userRole.setUserId(user.getId());
423
		userRoleRepository.persist(userRole);
424
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1000"));
25366 tejbeer 425
 
21278 ashik.ali 426
	}
21469 amit.gupta 427
 
428
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ID, method = RequestMethod.GET)
25366 tejbeer 429
	public ResponseEntity<?> getById(HttpServletRequest request, @RequestParam(name = "id") int id)
430
			throws ProfitMandiBusinessException {
21469 amit.gupta 431
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 432
		return responseSender.ok(userRepository.selectById(id));
21248 ashik.ali 433
	}
21469 amit.gupta 434
 
435
	@RequestMapping(value = ProfitMandiConstants.URL_USER_MOBILE_NUMBER, method = RequestMethod.GET)
436
	public ResponseEntity<?> getByMobileNumber(HttpServletRequest request,
30546 tejbeer 437
			@RequestParam(name = "mobileNumber") String mobileNumber) throws ProfitMandiBusinessException {
21469 amit.gupta 438
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 439
		return responseSender.ok(userRepository.selectByMobileNumber(mobileNumber));
21248 ashik.ali 440
	}
21469 amit.gupta 441
 
21784 amit.gupta 442
	@ApiImplicitParams({
30546 tejbeer 443
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
21501 amit.gupta 444
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ACTIVATE, method = RequestMethod.POST)
445
	public ResponseEntity<?> activateUser(HttpServletRequest request,
30546 tejbeer 446
			@RequestParam(name = "activationCode") String activationCode) throws Throwable {
21855 amit.gupta 447
		int userId = (int) request.getAttribute("userId");
21784 amit.gupta 448
		UserCart uc = userAccountRepository.getUserCart(userId);
449
		return responseSender.ok(userService.updateActivation(userId, uc.getUserId(), activationCode));
450
	}
21855 amit.gupta 451
 
25458 tejbeer 452
	/*
453
	 * @ApiImplicitParams({
30295 amit.gupta 454
	 *
25458 tejbeer 455
	 * @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true,
456
	 * dataType = "string", paramType = "header") })
30295 amit.gupta 457
	 *
25458 tejbeer 458
	 * @RequestMapping(value = ProfitMandiConstants.URL_USER_NOTIFICATIONS, method =
459
	 * RequestMethod.GET) public ResponseEntity<?>
460
	 * getNofitications(HttpServletRequest request,
30295 amit.gupta 461
	 *
25458 tejbeer 462
	 * @RequestParam(name = "androidId") String androidId, @RequestParam(name =
463
	 * "pageNumber") int pageNumber,
30295 amit.gupta 464
	 *
25458 tejbeer 465
	 * @RequestParam(name = "pageSize") int pageSize) throws
466
	 * ProfitMandiBusinessException { int userId = (int)
467
	 * request.getAttribute("userId"); String restResponse = null; Map<String,
468
	 * String> params = new HashMap<>();
30295 amit.gupta 469
	 *
25458 tejbeer 470
	 * String uri = "/getAllNotifications"; params.put("user_id", userId + "");
471
	 * params.put("android_id", androidId); params.put("limit", pageSize + "");
472
	 * params.put("offset", "" + ((pageNumber - 1) * pageSize)); try { restResponse
473
	 * = restClient.get(SchemeType.HTTP, nodeHost, nodePort, uri, params); } catch
474
	 * (HttpHostConnectException e) { throw new ProfitMandiBusinessException("", "",
475
	 * "Could not Connect to host"); }
30295 amit.gupta 476
	 *
25458 tejbeer 477
	 * JsonArray result_json = Json.parse(restResponse).asArray();
30295 amit.gupta 478
	 *
25458 tejbeer 479
	 * List<Notification> notifications = new ArrayList<>();
30295 amit.gupta 480
	 *
25458 tejbeer 481
	 * for (JsonValue j : result_json) {
482
	 * notifications.add(toNotifiaction(j.asObject())); }
30295 amit.gupta 483
	 *
25458 tejbeer 484
	 * return responseSender.ok(notifications); }
30295 amit.gupta 485
	 *
25458 tejbeer 486
	 * private Notification toNotifiaction(JsonObject jsonObject) { Notification n =
487
	 * (Notification) (new Gson().fromJson(jsonObject.toString(),
488
	 * Notification.class)); if (n.getStatus().equals("opened") ||
489
	 * n.getStatus().equals("referrer") || n.getStatus().equals("seen")) {
490
	 * n.setSeen(true); } return n; }
491
	 */
21855 amit.gupta 492
 
21426 ashik.ali 493
	@RequestMapping(value = ProfitMandiConstants.URL_USER_IS_EXIST_MOBILE_NUMBER, method = RequestMethod.GET)
21469 amit.gupta 494
	public ResponseEntity<?> isMobileNumberExist(HttpServletRequest request,
30546 tejbeer 495
			@RequestParam(name = "mobileNumber") String mobileNumber) {
21469 amit.gupta 496
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 497
		return responseSender.ok(userRepository.isExistByMobileNumber(mobileNumber));
21426 ashik.ali 498
	}
21469 amit.gupta 499
 
500
	@RequestMapping(value = ProfitMandiConstants.URL_USER_EMAIL_ID, method = RequestMethod.GET)
25366 tejbeer 501
	public ResponseEntity<?> getByEmailId(HttpServletRequest request, @RequestParam(name = "emailId") String emailId)
502
			throws ProfitMandiBusinessException {
21469 amit.gupta 503
		LOGGER.info("requested url : " + request.getRequestURL().toString());
23204 ashik.ali 504
		User user = null;
25366 tejbeer 505
		try {
23204 ashik.ali 506
			user = userRepository.selectByEmailId(emailId);
25366 tejbeer 507
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
23204 ashik.ali 508
			user = userRepository.selectBySecondryEmailId(emailId);
509
		}
510
		return responseSender.ok(user);
21248 ashik.ali 511
	}
21469 amit.gupta 512
 
513
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ROLE_ALL, method = RequestMethod.GET)
514
	public ResponseEntity<?> getAllRoles(HttpServletRequest request, @RequestParam(name = "id") int id) {
515
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 516
		return responseSender.ok(userRoleRepository.selectRolesByUserId(id));
21248 ashik.ali 517
	}
25366 tejbeer 518
 
23204 ashik.ali 519
	@ApiImplicitParams({
30546 tejbeer 520
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
23204 ashik.ali 521
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID_AND_FOFO_STORE_CODE, method = RequestMethod.GET)
25366 tejbeer 522
	public ResponseEntity<?> getSecondryEmailAndStoreCode(HttpServletRequest request)
523
			throws ProfitMandiBusinessException {
23204 ashik.ali 524
		LOGGER.info("requested url : " + request.getRequestURL().toString());
525
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
526
		return responseSender.ok(userService.getEmailsAndFofoStoreCodeByUserId(userId));
527
	}
25366 tejbeer 528
 
23204 ashik.ali 529
	@ApiImplicitParams({
30546 tejbeer 530
			@ApiImplicitParam(name = "Auth-Token", value = "-Token", required = true, dataType = "string", paramType = "header") })
23858 ashik.ali 531
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID, method = RequestMethod.PUT)
23204 ashik.ali 532
	public ResponseEntity<?> updateSecondryEmailId(HttpServletRequest request,
30546 tejbeer 533
			@RequestParam(name = ProfitMandiConstants.SECONDRY_EMAIL_ID) String secondryEmailId) throws Throwable {
25366 tejbeer 534
		int userId = (int) request.getAttribute("userId");
535
		User user = userRepository.selectById(userId);
536
		user.setSecondryEmailId(secondryEmailId);
537
		userRepository.persist(user);
538
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1001"));
539
	}
21414 kshitij.so 540
 
541
	@RequestMapping(value = ProfitMandiConstants.URL_ADMIN_TOKEN, method = RequestMethod.POST)
21469 amit.gupta 542
	public ResponseEntity<?> getAdminToken(HttpServletRequest request,
30546 tejbeer 543
			@RequestParam(name = "adminToken") String adminToken, @RequestParam(name = "emailId") String emailId)
544
			throws Exception {
21469 amit.gupta 545
		LOGGER.info("requested url : " + request.getRequestURL().toString());
546
		if (!adminToken.equals(validAdminToken)) {
22930 ashik.ali 547
			return responseSender.forbidden(null);
21414 kshitij.so 548
		}
21469 amit.gupta 549
 
30295 amit.gupta 550
		return responseSender.ok(this.getAuthTokenMap(emailId));
25366 tejbeer 551
 
21414 kshitij.so 552
	}
25366 tejbeer 553
 
26667 amit.gupta 554
	@RequestMapping(value = "/mobileappsettings")
25366 tejbeer 555
	public ResponseEntity<?> mobileAppSettings(HttpServletRequest request, @RequestParam(name = "t") int timestamp,
30546 tejbeer 556
			@RequestParam(name = "imeinumber") String imeinumber)
25366 tejbeer 557
			throws ProfitMandiBusinessException, ClientProtocolException, IOException {
26644 amit.gupta 558
 
559
		final String uri = "http://192.168.158.89/mobileappsettings?t=" + timestamp + "&imeinumber=" + imeinumber;
560
		final String BASIC_AUTH = "Basic " + Base64.getEncoder().encodeToString("dtr:dtr18Feb2015".getBytes());
561
		Map<String, String> headers = new HashMap<>();
562
		Map<String, String> params = new HashMap<>();
563
		headers.put("Authorization", BASIC_AUTH);
29878 tejbeer 564
		if (timestamp == 0) {
26870 amit.gupta 565
			return responseSender.ok(OrderController.APP_SETTINGS);
566
		} else {
567
			return responseSender.ok(OrderController.APP_SETTINGS_BLANK);
568
		}
25300 tejbeer 569
	}
26792 tejbeer 570
 
26645 amit.gupta 571
	@RequestMapping(value = "/mobileappsettings1", method = RequestMethod.POST)
572
	public ResponseEntity<?> mobileAppSettings1(HttpServletRequest request, @RequestParam(name = "t") int timestamp,
30546 tejbeer 573
			@RequestParam(name = "imeinumber") String imeinumber)
26792 tejbeer 574
			throws ProfitMandiBusinessException, ClientProtocolException, IOException {
26645 amit.gupta 575
		LocalDateTime settingsLastUpdated = LocalDateTime.ofEpochSecond(timestamp, 0, ZoneOffset.ofHoursMinutes(5, 30));
576
		List<MobileAppSetting> mobileAppSettings = mobileAppSettingsRepository.getSettingAftera(settingsLastUpdated);
26792 tejbeer 577
 
26645 amit.gupta 578
		List<MobileAppSettingsWrapper> mobileSettingsWrappersList = mobileAppSettings.stream()
579
				.map(x -> new MobileAppSettingsWrapper(x)).collect(Collectors.toList());
580
		SettingsWrapper wrapper = new SettingsWrapper(mobileSettingsWrappersList);
26792 tejbeer 581
 
26645 amit.gupta 582
		LOGGER.info("Wrapper {}", wrapper);
26646 amit.gupta 583
		return responseSender.ok(objectMapper.writeValueAsString(wrapper));
26645 amit.gupta 584
	}
22032 ashik.ali 585
 
25366 tejbeer 586
	@RequestMapping(value = "/getPartners", method = RequestMethod.GET)
587
	@ApiImplicitParams({
30546 tejbeer 588
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25366 tejbeer 589
	public ResponseEntity<?> getPartners(HttpServletRequest request, @RequestParam(name = "gmailId") String gmailId,
30546 tejbeer 590
			@RequestParam(value = "offset") int offset, @RequestParam(value = "limit") int limit)
25366 tejbeer 591
			throws ProfitMandiBusinessException {
592
		AuthUser authUser = authRepository.selectByGmailId(gmailId);
593
 
25619 amit.gupta 594
		Map<String, Set<String>> storeGuyMap = csService.getAuthUserPartnerEmailMapping();
25366 tejbeer 595
 
25619 amit.gupta 596
		Set<String> emails = storeGuyMap.get(authUser.getEmailId().toLowerCase());
25366 tejbeer 597
		LOGGER.info("emails" + emails);
25619 amit.gupta 598
		List<User> users = userRepository.selectAllByEmails(new ArrayList<>(emails), offset, limit);
25366 tejbeer 599
		List<Partner> partners = new ArrayList<>();
600
		for (User user : users) {
25458 tejbeer 601
 
25366 tejbeer 602
			UserAccount uc = userAccountRepository.selectSaholicByUserId(user.getId());
25458 tejbeer 603
			com.spice.profitmandi.dao.entity.user.User userInfo = userUserRepository.selectById(uc.getAccountKey());
25366 tejbeer 604
			CustomRetailer customRetailer = retailerService.getFofoRetailer(userInfo.getId());
605
 
606
			Partner partner = new Partner();
607
			partner.setBusinessName(customRetailer.getBusinessName());
608
			partner.setPartnerId(customRetailer.getPartnerId());
609
			partner.setCartId(customRetailer.getCartId());
610
			partner.setEmail(customRetailer.getEmail());
611
			partner.setGstNumber(customRetailer.getGstNumber());
612
			partner.setDisplayName(customRetailer.getDisplayName());
613
			partner.setCity(customRetailer.getAddress().getCity());
614
			partner.setUserId(user.getId());
615
			partners.add(partner);
616
		}
617
		LOGGER.info("partners" + partners);
618
		return responseSender.ok(partners);
619
	}
620
 
25458 tejbeer 621
	@RequestMapping(value = "/user/refferal", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
622
	@ApiImplicitParams({
30546 tejbeer 623
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25458 tejbeer 624
	public ResponseEntity<?> RefferalUser(HttpServletRequest request,
30546 tejbeer 625
			@RequestBody CreateRefferalRequest createRefferalRequest) throws Exception {
25458 tejbeer 626
		Refferal refferal = new Refferal();
627
		refferal.setFirstName(createRefferalRequest.getFirstName());
628
		refferal.setLastName(createRefferalRequest.getLastName());
629
		refferal.setMobile(createRefferalRequest.getMobile());
630
		refferal.setState(createRefferalRequest.getState());
631
		refferal.setCity(createRefferalRequest.getCity());
632
		refferal.setCreatedTimestamp(LocalDateTime.now());
633
		refferal.setUpdatedTimestamp(LocalDateTime.now());
25496 tejbeer 634
		refferal.setStatus(RefferalStatus.pending);
25458 tejbeer 635
		if (createRefferalRequest.isFofoAssociate()) {
636
			AuthUser authUser = authRepository.selectByGmailId(createRefferalRequest.getReffereeEmail());
25483 tejbeer 637
			if (authUser == null) {
25458 tejbeer 638
				Promoter promoter = promoterRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
639
				refferal.setRefereeName(promoter.getName());
25483 tejbeer 640
				refferal.setRefereeEmail(promoter.getEmail());
25458 tejbeer 641
				refferal.setRefereeMobile(promoter.getMobile());
642
			} else {
643
				refferal.setRefereeName(authUser.getFirstName());
25483 tejbeer 644
				refferal.setRefereeEmail(authUser.getGmailId());
25458 tejbeer 645
				refferal.setRefereeMobile(authUser.getMobileNumber());
646
			}
647
		} else {
648
			User user = userRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
649
			refferal.setRefereeName(user.getFirstName());
25483 tejbeer 650
			refferal.setRefereeEmail(user.getEmailId());
25458 tejbeer 651
			refferal.setRefereeMobile(user.getMobileNumber());
652
		}
653
 
654
		refferalRepository.persist(refferal);
29892 tejbeer 655
 
656
		List<PartnerOnBoardingPanel> pobs = partnerOnBoardingPanelRepository
657
				.selectAllByPhoneNumber((Long.parseLong(refferal.getMobile())));
658
 
659
		if (!pobs.isEmpty()) {
660
 
661
			List<PartnerOnBoardingStatus> ponbStatus = pobs.stream().map(x -> x.getStatus())
662
					.collect(Collectors.toList());
663
 
664
			if (ponbStatus.contains(PartnerOnBoardingStatus.open)) {
665
				refferal.setStatus(RefferalStatus.rejected);
666
				refferal.setRejectedReason("This is already a Smartdukaan Partner.");
667
			} else if (ponbStatus.contains(PartnerOnBoardingStatus.pending)) {
668
				refferal.setStatus(RefferalStatus.rejected);
669
				refferal.setRejectedReason("This is already a Smartdukaan Partner.");
670
			} else {
671
				this.sendEmailToValidate(refferal);
672
			}
673
 
674
		} else {
675
 
676
			this.sendEmailToValidate(refferal);
677
 
678
		}
679
		return responseSender.ok(true);
680
	}
681
 
682
	private void sendEmailToValidate(Refferal refferal) throws MessagingException, UnsupportedEncodingException {
683
 
26792 tejbeer 684
		String subject = "Referral Validate Request for " + refferal.getRefereeEmail();
685
		String messageText = this.getMessageForReferral(refferal);
686
		MimeMessage message = mailSender.createMimeMessage();
687
		MimeMessageHelper helper = new MimeMessageHelper(message, true);
30546 tejbeer 688
		String[] email = { "kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "sm@smartdukaan.com" };
26792 tejbeer 689
		helper.setSubject(subject);
690
		helper.setText(messageText, true);
691
		helper.setTo(email);
692
		InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
693
		helper.setFrom(senderAddress);
694
		mailSender.send(message);
695
 
25458 tejbeer 696
	}
25488 tejbeer 697
 
26792 tejbeer 698
	private String getMessageForReferral(Refferal referral) {
699
 
700
		StringBuilder sb = new StringBuilder();
701
		sb.append("<html><body><p>Alert</p><p> Referral Requests:-</p>"
702
				+ "<br/><table style='border:1px solid black ;padding: 5px';>");
703
		sb.append("<tbody>\n" + "	    				<tr>\n"
704
				+ "	    					<th style='border:1px solid black;padding: 5px'>RefereeName</th>\n"
705
				+ "	    					<th style='border:1px solid black;padding: 5px'>Referee Email</th>\n"
706
				+ "	    					<th style='border:1px solid black;padding: 5px'>Referral Name</th>\n"
707
				+ "	    					<th style='border:1px solid black;padding: 5px'>Refferal Mobile</th>\n"
708
				+ "	    					<th style='border:1px solid black;padding: 5px'>city</th>\n"
709
				+ "	    					<th style='border:1px solid black;padding: 5px'>state</th>\n"
710
				+ "	    				</tr>");
711
 
712
		sb.append("<tr>");
713
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getRefereeName() + "</td>");
714
 
715
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getRefereeEmail() + "</td>");
716
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getFirstName() + "</td>");
717
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getMobile() + "</td>");
718
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getCity() + "</td>");
719
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getState() + "</td>");
720
 
721
		sb.append("</tr>");
722
 
723
		sb.append("</tbody></table></body></html>");
724
 
725
		return sb.toString();
726
	}
727
 
25488 tejbeer 728
	@RequestMapping(value = "/user/refferalAmount", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
729
	@ApiImplicitParams({
30546 tejbeer 730
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25488 tejbeer 731
	public ResponseEntity<?> RefferalAmount(HttpServletRequest request, @RequestParam String refereeEmail)
732
			throws Exception {
733
		LocalDateTime ldt = LocalDate.now().atStartOfDay().withDayOfMonth(16);
734
		DateRangeModel drm = new DateRangeModel();
735
		List<RefferalEarningModel> refferAmountModel = new ArrayList<RefferalEarningModel>();
736
		RefferalEarningModel rfm = new RefferalEarningModel();
737
		long currentMonthEstimaterefferal = 0;
738
		long currentMonthConfirmedrefferal = 0;
739
		if (LocalDateTime.now().isBefore(ldt)) {
740
			List<Refferal> allPendingRefferalBeforeCurrentMonth = refferalRepository
741
					.selectByEmailIdAndStatusAndbeforeCurrentMonth(refereeEmail, RefferalStatus.pending);
742
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
743
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(1));
744
 
745
			List<Refferal> previousMonthapprovedRefferalAfterSixteen = refferalRepository
746
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
747
			List<Refferal> previousMonthtransferredRefferalAfterSixteen = refferalRepository
748
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
749
 
750
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
751
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
752
 
753
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
754
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
755
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
756
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
757
			long pendingRefferalBeforeCurrentMonth = allPendingRefferalBeforeCurrentMonth.size();
758
			long previousapprovedRefferalAfterSixteen = previousMonthapprovedRefferalAfterSixteen.size();
759
			long previoustransferredRefferalAfterSixteen = previousMonthtransferredRefferalAfterSixteen.size();
760
			long previousapprovedRefferalbeforeSixteen = previousMonthapprovedRefferalbeforeSixteen.size();
761
			long previoustransferredRefferalbeforeSixteen = previousMonthtransferredRefferalbeforeSixteen.size();
762
			long previousMonthEstimateRefferal = pendingRefferalBeforeCurrentMonth
763
					+ previousapprovedRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen;
764
			long previousMonthConfirmedRefferal = previousapprovedRefferalAfterSixteen
765
					+ previoustransferredRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen
766
					+ previoustransferredRefferalbeforeSixteen;
25490 tejbeer 767
			rfm = refferAmountEarning(pendingRefferalBeforeCurrentMonth, previousMonthConfirmedRefferal,
25488 tejbeer 768
					YearMonth.now().minusMonths(1));
769
			refferAmountModel.add(rfm);
770
			LOGGER.info("previousMonthPendingApprovedRefferal" + previousMonthEstimateRefferal);
771
			LOGGER.info("previousMonthApprovedTransfferedRefferal" + previousMonthConfirmedRefferal);
772
 
25509 tejbeer 773
			List<Refferal> pendingofCurrentMonth = refferalRepository
774
					.selectByEmailIdAndStatusAndBetweenDates(refereeEmail, RefferalStatus.pending, YearMonth.now());
25488 tejbeer 775
			List<Refferal> approvedofCurrentMonth = refferalRepository.selectByEmailIdAndStatusAndDatesBetweenTimestamp(
776
					refereeEmail, RefferalStatus.approved, YearMonth.now());
777
			List<Refferal> transferredofCurrentMonth = refferalRepository
778
					.selectByEmailIdAndStatusAndDatesBetweenTimestamp(refereeEmail, RefferalStatus.transferred,
779
							YearMonth.now());
25490 tejbeer 780
			LOGGER.info("pendingofCurrentMonth" + pendingofCurrentMonth);
25509 tejbeer 781
			long pendingofCurrentMonthCount = pendingofCurrentMonth.size();
25488 tejbeer 782
			currentMonthEstimaterefferal = pendingofCurrentMonth.size() + approvedofCurrentMonth.size();
783
			currentMonthConfirmedrefferal = approvedofCurrentMonth.size() + transferredofCurrentMonth.size();
25509 tejbeer 784
 
25490 tejbeer 785
			rfm = refferAmountEarning(pendingofCurrentMonthCount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 786
 
787
			refferAmountModel.add(rfm);
788
 
789
		} else if (LocalDateTime.now().isAfter(ldt)) {
790
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
25496 tejbeer 791
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
25488 tejbeer 792
 
793
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
794
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
795
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
796
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
797
 
798
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
799
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
800
 
801
			List<Refferal> previousAndcurrentMonthapprovedRefferal = refferalRepository
802
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
803
 
804
			LocalDateTime currentMonthdate = LocalDateTime.now().withDayOfMonth(1);
805
 
806
			List<Refferal> preCurrMonthapproved = previousAndcurrentMonthapprovedRefferal.stream()
807
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
808
			List<Refferal> previousAndcurrentMonthtransferredRefferal = refferalRepository
809
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
810
			List<Refferal> preCurrMonthtransferred = previousAndcurrentMonthtransferredRefferal.stream()
811
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
812
 
813
			long approvedRefferal = previousMonthapprovedRefferalbeforeSixteen.size()
814
					+ previousMonthtransferredRefferalbeforeSixteen.size() + preCurrMonthapproved.size()
815
					+ preCurrMonthtransferred.size();
816
			rfm = new RefferalEarningModel();
29878 tejbeer 817
			rfm.setActualEarning(approvedRefferal * 5000);
27595 tejbeer 818
 
25488 tejbeer 819
			rfm.setYearMonth(YearMonth.now().minusMonths(1));
25490 tejbeer 820
			rfm.setPendingRefferal(0);
25509 tejbeer 821
			rfm.setApprovedRefferal(approvedRefferal);
25488 tejbeer 822
			refferAmountModel.add(rfm);
823
			List<Refferal> allpendingRefferal = refferalRepository.selectByEmailIdAndStatus(refereeEmail,
824
					RefferalStatus.pending);
825
			LOGGER.info("allpendingRefferal" + allpendingRefferal);
826
 
827
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(16));
828
			drm.setEndDate(LocalDateTime.now().plusMonths(1).withDayOfMonth(1));
829
 
830
			List<Refferal> currentMonthapprovedRefferalAfterSixteen = refferalRepository
831
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
832
			List<Refferal> currentMonthtransferredRefferalAfterSixteen = refferalRepository
833
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
834
			LOGGER.info("currentMonthapprovedRefferalAfterSixteen" + currentMonthapprovedRefferalAfterSixteen);
835
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(1));
836
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
837
 
838
			List<Refferal> currentMonthapprovedRefferalbeforeSixteen = refferalRepository
839
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
840
			List<Refferal> currentMonthtransferredRefferalbeforeSixteen = refferalRepository
841
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
842
			LOGGER.info("currentMonthapprovedRefferalbeforeSixteen" + currentMonthapprovedRefferalbeforeSixteen);
25509 tejbeer 843
			long pendingrefferalcount = allpendingRefferal.size();
25488 tejbeer 844
			currentMonthConfirmedrefferal = currentMonthapprovedRefferalAfterSixteen.size()
845
					+ currentMonthtransferredRefferalAfterSixteen.size()
846
					+ currentMonthapprovedRefferalbeforeSixteen.size()
847
					+ currentMonthtransferredRefferalbeforeSixteen.size();
25509 tejbeer 848
 
849
			rfm = refferAmountEarning(pendingrefferalcount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 850
			refferAmountModel.add(rfm);
851
			LOGGER.info("currentMonthpendingApprovedrefferal" + currentMonthEstimaterefferal);
852
 
853
			LOGGER.info("currentMonthapprovedTransferredrefferal" + currentMonthConfirmedrefferal);
854
 
855
		}
856
		RefferalEarning re = new RefferalEarning();
857
		re.setTimestamp(LocalDateTime.now());
858
		re.setRefferalEarningModel(refferAmountModel);
859
		return responseSender.ok(re);
860
	}
861
 
25490 tejbeer 862
	private RefferalEarningModel refferAmountEarning(long pendingRefferalValue, long confirmedRefferalValue,
30546 tejbeer 863
			YearMonth yearMonth) {
25488 tejbeer 864
		RefferalEarningModel rfm = new RefferalEarningModel();
865
		rfm.setYearMonth(yearMonth);
25490 tejbeer 866
		rfm.setPendingRefferal(pendingRefferalValue);
867
		rfm.setApprovedRefferal(confirmedRefferalValue);
25509 tejbeer 868
		long estimateRefferalValue = pendingRefferalValue + confirmedRefferalValue;
25488 tejbeer 869
 
29878 tejbeer 870
		rfm.setMaximumEarning(estimateRefferalValue * 5000);
27595 tejbeer 871
 
29878 tejbeer 872
		rfm.setMinimumEarning(confirmedRefferalValue * 5000);
27595 tejbeer 873
 
25488 tejbeer 874
		return rfm;
875
	}
25979 tejbeer 876
 
29890 tejbeer 877
	@RequestMapping(value = "/user/getReferals", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
878
	@ApiImplicitParams({
30546 tejbeer 879
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
29890 tejbeer 880
	public ResponseEntity<?> getReferals(HttpServletRequest request, @RequestParam RefferalStatus status)
881
			throws Exception {
882
		int userId = (int) request.getAttribute("userId");
883
 
884
		User user = userRepository.selectById(userId);
885
		UserCart uc = userAccountRepository.getUserCart(userId);
886
 
887
		List<Refferal> refferals = refferalRepository.selectByEmailIdAndStatus(user.getEmailId(), status);
888
		return responseSender.ok(refferals);
889
	}
890
 
25622 amit.gupta 891
	@RequestMapping(value = "/user/partnerTarget", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
892
	@ApiImplicitParams({
30546 tejbeer 893
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25622 amit.gupta 894
	public ResponseEntity<?> PartnerTarget(HttpServletRequest request) throws Exception {
895
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
896
		int retailerId = userAccountRepository.selectRetailerIdByUserId(userId);
897
		PartnerType partnerType = partnerTypeChangeService.getTypeOnDate(retailerId, LocalDate.now());
25979 tejbeer 898
 
25622 amit.gupta 899
		return responseSender.ok(partnerType);
900
	}
26636 amit.gupta 901
 
27425 tejbeer 902
	@RequestMapping(value = "/user/authUser", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
903
	@ApiImplicitParams({
30546 tejbeer 904
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
27425 tejbeer 905
	public ResponseEntity<?> authUserDetail(HttpServletRequest request, @RequestParam int userId) throws Exception {
906
		User user = userRepository.selectById(userId);
907
		AuthUser authUser = authRepository.selectByEmailOrMobile(user.getEmailId());
908
		return responseSender.ok(authUser);
909
	}
910
 
21248 ashik.ali 911
}
26636 amit.gupta 912
 
913
class MobileAppSettingsWrapper {
914
	@JsonProperty(value = "Mobileappsetting")
915
	private MobileAppSetting mobileAppSettings;
916
 
917
	public MobileAppSettingsWrapper(MobileAppSetting mobileAppSettings) {
918
		super();
919
		this.mobileAppSettings = mobileAppSettings;
920
	}
26642 amit.gupta 921
 
922
	public MobileAppSetting getMobileAppSettings() {
923
		return mobileAppSettings;
924
	}
925
 
926
	public void setMobileAppSettings(MobileAppSetting mobileAppSettings) {
927
		this.mobileAppSettings = mobileAppSettings;
928
	}
26643 amit.gupta 929
 
930
	@Override
931
	public String toString() {
932
		return "MobileAppSettingsWrapper [mobileAppSettings=" + mobileAppSettings + "]";
933
	}
26644 amit.gupta 934
 
26636 amit.gupta 935
}
936
 
937
class SettingsWrapper {
938
	private List<MobileAppSettingsWrapper> settings;
26644 amit.gupta 939
 
26636 amit.gupta 940
	public SettingsWrapper(List<MobileAppSettingsWrapper> settings) {
941
		super();
942
		this.settings = settings;
943
	}
944
 
26642 amit.gupta 945
	@Override
946
	public String toString() {
947
		return "SettingsWrapper [settings=" + settings + "]";
948
	}
949
 
950
	public List<MobileAppSettingsWrapper> getSettings() {
951
		return settings;
952
	}
953
 
954
	public void setSettings(List<MobileAppSettingsWrapper> settings) {
955
		this.settings = settings;
956
	}
957
 
27425 tejbeer 958
}