Subversion Repositories SmartDukaan

Rev

Rev 30554 | Rev 30556 | 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();
30552 tejbeer 265
 
266
			LOGGER.info("emailtrue {}", userInfo.getEmail() == null);
267
 
30553 tejbeer 268
			LOGGER.info("equality {}",
269
					!(userInfo.getEmail() == null || user.getEmailId().equalsIgnoreCase(userInfo.getEmail())));
30555 tejbeer 270
			if (!(userInfo.getEmail() == null || user.getEmailId().equalsIgnoreCase(userInfo.getEmail()))) {
24491 amit.gupta 271
				String userName = null;
30547 tejbeer 272
				LOGGER.info("userinfo2 {}", userInfo);
25366 tejbeer 273
				if (user.getSecondryEmailId() != null && user.getSecondryEmailId().equals(userInfo.getEmail())) {
30547 tejbeer 274
 
275
					LOGGER.info("userinfo3 {}", user);
24491 amit.gupta 276
					userName = user.getFirstName() + " " + user.getLastName();
277
				} else {
28021 amit.gupta 278
					AuthUser authUser = authRepository.selectByGmailId(userInfo.getEmail());
30546 tejbeer 279
					LOGGER.info("authUser {}", authUser);
29878 tejbeer 280
					if (authUser == null || !authUser.isActive()) {
28021 amit.gupta 281
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_REGISTERED.getValue());
282
						responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
283
						return responseSender.ok(responseMap);
284
					}
285
					userName = authUser.getName();
24491 amit.gupta 286
				}
287
				responseMap.put(ProfitMandiConstants.USER_ID, userInfo.getUserId());
288
				responseMap.put(ProfitMandiConstants.USER_NAME, userName);
289
				responseMap.put(ProfitMandiConstants.USER_STATUS, "fofoAssociate");
290
				responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
26570 amit.gupta 291
				responseMap.put("storeUrl", "");
24491 amit.gupta 292
				return responseSender.ok(responseMap);
293
			}
30549 tejbeer 294
			LOGGER.info("userinfo10 {}", userInfo);
21483 amit.gupta 295
		} else {
296
			try {
30547 tejbeer 297
 
298
				LOGGER.info("userinfo4 {}", userInfo);
21483 amit.gupta 299
				user = userRepository.selectByEmailId(userInfo.getEmail());
300
			} catch (ProfitMandiBusinessException e1) {
301
			}
25366 tejbeer 302
			if (user == null) {
23204 ashik.ali 303
				try {
30548 tejbeer 304
					LOGGER.info("userinfo8 {}", userInfo);
23204 ashik.ali 305
					user = userRepository.selectBySecondryEmailId(userInfo.getEmail());
306
				} catch (ProfitMandiBusinessException e1) {
307
					LOGGER.info("Uneregistered user", userInfo.getEmail());
308
				}
309
			}
21483 amit.gupta 310
		}
311
		if (user != null) {
23858 ashik.ali 312
			int retailerId = userAccountRepository.selectRetailerIdByUserId(user.getId());
21491 amit.gupta 313
			responseMap.put(ProfitMandiConstants.EMAIL_ID, user.getEmailId());
21526 amit.gupta 314
			responseMap.put(ProfitMandiConstants.USER_ID, user.getId());
22017 amit.gupta 315
			responseMap.put(ProfitMandiConstants.USER_NAME, user.getFirstName() + " " + user.getLastName());
23786 amit.gupta 316
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(user.getId());
25366 tejbeer 317
			// LOGGER.info("userRoles {} ", userRoles);
22032 ashik.ali 318
 
319
			// generate new token if roles have been updated
23786 amit.gupta 320
			if (userInfo.getRoleIds() == null || roleIds.size() != userInfo.getRoleIds().size()) {
23858 ashik.ali 321
				String[] roleIdStrings = new String[roleIds.size()];
22603 amit.gupta 322
				int index = 0;
23786 amit.gupta 323
				for (int roleId : roleIds) {
23858 ashik.ali 324
					roleIdStrings[index++] = String.valueOf(roleId);
22603 amit.gupta 325
				}
23858 ashik.ali 326
				String newToken = JWTUtil.create(user.getId(), retailerId, roleIdStrings);
21483 amit.gupta 327
				responseMap.put("newAuthToken", newToken);
328
			}
23858 ashik.ali 329
			// if user is retailer
23786 amit.gupta 330
			Set<Integer> roleIdsSet = new HashSet<Integer>(roleIds);
23858 ashik.ali 331
			if (roleManager.isRetailer(roleIdsSet)) {
22032 ashik.ali 332
				UserCart uc = userAccountRepository.getUserCart(userInfo.getUserId());
333
				Retailer retailer = retailerRepository.selectById(uc.getUserId());
22370 amit.gupta 334
				com.spice.profitmandi.dao.entity.user.User saholicUser = userUserRepository.selectById(uc.getUserId());
25366 tejbeer 335
				if (saholicUser.getAddressId() != null) {
22370 amit.gupta 336
					Address address = addressRepository.selectById(saholicUser.getAddressId());
337
					responseMap.put(ProfitMandiConstants.ADDRESS, address);
338
				}
21485 amit.gupta 339
				// if retailer is activated 1 then verified retailer
340
				// else if migrated is 1 then old retailer
25366 tejbeer 341
				// also lets incoporte old process i.e is user is activated then also retailer
342
				// is verified retailer
21485 amit.gupta 343
				// else retailer is not verifed
22497 amit.gupta 344
				if (retailer.isActive() || user.isActivated()) {
23798 amit.gupta 345
					if (roleManager.isPartner(roleIdsSet)) {
22017 amit.gupta 346
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.FOFO.getValue());
26533 amit.gupta 347
						responseMap.put("storeUrl", retailerService.getAllFofoRetailerIdUrlMap().get(uc.getUserId()));
29011 amit.gupta 348
						responseMap.put("timelineStatus", this.getTimeLineStatus(uc.getUserId()));
22017 amit.gupta 349
					} else {
350
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.VERIFIED_RETAILER.getValue());
351
					}
22032 ashik.ali 352
				} else if (retailer.isMigrated()) {
21485 amit.gupta 353
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.RETAILER.getValue());
21469 amit.gupta 354
				} else {
21485 amit.gupta 355
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_VERIFIED_RETAILER.getValue());
21469 amit.gupta 356
				}
