Subversion Repositories SmartDukaan

Rev

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