23798 amit.gupta 357
			} else if (roleManager.isUser(roleIdsSet)) {
22502 amit.gupta 358
				responseMap.put("userInfo", getRegisteredUserInfo(user));
21469 amit.gupta 359
				responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.REGISTERED.getValue());
22032 ashik.ali 360
			}
21491 amit.gupta 361
		} else {
362
			responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_REGISTERED.getValue());
363
			responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
21469 amit.gupta 364
		}
22032 ashik.ali 365
 
21469 amit.gupta 366
		return responseSender.ok(responseMap);
367
	}
25366 tejbeer 368
 
29011 amit.gupta 369
	@Autowired
370
	FofoStoreRepository fofoStoreRepository;
371
	@Autowired
372
	PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
373
	@Autowired
374
	StoreTimelineTatService storeTimelineTatService;
29878 tejbeer 375
 
29011 amit.gupta 376
	private boolean getTimeLineStatus(int fofoId) throws ProfitMandiBusinessException {
377
		FofoStore fs = fofoStoreRepository.selectByRetailerId(fofoId);
378
		PartnerOnBoardingPanel partnerOnBoardingPanel = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
379
		boolean status = true;
380
		if (partnerOnBoardingPanel != null) {
381
 
382
			status = storeTimelineTatService.getTimelineCompleted(partnerOnBoardingPanel.getId());
383
		}
384
 
385
		LOGGER.info("status" + status);
386
		return status;
387
	}
388
 
22502 amit.gupta 389
	private RegisteredUserInfo getRegisteredUserInfo(User user) throws Throwable {
22492 amit.gupta 390
		RegisteredUserInfo ri = new RegisteredUserInfo();
391
		ri.setCity(user.getCity());
392
		ri.setFirstName(user.getFirstName());
393
		ri.setLastName(user.getLastName());
22493 amit.gupta 394
		ri.setPhone(user.getMobileNumber());
22492 amit.gupta 395
		ri.setPinCode(user.getPinCode());
22845 amit.gupta 396
		ri.setState(user.getState());
22492 amit.gupta 397
		return ri;
398
	}
21469 amit.gupta 399
 
400
	@RequestMapping(value = ProfitMandiConstants.URL_USER, method = RequestMethod.POST)
21501 amit.gupta 401
	@ApiImplicitParams({
30546 tejbeer 402
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
22032 ashik.ali 403
	public ResponseEntity<?> createUser(HttpServletRequest request, @RequestBody UserRequest userRequest)
22930 ashik.ali 404
			throws ProfitMandiBusinessException {
21469 amit.gupta 405
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21368 kshitij.so 406
		User user = new User();
407
		user.setFirstName(userRequest.getFirstName());
408
		user.setLastName(userRequest.getLastName());
409
		user.setCity(userRequest.getCity());
410
		user.setPinCode(Integer.valueOf(userRequest.getPinCode()));
22845 amit.gupta 411
		user.setState(userRequest.getState());
21708 amit.gupta 412
		user.setMobileNumber(userRequest.getMobieNumber());
21368 kshitij.so 413
		user.setEmailId(userRequest.getEmailId());
414
		user.setUsername("");
415
		user.setPassword("");
416
		user.setMobile_verified(false);
417
		user.setReferral_url("");
418
		user.setGroup_id(1);
22504 amit.gupta 419
		user.setStatus(1);
21368 kshitij.so 420
		user.setActivated(false);
21501 amit.gupta 421
		user.setCreateTimestamp(LocalDateTime.now());
422
		user.setUpdateTimestamp(LocalDateTime.now());
22930 ashik.ali 423
		userRepository.persist(user);
23858 ashik.ali 424
		Role role = roleRepository.selectByName(RoleType.USER.toString());
22930 ashik.ali 425
		UserRole userRole = new UserRole();
23858 ashik.ali 426
		userRole.setRoleId(role.getId());
22930 ashik.ali 427
		userRole.setUserId(user.getId());
428
		userRoleRepository.persist(userRole);
429
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1000"));
25366 tejbeer 430
 
21278 ashik.ali 431
	}
21469 amit.gupta 432
 
433
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ID, method = RequestMethod.GET)
25366 tejbeer 434
	public ResponseEntity<?> getById(HttpServletRequest request, @RequestParam(name = "id") int id)
435
			throws ProfitMandiBusinessException {
21469 amit.gupta 436
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 437
		return responseSender.ok(userRepository.selectById(id));
21248 ashik.ali 438
	}
21469 amit.gupta 439
 
440
	@RequestMapping(value = ProfitMandiConstants.URL_USER_MOBILE_NUMBER, method = RequestMethod.GET)
441
	public ResponseEntity<?> getByMobileNumber(HttpServletRequest request,
30546 tejbeer 442
			@RequestParam(name = "mobileNumber") String mobileNumber) throws ProfitMandiBusinessException {
21469 amit.gupta 443
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 444
		return responseSender.ok(userRepository.selectByMobileNumber(mobileNumber));
21248 ashik.ali 445
	}
21469 amit.gupta 446
 
21784 amit.gupta 447
	@ApiImplicitParams({
30546 tejbeer 448
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
21501 amit.gupta 449
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ACTIVATE, method = RequestMethod.POST)
450
	public ResponseEntity<?> activateUser(HttpServletRequest request,
30546 tejbeer 451
			@RequestParam(name = "activationCode") String activationCode) throws Throwable {
21855 amit.gupta 452
		int userId = (int) request.getAttribute("userId");
21784 amit.gupta 453
		UserCart uc = userAccountRepository.getUserCart(userId);
454
		return responseSender.ok(userService.updateActivation(userId, uc.getUserId(), activationCode));
455
	}
21855 amit.gupta 456
 
25458 tejbeer 457
	/*
458
	 * @ApiImplicitParams({
30295 amit.gupta 459
	 *
25458 tejbeer 460
	 * @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true,
461
	 * dataType = "string", paramType = "header") })
30295 amit.gupta 462
	 *
25458 tejbeer 463
	 * @RequestMapping(value = ProfitMandiConstants.URL_USER_NOTIFICATIONS, method =
464
	 * RequestMethod.GET) public ResponseEntity<?>
465
	 * getNofitications(HttpServletRequest request,
30295 amit.gupta 466
	 *
25458 tejbeer 467
	 * @RequestParam(name = "androidId") String androidId, @RequestParam(name =
468
	 * "pageNumber") int pageNumber,
30295 amit.gupta 469
	 *
25458 tejbeer 470
	 * @RequestParam(name = "pageSize") int pageSize) throws
471
	 * ProfitMandiBusinessException { int userId = (int)
472
	 * request.getAttribute("userId"); String restResponse = null; Map<String,
473
	 * String> params = new HashMap<>();
30295 amit.gupta 474
	 *
25458 tejbeer 475
	 * String uri = "/getAllNotifications"; params.put("user_id", userId + "");
476
	 * params.put("android_id", androidId); params.put("limit", pageSize + "");
477
	 * params.put("offset", "" + ((pageNumber - 1) * pageSize)); try { restResponse
478
	 * = restClient.get(SchemeType.HTTP, nodeHost, nodePort, uri, params); } catch
479
	 * (HttpHostConnectException e) { throw new ProfitMandiBusinessException("", "",
480
	 * "Could not Connect to host"); }
30295 amit.gupta 481
	 *
25458 tejbeer 482
	 * JsonArray result_json = Json.parse(restResponse).asArray();
30295 amit.gupta 483
	 *
25458 tejbeer 484
	 * List<Notification> notifications = new ArrayList<>();
30295 amit.gupta 485
	 *
25458 tejbeer 486
	 * for (JsonValue j : result_json) {
487
	 * notifications.add(toNotifiaction(j.asObject())); }
30295 amit.gupta 488
	 *
25458 tejbeer 489
	 * return responseSender.ok(notifications); }
30295 amit.gupta 490
	 *
25458 tejbeer 491
	 * private Notification toNotifiaction(JsonObject jsonObject) { Notification n =
492
	 * (Notification) (new Gson().fromJson(jsonObject.toString(),
493
	 * Notification.class)); if (n.getStatus().equals("opened") ||
494
	 * n.getStatus().equals("referrer") || n.getStatus().equals("seen")) {
495
	 * n.setSeen(true); } return n; }
496
	 */
21855 amit.gupta 497
 
21426 ashik.ali 498
	@RequestMapping(value = ProfitMandiConstants.URL_USER_IS_EXIST_MOBILE_NUMBER, method = RequestMethod.GET)
21469 amit.gupta 499
	public ResponseEntity<?> isMobileNumberExist(HttpServletRequest request,
30546 tejbeer 500
			@RequestParam(name = "mobileNumber") String mobileNumber) {
21469 amit.gupta 501
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 502
		return responseSender.ok(userRepository.isExistByMobileNumber(mobileNumber));
21426 ashik.ali 503
	}
21469 amit.gupta 504
 
505
	@RequestMapping(value = ProfitMandiConstants.URL_USER_EMAIL_ID, method = RequestMethod.GET)
25366 tejbeer 506
	public ResponseEntity<?> getByEmailId(HttpServletRequest request, @RequestParam(name = "emailId") String emailId)
507
			throws ProfitMandiBusinessException {
21469 amit.gupta 508
		LOGGER.info("requested url : " + request.getRequestURL().toString());
23204 ashik.ali 509
		User user = null;
25366 tejbeer 510
		try {
23204 ashik.ali 511
			user = userRepository.selectByEmailId(emailId);
25366 tejbeer 512
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
23204 ashik.ali 513
			user = userRepository.selectBySecondryEmailId(emailId);
514
		}
515
		return responseSender.ok(user);
21248 ashik.ali 516
	}
21469 amit.gupta 517
 
518
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ROLE_ALL, method = RequestMethod.GET)
519
	public ResponseEntity<?> getAllRoles(HttpServletRequest request, @RequestParam(name = "id") int id) {
520
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 521
		return responseSender.ok(userRoleRepository.selectRolesByUserId(id));
21248 ashik.ali 522
	}
25366 tejbeer 523
 
23204 ashik.ali 524
	@ApiImplicitParams({
30546 tejbeer 525
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
23204 ashik.ali 526
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID_AND_FOFO_STORE_CODE, method = RequestMethod.GET)
25366 tejbeer 527
	public ResponseEntity<?> getSecondryEmailAndStoreCode(HttpServletRequest request)
528
			throws ProfitMandiBusinessException {
23204 ashik.ali 529
		LOGGER.info("requested url : " + request.getRequestURL().toString());
530
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
531
		return responseSender.ok(userService.getEmailsAndFofoStoreCodeByUserId(userId));
532
	}
25366 tejbeer 533
 
23204 ashik.ali 534
	@ApiImplicitParams({
30546 tejbeer 535
			@ApiImplicitParam(name = "Auth-Token", value = "-Token", required = true, dataType = "string", paramType = "header") })
23858 ashik.ali 536
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID, method = RequestMethod.PUT)
23204 ashik.ali 537
	public ResponseEntity<?> updateSecondryEmailId(HttpServletRequest request,
30546 tejbeer 538
			@RequestParam(name = ProfitMandiConstants.SECONDRY_EMAIL_ID) String secondryEmailId) throws Throwable {
25366 tejbeer 539
		int userId = (int) request.getAttribute("userId");
540
		User user = userRepository.selectById(userId);
541
		user.setSecondryEmailId(secondryEmailId);
542
		userRepository.persist(user);
543
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1001"));
544
	}
21414 kshitij.so 545
 
546
	@RequestMapping(value = ProfitMandiConstants.URL_ADMIN_TOKEN, method = RequestMethod.POST)
21469 amit.gupta 547
	public ResponseEntity<?> getAdminToken(HttpServletRequest request,
30546 tejbeer 548
			@RequestParam(name = "adminToken") String adminToken, @RequestParam(name = "emailId") String emailId)
549
			throws Exception {
21469 amit.gupta 550
		LOGGER.info("requested url : " + request.getRequestURL().toString());
551
		if (!adminToken.equals(validAdminToken)) {
22930 ashik.ali 552
			return responseSender.forbidden(null);
21414 kshitij.so 553
		}
21469 amit.gupta 554
 
30295 amit.gupta 555
		return responseSender.ok(this.getAuthTokenMap(emailId));
25366 tejbeer 556
 
21414 kshitij.so 557
	}
25366 tejbeer 558
 
26667 amit.gupta 559
	@RequestMapping(value = "/mobileappsettings")
25366 tejbeer 560
	public ResponseEntity<?> mobileAppSettings(HttpServletRequest request, @RequestParam(name = "t") int timestamp,
30546 tejbeer 561
			@RequestParam(name = "imeinumber") String imeinumber)
25366 tejbeer 562
			throws ProfitMandiBusinessException, ClientProtocolException, IOException {
26644 amit.gupta 563
 
564
		final String uri = "http://192.168.158.89/mobileappsettings?t=" + timestamp + "&imeinumber=" + imeinumber;
565
		final String BASIC_AUTH = "Basic " + Base64.getEncoder().encodeToString("dtr:dtr18Feb2015".getBytes());
566
		Map<String, String> headers = new HashMap<>();
567
		Map<String, String> params = new HashMap<>();
568
		headers.put("Authorization", BASIC_AUTH);
29878 tejbeer 569
		if (timestamp == 0) {
26870 amit.gupta 570
			return responseSender.ok(OrderController.APP_SETTINGS);
571
		} else {
572
			return responseSender.ok(OrderController.APP_SETTINGS_BLANK);
573
		}
25300 tejbeer 574
	}
26792 tejbeer 575
 
26645 amit.gupta 576
	@RequestMapping(value = "/mobileappsettings1", method = RequestMethod.POST)
577
	public ResponseEntity<?> mobileAppSettings1(HttpServletRequest request, @RequestParam(name = "t") int timestamp,
30546 tejbeer 578
			@RequestParam(name = "imeinumber") String imeinumber)
26792 tejbeer 579
			throws ProfitMandiBusinessException, ClientProtocolException, IOException {
26645 amit.gupta 580
		LocalDateTime settingsLastUpdated = LocalDateTime.ofEpochSecond(timestamp, 0, ZoneOffset.ofHoursMinutes(5, 30));
581
		List<MobileAppSetting> mobileAppSettings = mobileAppSettingsRepository.getSettingAftera(settingsLastUpdated);
26792 tejbeer 582
 
26645 amit.gupta 583
		List<MobileAppSettingsWrapper> mobileSettingsWrappersList = mobileAppSettings.stream()
584
				.map(x -> new MobileAppSettingsWrapper(x)).collect(Collectors.toList());
585
		SettingsWrapper wrapper = new SettingsWrapper(mobileSettingsWrappersList);
26792 tejbeer 586
 
26645 amit.gupta 587
		LOGGER.info("Wrapper {}", wrapper);
26646 amit.gupta 588
		return responseSender.ok(objectMapper.writeValueAsString(wrapper));
26645 amit.gupta 589
	}
22032 ashik.ali 590
 
25366 tejbeer 591
	@RequestMapping(value = "/getPartners", method = RequestMethod.GET)
592
	@ApiImplicitParams({
30546 tejbeer 593
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25366 tejbeer 594
	public ResponseEntity<?> getPartners(HttpServletRequest request, @RequestParam(name = "gmailId") String gmailId,
30546 tejbeer 595
			@RequestParam(value = "offset") int offset, @RequestParam(value = "limit") int limit)
25366 tejbeer 596
			throws ProfitMandiBusinessException {
597
		AuthUser authUser = authRepository.selectByGmailId(gmailId);
598
 
25619 amit.gupta 599
		Map<String, Set<String>> storeGuyMap = csService.getAuthUserPartnerEmailMapping();
25366 tejbeer 600
 
25619 amit.gupta 601
		Set<String> emails = storeGuyMap.get(authUser.getEmailId().toLowerCase());
25366 tejbeer 602
		LOGGER.info("emails" + emails);
25619 amit.gupta 603
		List<User> users = userRepository.selectAllByEmails(new ArrayList<>(emails), offset, limit);
25366 tejbeer 604
		List<Partner> partners = new ArrayList<>();
605
		for (User user : users) {
25458 tejbeer 606
 
25366 tejbeer 607
			UserAccount uc = userAccountRepository.selectSaholicByUserId(user.getId());
25458 tejbeer 608
			com.spice.profitmandi.dao.entity.user.User userInfo = userUserRepository.selectById(uc.getAccountKey());
25366 tejbeer 609
			CustomRetailer customRetailer = retailerService.getFofoRetailer(userInfo.getId());
610
 
611
			Partner partner = new Partner();
612
			partner.setBusinessName(customRetailer.getBusinessName());
613
			partner.setPartnerId(customRetailer.getPartnerId());
614
			partner.setCartId(customRetailer.getCartId());
615
			partner.setEmail(customRetailer.getEmail());
616
			partner.setGstNumber(customRetailer.getGstNumber());
617
			partner.setDisplayName(customRetailer.getDisplayName());
618
			partner.setCity(customRetailer.getAddress().getCity());
619
			partner.setUserId(user.getId());
620
			partners.add(partner);
621
		}
622
		LOGGER.info("partners" + partners);
623
		return responseSender.ok(partners);
624
	}
625
 
25458 tejbeer 626
	@RequestMapping(value = "/user/refferal", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
627
	@ApiImplicitParams({
30546 tejbeer 628
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25458 tejbeer 629
	public ResponseEntity<?> RefferalUser(HttpServletRequest request,
30546 tejbeer 630
			@RequestBody CreateRefferalRequest createRefferalRequest) throws Exception {
25458 tejbeer 631
		Refferal refferal = new Refferal();
632
		refferal.setFirstName(createRefferalRequest.getFirstName());
633
		refferal.setLastName(createRefferalRequest.getLastName());
634
		refferal.setMobile(createRefferalRequest.getMobile());
635
		refferal.setState(createRefferalRequest.getState());
636
		refferal.setCity(createRefferalRequest.getCity());
637
		refferal.setCreatedTimestamp(LocalDateTime.now());
638
		refferal.setUpdatedTimestamp(LocalDateTime.now());
25496 tejbeer 639
		refferal.setStatus(RefferalStatus.pending);
25458 tejbeer 640
		if (createRefferalRequest.isFofoAssociate()) {
641
			AuthUser authUser = authRepository.selectByGmailId(createRefferalRequest.getReffereeEmail());
25483 tejbeer 642
			if (authUser == null) {
25458 tejbeer 643
				Promoter promoter = promoterRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
644
				refferal.setRefereeName(promoter.getName());
25483 tejbeer 645
				refferal.setRefereeEmail(promoter.getEmail());
25458 tejbeer 646
				refferal.setRefereeMobile(promoter.getMobile());
647
			} else {
648
				refferal.setRefereeName(authUser.getFirstName());
25483 tejbeer 649
				refferal.setRefereeEmail(authUser.getGmailId());
25458 tejbeer 650
				refferal.setRefereeMobile(authUser.getMobileNumber());
651
			}
652
		} else {
653
			User user = userRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
654
			refferal.setRefereeName(user.getFirstName());
25483 tejbeer 655
			refferal.setRefereeEmail(user.getEmailId());
25458 tejbeer 656
			refferal.setRefereeMobile(user.getMobileNumber());
657
		}
658
 
659
		refferalRepository.persist(refferal);
29892 tejbeer 660
 
661
		List<PartnerOnBoardingPanel> pobs = partnerOnBoardingPanelRepository
662
				.selectAllByPhoneNumber((Long.parseLong(refferal.getMobile())));
663
 
664
		if (!pobs.isEmpty()) {
665
 
666
			List<PartnerOnBoardingStatus> ponbStatus = pobs.stream().map(x -> x.getStatus())
667
					.collect(Collectors.toList());
668
 
669
			if (ponbStatus.contains(PartnerOnBoardingStatus.open)) {
670
				refferal.setStatus(RefferalStatus.rejected);
671
				refferal.setRejectedReason("This is already a Smartdukaan Partner.");
672
			} else if (ponbStatus.contains(PartnerOnBoardingStatus.pending)) {
673
				refferal.setStatus(RefferalStatus.rejected);
674
				refferal.setRejectedReason("This is already a Smartdukaan Partner.");
675
			} else {
676
				this.sendEmailToValidate(refferal);
677
			}
678
 
679
		} else {
680
 
681
			this.sendEmailToValidate(refferal);
682
 
683
		}
684
		return responseSender.ok(true);
685
	}
686
 
687
	private void sendEmailToValidate(Refferal refferal) throws MessagingException, UnsupportedEncodingException {
688
 
26792 tejbeer 689
		String subject = "Referral Validate Request for " + refferal.getRefereeEmail();
690
		String messageText = this.getMessageForReferral(refferal);
691
		MimeMessage message = mailSender.createMimeMessage();
692
		MimeMessageHelper helper = new MimeMessageHelper(message, true);
30546 tejbeer 693
		String[] email = { "kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "sm@smartdukaan.com" };
26792 tejbeer 694
		helper.setSubject(subject);
695
		helper.setText(messageText, true);
696
		helper.setTo(email);
697
		InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
698
		helper.setFrom(senderAddress);
699
		mailSender.send(message);
700
 
25458 tejbeer 701
	}
25488 tejbeer 702
 
26792 tejbeer 703
	private String getMessageForReferral(Refferal referral) {
704
 
705
		StringBuilder sb = new StringBuilder();
706
		sb.append("<html><body><p>Alert</p><p> Referral Requests:-</p>"
707
				+ "<br/><table style='border:1px solid black ;padding: 5px';>");
708
		sb.append("<tbody>\n" + "	    				<tr>\n"
709
				+ "	    					<th style='border:1px solid black;padding: 5px'>RefereeName</th>\n"
710
				+ "	    					<th style='border:1px solid black;padding: 5px'>Referee Email</th>\n"
711
				+ "	    					<th style='border:1px solid black;padding: 5px'>Referral Name</th>\n"
712
				+ "	    					<th style='border:1px solid black;padding: 5px'>Refferal Mobile</th>\n"
713
				+ "	    					<th style='border:1px solid black;padding: 5px'>city</th>\n"
714
				+ "	    					<th style='border:1px solid black;padding: 5px'>state</th>\n"
715
				+ "	    				</tr>");
716
 
717
		sb.append("<tr>");
718
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getRefereeName() + "</td>");
719
 
720
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getRefereeEmail() + "</td>");
721
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getFirstName() + "</td>");
722
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getMobile() + "</td>");
723
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getCity() + "</td>");
724
		sb.append("<td style='border:1px solid black;padding: 5px'>" + referral.getState() + "</td>");
725
 
726
		sb.append("</tr>");
727
 
728
		sb.append("</tbody></table></body></html>");
729
 
730
		return sb.toString();
731
	}
732
 
25488 tejbeer 733
	@RequestMapping(value = "/user/refferalAmount", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
734
	@ApiImplicitParams({
30546 tejbeer 735
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25488 tejbeer 736
	public ResponseEntity<?> RefferalAmount(HttpServletRequest request, @RequestParam String refereeEmail)
737
			throws Exception {
738
		LocalDateTime ldt = LocalDate.now().atStartOfDay().withDayOfMonth(16);
739
		DateRangeModel drm = new DateRangeModel();
740
		List<RefferalEarningModel> refferAmountModel = new ArrayList<RefferalEarningModel>();
741
		RefferalEarningModel rfm = new RefferalEarningModel();
742
		long currentMonthEstimaterefferal = 0;
743
		long currentMonthConfirmedrefferal = 0;
744
		if (LocalDateTime.now().isBefore(ldt)) {
745
			List<Refferal> allPendingRefferalBeforeCurrentMonth = refferalRepository
746
					.selectByEmailIdAndStatusAndbeforeCurrentMonth(refereeEmail, RefferalStatus.pending);
747
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
748
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(1));
749
 
750
			List<Refferal> previousMonthapprovedRefferalAfterSixteen = refferalRepository
751
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
752
			List<Refferal> previousMonthtransferredRefferalAfterSixteen = refferalRepository
753
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
754
 
755
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
756
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
757
 
758
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
759
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
760
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
761
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
762
			long pendingRefferalBeforeCurrentMonth = allPendingRefferalBeforeCurrentMonth.size();
763
			long previousapprovedRefferalAfterSixteen = previousMonthapprovedRefferalAfterSixteen.size();
764
			long previoustransferredRefferalAfterSixteen = previousMonthtransferredRefferalAfterSixteen.size();
765
			long previousapprovedRefferalbeforeSixteen = previousMonthapprovedRefferalbeforeSixteen.size();
766
			long previoustransferredRefferalbeforeSixteen = previousMonthtransferredRefferalbeforeSixteen.size();
767
			long previousMonthEstimateRefferal = pendingRefferalBeforeCurrentMonth
768
					+ previousapprovedRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen;
769
			long previousMonthConfirmedRefferal = previousapprovedRefferalAfterSixteen
770
					+ previoustransferredRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen
771
					+ previoustransferredRefferalbeforeSixteen;
25490 tejbeer 772
			rfm = refferAmountEarning(pendingRefferalBeforeCurrentMonth, previousMonthConfirmedRefferal,
25488 tejbeer 773
					YearMonth.now().minusMonths(1));
774
			refferAmountModel.add(rfm);
775
			LOGGER.info("previousMonthPendingApprovedRefferal" + previousMonthEstimateRefferal);
776
			LOGGER.info("previousMonthApprovedTransfferedRefferal" + previousMonthConfirmedRefferal);
777
 
25509 tejbeer 778
			List<Refferal> pendingofCurrentMonth = refferalRepository
779
					.selectByEmailIdAndStatusAndBetweenDates(refereeEmail, RefferalStatus.pending, YearMonth.now());
25488 tejbeer 780
			List<Refferal> approvedofCurrentMonth = refferalRepository.selectByEmailIdAndStatusAndDatesBetweenTimestamp(
781
					refereeEmail, RefferalStatus.approved, YearMonth.now());
782
			List<Refferal> transferredofCurrentMonth = refferalRepository
783
					.selectByEmailIdAndStatusAndDatesBetweenTimestamp(refereeEmail, RefferalStatus.transferred,
784
							YearMonth.now());
25490 tejbeer 785
			LOGGER.info("pendingofCurrentMonth" + pendingofCurrentMonth);
25509 tejbeer 786
			long pendingofCurrentMonthCount = pendingofCurrentMonth.size();
25488 tejbeer 787
			currentMonthEstimaterefferal = pendingofCurrentMonth.size() + approvedofCurrentMonth.size();
788
			currentMonthConfirmedrefferal = approvedofCurrentMonth.size() + transferredofCurrentMonth.size();
25509 tejbeer 789
 
25490 tejbeer 790
			rfm = refferAmountEarning(pendingofCurrentMonthCount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 791
 
792
			refferAmountModel.add(rfm);
793
 
794
		} else if (LocalDateTime.now().isAfter(ldt)) {
795
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
25496 tejbeer 796
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
25488 tejbeer 797
 
798
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
799
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
800
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
801
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
802
 
803
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
804
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
805
 
806
			List<Refferal> previousAndcurrentMonthapprovedRefferal = refferalRepository
807
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
808
 
809
			LocalDateTime currentMonthdate = LocalDateTime.now().withDayOfMonth(1);
810
 
811
			List<Refferal> preCurrMonthapproved = previousAndcurrentMonthapprovedRefferal.stream()
812
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
813
			List<Refferal> previousAndcurrentMonthtransferredRefferal = refferalRepository
814
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
815
			List<Refferal> preCurrMonthtransferred = previousAndcurrentMonthtransferredRefferal.stream()
816
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
817
 
818
			long approvedRefferal = previousMonthapprovedRefferalbeforeSixteen.size()
819
					+ previousMonthtransferredRefferalbeforeSixteen.size() + preCurrMonthapproved.size()
820
					+ preCurrMonthtransferred.size();
821
			rfm = new RefferalEarningModel();
29878 tejbeer 822
			rfm.setActualEarning(approvedRefferal * 5000);
27595 tejbeer 823
 
25488 tejbeer 824
			rfm.setYearMonth(YearMonth.now().minusMonths(1));
25490 tejbeer 825
			rfm.setPendingRefferal(0);
25509 tejbeer 826
			rfm.setApprovedRefferal(approvedRefferal);
25488 tejbeer 827
			refferAmountModel.add(rfm);
828
			List<Refferal> allpendingRefferal = refferalRepository.selectByEmailIdAndStatus(refereeEmail,
829
					RefferalStatus.pending);
830
			LOGGER.info("allpendingRefferal" + allpendingRefferal);
831
 
832
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(16));
833
			drm.setEndDate(LocalDateTime.now().plusMonths(1).withDayOfMonth(1));
834
 
835
			List<Refferal> currentMonthapprovedRefferalAfterSixteen = refferalRepository
836
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
837
			List<Refferal> currentMonthtransferredRefferalAfterSixteen = refferalRepository
838
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
839
			LOGGER.info("currentMonthapprovedRefferalAfterSixteen" + currentMonthapprovedRefferalAfterSixteen);
840
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(1));
841
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
842
 
843
			List<Refferal> currentMonthapprovedRefferalbeforeSixteen = refferalRepository
844
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
845
			List<Refferal> currentMonthtransferredRefferalbeforeSixteen = refferalRepository
846
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
847
			LOGGER.info("currentMonthapprovedRefferalbeforeSixteen" + currentMonthapprovedRefferalbeforeSixteen);
25509 tejbeer 848
			long pendingrefferalcount = allpendingRefferal.size();
25488 tejbeer 849
			currentMonthConfirmedrefferal = currentMonthapprovedRefferalAfterSixteen.size()
850
					+ currentMonthtransferredRefferalAfterSixteen.size()
851
					+ currentMonthapprovedRefferalbeforeSixteen.size()
852
					+ currentMonthtransferredRefferalbeforeSixteen.size();
25509 tejbeer 853
 
854
			rfm = refferAmountEarning(pendingrefferalcount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 855
			refferAmountModel.add(rfm);
856
			LOGGER.info("currentMonthpendingApprovedrefferal" + currentMonthEstimaterefferal);
857
 
858
			LOGGER.info("currentMonthapprovedTransferredrefferal" + currentMonthConfirmedrefferal);
859
 
860
		}
861
		RefferalEarning re = new RefferalEarning();
862
		re.setTimestamp(LocalDateTime.now());
863
		re.setRefferalEarningModel(refferAmountModel);
864
		return responseSender.ok(re);
865
	}
866
 
25490 tejbeer 867
	private RefferalEarningModel refferAmountEarning(long pendingRefferalValue, long confirmedRefferalValue,
30546 tejbeer 868
			YearMonth yearMonth) {
25488 tejbeer 869
		RefferalEarningModel rfm = new RefferalEarningModel();
870
		rfm.setYearMonth(yearMonth);
25490 tejbeer 871
		rfm.setPendingRefferal(pendingRefferalValue);
872
		rfm.setApprovedRefferal(confirmedRefferalValue);
25509 tejbeer 873
		long estimateRefferalValue = pendingRefferalValue + confirmedRefferalValue;
25488 tejbeer 874
 
29878 tejbeer 875
		rfm.setMaximumEarning(estimateRefferalValue * 5000);
27595 tejbeer 876
 
29878 tejbeer 877
		rfm.setMinimumEarning(confirmedRefferalValue * 5000);
27595 tejbeer 878
 
25488 tejbeer 879
		return rfm;
880
	}
25979 tejbeer 881
 
29890 tejbeer 882
	@RequestMapping(value = "/user/getReferals", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
883
	@ApiImplicitParams({
30546 tejbeer 884
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
29890 tejbeer 885
	public ResponseEntity<?> getReferals(HttpServletRequest request, @RequestParam RefferalStatus status)
886
			throws Exception {
887
		int userId = (int) request.getAttribute("userId");
888
 
889
		User user = userRepository.selectById(userId);
890
		UserCart uc = userAccountRepository.getUserCart(userId);
891
 
892
		List<Refferal> refferals = refferalRepository.selectByEmailIdAndStatus(user.getEmailId(), status);
893
		return responseSender.ok(refferals);
894
	}
895
 
25622 amit.gupta 896
	@RequestMapping(value = "/user/partnerTarget", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
897
	@ApiImplicitParams({
30546 tejbeer 898
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
25622 amit.gupta 899
	public ResponseEntity<?> PartnerTarget(HttpServletRequest request) throws Exception {
900
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
901
		int retailerId = userAccountRepository.selectRetailerIdByUserId(userId);
902
		PartnerType partnerType = partnerTypeChangeService.getTypeOnDate(retailerId, LocalDate.now());
25979 tejbeer 903
 
25622 amit.gupta 904
		return responseSender.ok(partnerType);
905
	}
26636 amit.gupta 906
 
27425 tejbeer 907
	@RequestMapping(value = "/user/authUser", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
908
	@ApiImplicitParams({
30546 tejbeer 909
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
27425 tejbeer 910
	public ResponseEntity<?> authUserDetail(HttpServletRequest request, @RequestParam int userId) throws Exception {
911
		User user = userRepository.selectById(userId);
912
		AuthUser authUser = authRepository.selectByEmailOrMobile(user.getEmailId());
913
		return responseSender.ok(authUser);
914
	}
915
 
21248 ashik.ali 916
}
26636 amit.gupta 917
 
918
class MobileAppSettingsWrapper {
919
	@JsonProperty(value = "Mobileappsetting")
920
	private MobileAppSetting mobileAppSettings;
921
 
922
	public MobileAppSettingsWrapper(MobileAppSetting mobileAppSettings) {
923
		super();
924
		this.mobileAppSettings = mobileAppSettings;
925
	}
26642 amit.gupta 926
 
927
	public MobileAppSetting getMobileAppSettings() {
928
		return mobileAppSettings;
929
	}
930
 
931
	public void setMobileAppSettings(MobileAppSetting mobileAppSettings) {
932
		this.mobileAppSettings = mobileAppSettings;
933
	}
26643 amit.gupta 934
 
935
	@Override
936
	public String toString() {
937
		return "MobileAppSettingsWrapper [mobileAppSettings=" + mobileAppSettings + "]";
938
	}
26644 amit.gupta 939
 
26636 amit.gupta 940
}
941
 
942
class SettingsWrapper {
943
	private List<MobileAppSettingsWrapper> settings;
26644 amit.gupta 944
 
26636 amit.gupta 945
	public SettingsWrapper(List<MobileAppSettingsWrapper> settings) {
946
		super();
947
		this.settings = settings;
948
	}
949
 
26642 amit.gupta 950
	@Override
951
	public String toString() {
952
		return "SettingsWrapper [settings=" + settings + "]";
953
	}
954
 
955
	public List<MobileAppSettingsWrapper> getSettings() {
956
		return settings;
957
	}
958
 
959
	public void setSettings(List<MobileAppSettingsWrapper> settings) {
960
		this.settings = settings;
961
	}
962
 
27425 tejbeer 963
}