Subversion Repositories SmartDukaan

Rev

Rev 25979 | Rev 26396 | 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
 
25300 tejbeer 3
import java.io.IOException;
25488 tejbeer 4
import java.time.LocalDate;
21248 ashik.ali 5
import java.time.LocalDateTime;
25488 tejbeer 6
import java.time.YearMonth;
21855 amit.gupta 7
import java.util.ArrayList;
25300 tejbeer 8
import java.util.Base64;
21428 amit.gupta 9
import java.util.HashMap;
23786 amit.gupta 10
import java.util.HashSet;
21855 amit.gupta 11
import java.util.List;
21277 ashik.ali 12
import java.util.Map;
23786 amit.gupta 13
import java.util.Set;
25488 tejbeer 14
import java.util.stream.Collectors;
21248 ashik.ali 15
 
16
import javax.servlet.http.HttpServletRequest;
17
 
25300 tejbeer 18
import org.apache.http.client.ClientProtocolException;
23786 amit.gupta 19
import org.apache.logging.log4j.LogManager;
23859 ashik.ali 20
import org.apache.logging.log4j.Logger;
21278 ashik.ali 21
import org.springframework.beans.factory.annotation.Autowired;
21414 kshitij.so 22
import org.springframework.beans.factory.annotation.Value;
25366 tejbeer 23
import org.springframework.http.MediaType;
21248 ashik.ali 24
import org.springframework.http.ResponseEntity;
25
import org.springframework.stereotype.Controller;
21702 ashik.ali 26
import org.springframework.transaction.annotation.Transactional;
21366 kshitij.so 27
import org.springframework.web.bind.annotation.RequestBody;
21248 ashik.ali 28
import org.springframework.web.bind.annotation.RequestMapping;
29
import org.springframework.web.bind.annotation.RequestMethod;
30
import org.springframework.web.bind.annotation.RequestParam;
31
 
32
import com.spice.profitmandi.common.ResponseCodeHolder;
33
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
25366 tejbeer 34
import com.spice.profitmandi.common.model.CustomRetailer;
22930 ashik.ali 35
import com.spice.profitmandi.common.model.GoogleLoginRequest;
21248 ashik.ali 36
import com.spice.profitmandi.common.model.ProfitMandiConstants;
22492 amit.gupta 37
import com.spice.profitmandi.common.model.RegisteredUserInfo;
21469 amit.gupta 38
import com.spice.profitmandi.common.model.UserInfo;
21282 ashik.ali 39
import com.spice.profitmandi.common.util.JWTUtil;
21855 amit.gupta 40
import com.spice.profitmandi.common.web.client.RestClient;
21740 ashik.ali 41
import com.spice.profitmandi.common.web.util.ResponseSender;
25366 tejbeer 42
import com.spice.profitmandi.dao.entity.auth.AuthUser;
21735 ashik.ali 43
import com.spice.profitmandi.dao.entity.dtr.Retailer;
23858 ashik.ali 44
import com.spice.profitmandi.dao.entity.dtr.Role;
21735 ashik.ali 45
import com.spice.profitmandi.dao.entity.dtr.User;
25366 tejbeer 46
import com.spice.profitmandi.dao.entity.dtr.UserAccount;
21735 ashik.ali 47
import com.spice.profitmandi.dao.entity.dtr.UserRole;
25622 amit.gupta 48
import com.spice.profitmandi.dao.entity.fofo.PartnerType;
22355 ashik.ali 49
import com.spice.profitmandi.dao.entity.user.Address;
25458 tejbeer 50
import com.spice.profitmandi.dao.entity.user.Promoter;
51
import com.spice.profitmandi.dao.entity.user.Refferal;
25488 tejbeer 52
import com.spice.profitmandi.dao.enumuration.dtr.RefferalStatus;
21735 ashik.ali 53
import com.spice.profitmandi.dao.enumuration.dtr.RoleType;
25979 tejbeer 54
import com.spice.profitmandi.dao.model.CreateRefferalRequest;
25488 tejbeer 55
import com.spice.profitmandi.dao.model.DateRangeModel;
21643 ashik.ali 56
import com.spice.profitmandi.dao.model.UserCart;
25366 tejbeer 57
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
25619 amit.gupta 58
import com.spice.profitmandi.dao.repository.cs.CsService;
25458 tejbeer 59
import com.spice.profitmandi.dao.repository.dtr.RefferalRepository;
21735 ashik.ali 60
import com.spice.profitmandi.dao.repository.dtr.RetailerRepository;
23786 amit.gupta 61
import com.spice.profitmandi.dao.repository.dtr.RoleRepository;
21735 ashik.ali 62
import com.spice.profitmandi.dao.repository.dtr.UserAccountRepository;
63
import com.spice.profitmandi.dao.repository.dtr.UserRepository;
64
import com.spice.profitmandi.dao.repository.dtr.UserRoleRepository;
25622 amit.gupta 65
import com.spice.profitmandi.dao.repository.fofo.PartnerTypeChangeService;
22355 ashik.ali 66
import com.spice.profitmandi.dao.repository.user.AddressRepository;
25458 tejbeer 67
import com.spice.profitmandi.dao.repository.user.PromoterRepository;
24491 amit.gupta 68
import com.spice.profitmandi.service.AuthService;
23798 amit.gupta 69
import com.spice.profitmandi.service.authentication.RoleManager;
25366 tejbeer 70
import com.spice.profitmandi.service.user.RetailerService;
23787 amit.gupta 71
import com.spice.profitmandi.service.user.UserService;
21469 amit.gupta 72
import com.spice.profitmandi.web.enumuration.UserStatus;
21277 ashik.ali 73
import com.spice.profitmandi.web.processor.GoogleLoginProcessor;
25979 tejbeer 74
 
25488 tejbeer 75
import com.spice.profitmandi.web.req.RefferalEarning;
76
import com.spice.profitmandi.web.req.RefferalEarningModel;
21366 kshitij.so 77
import com.spice.profitmandi.web.req.UserRequest;
25366 tejbeer 78
import com.spice.profitmandi.web.res.Partner;
21248 ashik.ali 79
 
21469 amit.gupta 80
import io.swagger.annotations.ApiImplicitParam;
81
import io.swagger.annotations.ApiImplicitParams;
82
 
21248 ashik.ali 83
/**
84
 * @author ashikali
85
 *
86
 */
87
@Controller
25366 tejbeer 88
@Transactional(rollbackFor = Throwable.class)
21248 ashik.ali 89
public class UserController {
21469 amit.gupta 90
 
21448 ashik.ali 91
	@Autowired
22930 ashik.ali 92
	private ResponseSender<?> responseSender;
21469 amit.gupta 93
 
23568 govind 94
	private static final Logger LOGGER = LogManager.getLogger(UserController.class);
21469 amit.gupta 95
 
21855 amit.gupta 96
	@Value("${notifications.api.host}")
97
	private String nodeHost;
25366 tejbeer 98
 
21855 amit.gupta 99
	@Value("${notifications.api.port}")
100
	private int nodePort;
101
 
21414 kshitij.so 102
	@Value("${admin.token}")
103
	private String validAdminToken;
21469 amit.gupta 104
 
21278 ashik.ali 105
	@Autowired
22873 ashik.ali 106
	private UserRepository userRepository;
25366 tejbeer 107
 
22355 ashik.ali 108
	@Autowired
22873 ashik.ali 109
	private com.spice.profitmandi.dao.repository.user.UserRepository userUserRepository;
21469 amit.gupta 110
 
21278 ashik.ali 111
	@Autowired
22873 ashik.ali 112
	private RetailerRepository retailerRepository;
21485 amit.gupta 113
 
114
	@Autowired
22873 ashik.ali 115
	private UserRoleRepository userRoleRepository;
21469 amit.gupta 116
 
21426 ashik.ali 117
	@Autowired
25622 amit.gupta 118
	private PartnerTypeChangeService partnerTypeChangeService;
119
 
120
	@Autowired
22873 ashik.ali 121
	private UserAccountRepository userAccountRepository;
25366 tejbeer 122
 
22355 ashik.ali 123
	@Autowired
24491 amit.gupta 124
	private AuthService authService;
25366 tejbeer 125
 
24491 amit.gupta 126
	@Autowired
22873 ashik.ali 127
	private AddressRepository addressRepository;
21469 amit.gupta 128
 
21426 ashik.ali 129
	@Autowired
22873 ashik.ali 130
	private GoogleLoginProcessor googleLoginProcessor;
21855 amit.gupta 131
 
21784 amit.gupta 132
	@Autowired
22873 ashik.ali 133
	private UserService userService;
25366 tejbeer 134
 
23786 amit.gupta 135
	@Autowired
25619 amit.gupta 136
	private CsService csService;
137
 
138
	@Autowired
23858 ashik.ali 139
	private RestClient restClient;
25366 tejbeer 140
 
23858 ashik.ali 141
	@Autowired
23798 amit.gupta 142
	private RoleManager roleManager;
25366 tejbeer 143
 
23786 amit.gupta 144
	@Autowired
145
	private RoleRepository roleRepository;
21469 amit.gupta 146
 
25366 tejbeer 147
	@Autowired
148
	private AuthRepository authRepository;
149
 
150
	@Autowired
151
	private RetailerService retailerService;
152
 
25458 tejbeer 153
	@Autowired
154
	private RefferalRepository refferalRepository;
155
 
156
	@Autowired
157
	private PromoterRepository promoterRepository;
158
 
21469 amit.gupta 159
	@RequestMapping(value = ProfitMandiConstants.URL_USER_GOOGLE_LOGIN, method = RequestMethod.POST)
25366 tejbeer 160
	public ResponseEntity<?> googleLogin(HttpServletRequest request, @RequestBody GoogleLoginRequest googleLoginRequest)
161
			throws ProfitMandiBusinessException {
23698 amit.gupta 162
		LOGGER.info("requested url : " + request.getRequestURL().toString());
24494 amit.gupta 163
		Map<String, Object> resultMap = googleLoginProcessor.process(googleLoginRequest);
164
		LOGGER.info("Response sent is {}", resultMap);
23698 amit.gupta 165
		return responseSender.ok(googleLoginProcessor.process(googleLoginRequest));
21277 ashik.ali 166
	}
21469 amit.gupta 167
 
168
	@RequestMapping(value = ProfitMandiConstants.URL_USER_TOKEN_IS_EXPIRED, method = RequestMethod.GET)
25366 tejbeer 169
	public ResponseEntity<?> tokenIsExpired(HttpServletRequest request, @RequestParam(name = "token") String token)
170
			throws ProfitMandiBusinessException {
21469 amit.gupta 171
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 172
		return responseSender.ok(JWTUtil.isExpired(token));
21282 ashik.ali 173
	}
21469 amit.gupta 174
 
22355 ashik.ali 175
	@RequestMapping(value = ProfitMandiConstants.URL_USER_DETAIL_BY_TOKEN, method = RequestMethod.GET)
21469 amit.gupta 176
	@ApiImplicitParams({
177
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
178
	public ResponseEntity<?> tokenInfo(HttpServletRequest request) throws Throwable {
179
		Map<String, Object> responseMap = new HashMap<>();
180
		UserInfo userInfo = (UserInfo) request.getAttribute("userInfo");
21483 amit.gupta 181
		User user = null;
21855 amit.gupta 182
		if (userInfo.getUserId() > -1) {
21483 amit.gupta 183
			user = userRepository.selectById(userInfo.getUserId());
25366 tejbeer 184
			if (!(userInfo.getEmail() == null || user.getEmailId().equalsIgnoreCase(userInfo.getEmail()))) {
24491 amit.gupta 185
				String userName = null;
25366 tejbeer 186
				if (user.getSecondryEmailId() != null && user.getSecondryEmailId().equals(userInfo.getEmail())) {
24491 amit.gupta 187
					userName = user.getFirstName() + " " + user.getLastName();
188
				} else {
189
					userName = authService.getNameByEmailId(userInfo.getEmail());
190
				}
191
				responseMap.put(ProfitMandiConstants.USER_ID, userInfo.getUserId());
192
				responseMap.put(ProfitMandiConstants.USER_NAME, userName);
193
				responseMap.put(ProfitMandiConstants.USER_STATUS, "fofoAssociate");
194
				responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
195
				return responseSender.ok(responseMap);
196
			}
21483 amit.gupta 197
		} else {
198
			try {
199
				user = userRepository.selectByEmailId(userInfo.getEmail());
200
			} catch (ProfitMandiBusinessException e1) {
201
			}
25366 tejbeer 202
			if (user == null) {
23204 ashik.ali 203
				try {
204
					user = userRepository.selectBySecondryEmailId(userInfo.getEmail());
205
				} catch (ProfitMandiBusinessException e1) {
206
					LOGGER.info("Uneregistered user", userInfo.getEmail());
207
				}
208
			}
21483 amit.gupta 209
		}
210
		if (user != null) {
23858 ashik.ali 211
			int retailerId = userAccountRepository.selectRetailerIdByUserId(user.getId());
21491 amit.gupta 212
			responseMap.put(ProfitMandiConstants.EMAIL_ID, user.getEmailId());
21526 amit.gupta 213
			responseMap.put(ProfitMandiConstants.USER_ID, user.getId());
22017 amit.gupta 214
			responseMap.put(ProfitMandiConstants.USER_NAME, user.getFirstName() + " " + user.getLastName());
23786 amit.gupta 215
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(user.getId());
25366 tejbeer 216
			// LOGGER.info("userRoles {} ", userRoles);
22032 ashik.ali 217
 
218
			// generate new token if roles have been updated
23786 amit.gupta 219
			if (userInfo.getRoleIds() == null || roleIds.size() != userInfo.getRoleIds().size()) {
23858 ashik.ali 220
				String[] roleIdStrings = new String[roleIds.size()];
22603 amit.gupta 221
				int index = 0;
23786 amit.gupta 222
				for (int roleId : roleIds) {
23858 ashik.ali 223
					roleIdStrings[index++] = String.valueOf(roleId);
22603 amit.gupta 224
				}
23858 ashik.ali 225
				String newToken = JWTUtil.create(user.getId(), retailerId, roleIdStrings);
21483 amit.gupta 226
				responseMap.put("newAuthToken", newToken);
227
			}
23858 ashik.ali 228
			// if user is retailer
23786 amit.gupta 229
			Set<Integer> roleIdsSet = new HashSet<Integer>(roleIds);
23858 ashik.ali 230
			if (roleManager.isRetailer(roleIdsSet)) {
22032 ashik.ali 231
				UserCart uc = userAccountRepository.getUserCart(userInfo.getUserId());
232
				Retailer retailer = retailerRepository.selectById(uc.getUserId());
22370 amit.gupta 233
				com.spice.profitmandi.dao.entity.user.User saholicUser = userUserRepository.selectById(uc.getUserId());
25366 tejbeer 234
				if (saholicUser.getAddressId() != null) {
22370 amit.gupta 235
					Address address = addressRepository.selectById(saholicUser.getAddressId());
236
					responseMap.put(ProfitMandiConstants.ADDRESS, address);
237
				}
21485 amit.gupta 238
				// if retailer is activated 1 then verified retailer
239
				// else if migrated is 1 then old retailer
25366 tejbeer 240
				// also lets incoporte old process i.e is user is activated then also retailer
241
				// is verified retailer
21485 amit.gupta 242
				// else retailer is not verifed
22497 amit.gupta 243
				if (retailer.isActive() || user.isActivated()) {
23798 amit.gupta 244
					if (roleManager.isPartner(roleIdsSet)) {
22017 amit.gupta 245
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.FOFO.getValue());
246
					} else {
247
						responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.VERIFIED_RETAILER.getValue());
248
					}
22032 ashik.ali 249
				} else if (retailer.isMigrated()) {
21485 amit.gupta 250
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.RETAILER.getValue());
21469 amit.gupta 251
				} else {
21485 amit.gupta 252
					responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_VERIFIED_RETAILER.getValue());
21469 amit.gupta 253
				}
23798 amit.gupta 254
			} else if (roleManager.isUser(roleIdsSet)) {
22502 amit.gupta 255
				responseMap.put("userInfo", getRegisteredUserInfo(user));
21469 amit.gupta 256
				responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.REGISTERED.getValue());
22032 ashik.ali 257
			}
21491 amit.gupta 258
		} else {
259
			responseMap.put(ProfitMandiConstants.USER_STATUS, UserStatus.NOT_REGISTERED.getValue());
260
			responseMap.put(ProfitMandiConstants.EMAIL_ID, userInfo.getEmail());
21469 amit.gupta 261
		}
22032 ashik.ali 262
 
21469 amit.gupta 263
		return responseSender.ok(responseMap);
264
	}
25366 tejbeer 265
 
22502 amit.gupta 266
	private RegisteredUserInfo getRegisteredUserInfo(User user) throws Throwable {
22492 amit.gupta 267
		RegisteredUserInfo ri = new RegisteredUserInfo();
268
		ri.setCity(user.getCity());
269
		ri.setFirstName(user.getFirstName());
270
		ri.setLastName(user.getLastName());
22493 amit.gupta 271
		ri.setPhone(user.getMobileNumber());
22492 amit.gupta 272
		ri.setPinCode(user.getPinCode());
22845 amit.gupta 273
		ri.setState(user.getState());
22492 amit.gupta 274
		return ri;
275
	}
21469 amit.gupta 276
 
277
	@RequestMapping(value = ProfitMandiConstants.URL_USER, method = RequestMethod.POST)
21501 amit.gupta 278
	@ApiImplicitParams({
22032 ashik.ali 279
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
280
	public ResponseEntity<?> createUser(HttpServletRequest request, @RequestBody UserRequest userRequest)
22930 ashik.ali 281
			throws ProfitMandiBusinessException {
21469 amit.gupta 282
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21368 kshitij.so 283
		User user = new User();
284
		user.setFirstName(userRequest.getFirstName());
285
		user.setLastName(userRequest.getLastName());
286
		user.setCity(userRequest.getCity());
287
		user.setPinCode(Integer.valueOf(userRequest.getPinCode()));
22845 amit.gupta 288
		user.setState(userRequest.getState());
21708 amit.gupta 289
		user.setMobileNumber(userRequest.getMobieNumber());
21368 kshitij.so 290
		user.setEmailId(userRequest.getEmailId());
291
		user.setUsername("");
292
		user.setPassword("");
293
		user.setMobile_verified(false);
294
		user.setReferral_url("");
295
		user.setGroup_id(1);
22504 amit.gupta 296
		user.setStatus(1);
21368 kshitij.so 297
		user.setActivated(false);
21501 amit.gupta 298
		user.setCreateTimestamp(LocalDateTime.now());
299
		user.setUpdateTimestamp(LocalDateTime.now());
22930 ashik.ali 300
		userRepository.persist(user);
23858 ashik.ali 301
		Role role = roleRepository.selectByName(RoleType.USER.toString());
22930 ashik.ali 302
		UserRole userRole = new UserRole();
23858 ashik.ali 303
		userRole.setRoleId(role.getId());
22930 ashik.ali 304
		userRole.setUserId(user.getId());
305
		userRoleRepository.persist(userRole);
306
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1000"));
25366 tejbeer 307
 
21278 ashik.ali 308
	}
21469 amit.gupta 309
 
310
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ID, method = RequestMethod.GET)
25366 tejbeer 311
	public ResponseEntity<?> getById(HttpServletRequest request, @RequestParam(name = "id") int id)
312
			throws ProfitMandiBusinessException {
21469 amit.gupta 313
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 314
		return responseSender.ok(userRepository.selectById(id));
21248 ashik.ali 315
	}
21469 amit.gupta 316
 
317
	@RequestMapping(value = ProfitMandiConstants.URL_USER_MOBILE_NUMBER, method = RequestMethod.GET)
318
	public ResponseEntity<?> getByMobileNumber(HttpServletRequest request,
25366 tejbeer 319
			@RequestParam(name = "mobileNumber") String mobileNumber) throws ProfitMandiBusinessException {
21469 amit.gupta 320
		LOGGER.info("requested url : " + request.getRequestURL().toString());
22930 ashik.ali 321
		return responseSender.ok(userRepository.selectByMobileNumber(mobileNumber));
21248 ashik.ali 322
	}
21469 amit.gupta 323
 
21784 amit.gupta 324
	@ApiImplicitParams({
21501 amit.gupta 325
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
326
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ACTIVATE, method = RequestMethod.POST)
327
	public ResponseEntity<?> activateUser(HttpServletRequest request,
21784 amit.gupta 328
			@RequestParam(name = "activationCode") String activationCode) throws Throwable {
21855 amit.gupta 329
		int userId = (int) request.getAttribute("userId");
21784 amit.gupta 330
		UserCart uc = userAccountRepository.getUserCart(userId);
331
		return responseSender.ok(userService.updateActivation(userId, uc.getUserId(), activationCode));
332
	}
21855 amit.gupta 333
 
25458 tejbeer 334
	/*
335
	 * @ApiImplicitParams({
336
	 * 
337
	 * @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true,
338
	 * dataType = "string", paramType = "header") })
339
	 * 
340
	 * @RequestMapping(value = ProfitMandiConstants.URL_USER_NOTIFICATIONS, method =
341
	 * RequestMethod.GET) public ResponseEntity<?>
342
	 * getNofitications(HttpServletRequest request,
343
	 * 
344
	 * @RequestParam(name = "androidId") String androidId, @RequestParam(name =
345
	 * "pageNumber") int pageNumber,
346
	 * 
347
	 * @RequestParam(name = "pageSize") int pageSize) throws
348
	 * ProfitMandiBusinessException { int userId = (int)
349
	 * request.getAttribute("userId"); String restResponse = null; Map<String,
350
	 * String> params = new HashMap<>();
351
	 * 
352
	 * String uri = "/getAllNotifications"; params.put("user_id", userId + "");
353
	 * params.put("android_id", androidId); params.put("limit", pageSize + "");
354
	 * params.put("offset", "" + ((pageNumber - 1) * pageSize)); try { restResponse
355
	 * = restClient.get(SchemeType.HTTP, nodeHost, nodePort, uri, params); } catch
356
	 * (HttpHostConnectException e) { throw new ProfitMandiBusinessException("", "",
357
	 * "Could not Connect to host"); }
358
	 * 
359
	 * JsonArray result_json = Json.parse(restResponse).asArray();
360
	 * 
361
	 * List<Notification> notifications = new ArrayList<>();
362
	 * 
363
	 * for (JsonValue j : result_json) {
364
	 * notifications.add(toNotifiaction(j.asObject())); }
365
	 * 
366
	 * return responseSender.ok(notifications); }
367
	 * 
368
	 * private Notification toNotifiaction(JsonObject jsonObject) { Notification n =
369
	 * (Notification) (new Gson().fromJson(jsonObject.toString(),
370
	 * Notification.class)); if (n.getStatus().equals("opened") ||
371
	 * n.getStatus().equals("referrer") || n.getStatus().equals("seen")) {
372
	 * n.setSeen(true); } return n; }
373
	 */
21855 amit.gupta 374
 
21426 ashik.ali 375
	@RequestMapping(value = ProfitMandiConstants.URL_USER_IS_EXIST_MOBILE_NUMBER, method = RequestMethod.GET)
21469 amit.gupta 376
	public ResponseEntity<?> isMobileNumberExist(HttpServletRequest request,
377
			@RequestParam(name = "mobileNumber") String mobileNumber) {
378
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 379
		return responseSender.ok(userRepository.isExistByMobileNumber(mobileNumber));
21426 ashik.ali 380
	}
21469 amit.gupta 381
 
382
	@RequestMapping(value = ProfitMandiConstants.URL_USER_EMAIL_ID, method = RequestMethod.GET)
25366 tejbeer 383
	public ResponseEntity<?> getByEmailId(HttpServletRequest request, @RequestParam(name = "emailId") String emailId)
384
			throws ProfitMandiBusinessException {
21469 amit.gupta 385
		LOGGER.info("requested url : " + request.getRequestURL().toString());
23204 ashik.ali 386
		User user = null;
25366 tejbeer 387
		try {
23204 ashik.ali 388
			user = userRepository.selectByEmailId(emailId);
25366 tejbeer 389
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
23204 ashik.ali 390
			user = userRepository.selectBySecondryEmailId(emailId);
391
		}
392
		return responseSender.ok(user);
21248 ashik.ali 393
	}
21469 amit.gupta 394
 
395
	@RequestMapping(value = ProfitMandiConstants.URL_USER_ROLE_ALL, method = RequestMethod.GET)
396
	public ResponseEntity<?> getAllRoles(HttpServletRequest request, @RequestParam(name = "id") int id) {
397
		LOGGER.info("requested url : " + request.getRequestURL().toString());
21448 ashik.ali 398
		return responseSender.ok(userRoleRepository.selectRolesByUserId(id));
21248 ashik.ali 399
	}
25366 tejbeer 400
 
23204 ashik.ali 401
	@ApiImplicitParams({
25366 tejbeer 402
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
23204 ashik.ali 403
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID_AND_FOFO_STORE_CODE, method = RequestMethod.GET)
25366 tejbeer 404
	public ResponseEntity<?> getSecondryEmailAndStoreCode(HttpServletRequest request)
405
			throws ProfitMandiBusinessException {
23204 ashik.ali 406
		LOGGER.info("requested url : " + request.getRequestURL().toString());
407
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
408
		return responseSender.ok(userService.getEmailsAndFofoStoreCodeByUserId(userId));
409
	}
25366 tejbeer 410
 
23204 ashik.ali 411
	@ApiImplicitParams({
25366 tejbeer 412
			@ApiImplicitParam(name = "Auth-Token", value = "-Token", required = true, dataType = "string", paramType = "header") })
23858 ashik.ali 413
	@RequestMapping(value = ProfitMandiConstants.URL_USER_SECONDRY_EMAIL_ID, method = RequestMethod.PUT)
23204 ashik.ali 414
	public ResponseEntity<?> updateSecondryEmailId(HttpServletRequest request,
25366 tejbeer 415
			@RequestParam(name = ProfitMandiConstants.SECONDRY_EMAIL_ID) String secondryEmailId) throws Throwable {
416
		int userId = (int) request.getAttribute("userId");
417
		User user = userRepository.selectById(userId);
418
		user.setSecondryEmailId(secondryEmailId);
419
		userRepository.persist(user);
420
		return responseSender.ok(ResponseCodeHolder.getMessage("USR_OK_1001"));
421
	}
21414 kshitij.so 422
 
423
	@RequestMapping(value = ProfitMandiConstants.URL_ADMIN_TOKEN, method = RequestMethod.POST)
21469 amit.gupta 424
	public ResponseEntity<?> getAdminToken(HttpServletRequest request,
425
			@RequestParam(name = "adminToken") String adminToken, @RequestParam(name = "emailId") String emailId) {
426
		LOGGER.info("requested url : " + request.getRequestURL().toString());
427
		if (!adminToken.equals(validAdminToken)) {
22930 ashik.ali 428
			return responseSender.forbidden(null);
21414 kshitij.so 429
		}
21469 amit.gupta 430
 
21414 kshitij.so 431
		Map<String, Object> responseMap = new HashMap<>(2);
23204 ashik.ali 432
		User user = null;
21469 amit.gupta 433
		try {
23204 ashik.ali 434
			user = userRepository.selectByEmailId(emailId);
435
		} catch (ProfitMandiBusinessException profitMandiBusinessException) {
25366 tejbeer 436
 
23204 ashik.ali 437
		}
25366 tejbeer 438
 
439
		if (user == null) {
440
			try {
23204 ashik.ali 441
				user = userRepository.selectBySecondryEmailId(emailId);
25366 tejbeer 442
			} catch (ProfitMandiBusinessException profitMandiBusinessException) {
443
 
23204 ashik.ali 444
			}
445
		}
25366 tejbeer 446
		if (user != null) {
23858 ashik.ali 447
			int retailerId = 0;
448
			try {
449
				retailerId = userAccountRepository.selectRetailerIdByUserId(user.getId());
450
			} catch (ProfitMandiBusinessException e) {
451
				// TODO Auto-generated catch block
452
				e.printStackTrace();
453
			}
454
			List<Integer> roleIds = userRoleRepository.selectRoleIdsByUserId(user.getId());
455
			String[] roleIdsString = new String[roleIds.size()];
21414 kshitij.so 456
			int index = 0;
23858 ashik.ali 457
			for (int roleId : roleIds) {
458
				roleIdsString[index++] = String.valueOf(roleId);
21414 kshitij.so 459
			}
23858 ashik.ali 460
			responseMap.put(ProfitMandiConstants.TOKEN, JWTUtil.create(user.getId(), retailerId, roleIdsString));
21414 kshitij.so 461
			responseMap.put(ProfitMandiConstants.REGISTERED, true);
25366 tejbeer 462
		} else {
21469 amit.gupta 463
			responseMap.put(ProfitMandiConstants.TOKEN, JWTUtil.create(emailId));
21414 kshitij.so 464
			responseMap.put(ProfitMandiConstants.REGISTERED, false);
465
		}
21448 ashik.ali 466
		return responseSender.ok(responseMap);
21469 amit.gupta 467
 
21414 kshitij.so 468
	}
25366 tejbeer 469
 
25300 tejbeer 470
	@RequestMapping(value = "/mobileappsettings", method = RequestMethod.POST)
25366 tejbeer 471
	public ResponseEntity<?> mobileAppSettings(HttpServletRequest request, @RequestParam(name = "t") int timestamp,
472
			@RequestParam(name = "imeinumber") String imeinumber)
473
			throws ProfitMandiBusinessException, ClientProtocolException, IOException {
474
 
26203 amit.gupta 475
		final String uri = "http://192.168.158.89/mobileappsettings?t=" + timestamp + "&imeinumber=" + imeinumber;
25300 tejbeer 476
		final String BASIC_AUTH = "Basic " + Base64.getEncoder().encodeToString("dtr:dtr18Feb2015".getBytes());
477
		Map<String, String> headers = new HashMap<>();
478
		Map<String, String> params = new HashMap<>();
479
		headers.put("Authorization", BASIC_AUTH);
480
		return responseSender.ok(restClient.post(uri, params, headers));
481
	}
22032 ashik.ali 482
 
25366 tejbeer 483
	@RequestMapping(value = "/getPartners", method = RequestMethod.GET)
484
	@ApiImplicitParams({
485
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
486
	public ResponseEntity<?> getPartners(HttpServletRequest request, @RequestParam(name = "gmailId") String gmailId,
487
			@RequestParam(value = "offset") int offset, @RequestParam(value = "limit") int limit)
488
			throws ProfitMandiBusinessException {
489
		AuthUser authUser = authRepository.selectByGmailId(gmailId);
490
 
25619 amit.gupta 491
		Map<String, Set<String>> storeGuyMap = csService.getAuthUserPartnerEmailMapping();
25366 tejbeer 492
 
25619 amit.gupta 493
		Set<String> emails = storeGuyMap.get(authUser.getEmailId().toLowerCase());
25366 tejbeer 494
		LOGGER.info("emails" + emails);
25619 amit.gupta 495
		List<User> users = userRepository.selectAllByEmails(new ArrayList<>(emails), offset, limit);
25366 tejbeer 496
		List<Partner> partners = new ArrayList<>();
497
		for (User user : users) {
25458 tejbeer 498
 
25366 tejbeer 499
			UserAccount uc = userAccountRepository.selectSaholicByUserId(user.getId());
25458 tejbeer 500
			com.spice.profitmandi.dao.entity.user.User userInfo = userUserRepository.selectById(uc.getAccountKey());
25366 tejbeer 501
			CustomRetailer customRetailer = retailerService.getFofoRetailer(userInfo.getId());
502
 
503
			Partner partner = new Partner();
504
			partner.setBusinessName(customRetailer.getBusinessName());
505
			partner.setPartnerId(customRetailer.getPartnerId());
506
			partner.setCartId(customRetailer.getCartId());
507
			partner.setEmail(customRetailer.getEmail());
508
			partner.setGstNumber(customRetailer.getGstNumber());
509
			partner.setDisplayName(customRetailer.getDisplayName());
510
			partner.setCity(customRetailer.getAddress().getCity());
511
			partner.setUserId(user.getId());
512
			partners.add(partner);
513
		}
514
		LOGGER.info("partners" + partners);
515
		return responseSender.ok(partners);
516
	}
517
 
25458 tejbeer 518
	@RequestMapping(value = "/user/refferal", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
519
	@ApiImplicitParams({
520
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
521
	public ResponseEntity<?> RefferalUser(HttpServletRequest request,
522
			@RequestBody CreateRefferalRequest createRefferalRequest) throws Exception {
523
		Refferal refferal = new Refferal();
524
		refferal.setFirstName(createRefferalRequest.getFirstName());
525
		refferal.setLastName(createRefferalRequest.getLastName());
526
		refferal.setMobile(createRefferalRequest.getMobile());
527
		refferal.setState(createRefferalRequest.getState());
528
		refferal.setCity(createRefferalRequest.getCity());
529
		refferal.setCreatedTimestamp(LocalDateTime.now());
530
		refferal.setUpdatedTimestamp(LocalDateTime.now());
25496 tejbeer 531
		refferal.setStatus(RefferalStatus.pending);
25458 tejbeer 532
		if (createRefferalRequest.isFofoAssociate()) {
533
			AuthUser authUser = authRepository.selectByGmailId(createRefferalRequest.getReffereeEmail());
25483 tejbeer 534
			if (authUser == null) {
25458 tejbeer 535
				Promoter promoter = promoterRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
536
				refferal.setRefereeName(promoter.getName());
25483 tejbeer 537
				refferal.setRefereeEmail(promoter.getEmail());
25458 tejbeer 538
				refferal.setRefereeMobile(promoter.getMobile());
539
			} else {
540
				refferal.setRefereeName(authUser.getFirstName());
25483 tejbeer 541
				refferal.setRefereeEmail(authUser.getGmailId());
25458 tejbeer 542
				refferal.setRefereeMobile(authUser.getMobileNumber());
543
			}
544
		} else {
545
			User user = userRepository.selectByEmailId(createRefferalRequest.getReffereeEmail());
546
			refferal.setRefereeName(user.getFirstName());
25483 tejbeer 547
			refferal.setRefereeEmail(user.getEmailId());
25458 tejbeer 548
			refferal.setRefereeMobile(user.getMobileNumber());
549
		}
550
 
551
		refferalRepository.persist(refferal);
552
		return responseSender.ok(true);
553
	}
25488 tejbeer 554
 
555
	@RequestMapping(value = "/user/refferalAmount", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
556
	@ApiImplicitParams({
557
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
558
	public ResponseEntity<?> RefferalAmount(HttpServletRequest request, @RequestParam String refereeEmail)
559
			throws Exception {
560
		LocalDateTime ldt = LocalDate.now().atStartOfDay().withDayOfMonth(16);
561
		DateRangeModel drm = new DateRangeModel();
562
		List<RefferalEarningModel> refferAmountModel = new ArrayList<RefferalEarningModel>();
563
		RefferalEarningModel rfm = new RefferalEarningModel();
564
		long currentMonthEstimaterefferal = 0;
565
		long currentMonthConfirmedrefferal = 0;
566
		if (LocalDateTime.now().isBefore(ldt)) {
567
			List<Refferal> allPendingRefferalBeforeCurrentMonth = refferalRepository
568
					.selectByEmailIdAndStatusAndbeforeCurrentMonth(refereeEmail, RefferalStatus.pending);
569
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
570
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(1));
571
 
572
			List<Refferal> previousMonthapprovedRefferalAfterSixteen = refferalRepository
573
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
574
			List<Refferal> previousMonthtransferredRefferalAfterSixteen = refferalRepository
575
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
576
 
577
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
578
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
579
 
580
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
581
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
582
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
583
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
584
			long pendingRefferalBeforeCurrentMonth = allPendingRefferalBeforeCurrentMonth.size();
585
			long previousapprovedRefferalAfterSixteen = previousMonthapprovedRefferalAfterSixteen.size();
586
			long previoustransferredRefferalAfterSixteen = previousMonthtransferredRefferalAfterSixteen.size();
587
			long previousapprovedRefferalbeforeSixteen = previousMonthapprovedRefferalbeforeSixteen.size();
588
			long previoustransferredRefferalbeforeSixteen = previousMonthtransferredRefferalbeforeSixteen.size();
589
			long previousMonthEstimateRefferal = pendingRefferalBeforeCurrentMonth
590
					+ previousapprovedRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen;
591
			long previousMonthConfirmedRefferal = previousapprovedRefferalAfterSixteen
592
					+ previoustransferredRefferalAfterSixteen + previousapprovedRefferalbeforeSixteen
593
					+ previoustransferredRefferalbeforeSixteen;
25490 tejbeer 594
			rfm = refferAmountEarning(pendingRefferalBeforeCurrentMonth, previousMonthConfirmedRefferal,
25488 tejbeer 595
					YearMonth.now().minusMonths(1));
596
			refferAmountModel.add(rfm);
597
			LOGGER.info("previousMonthPendingApprovedRefferal" + previousMonthEstimateRefferal);
598
			LOGGER.info("previousMonthApprovedTransfferedRefferal" + previousMonthConfirmedRefferal);
599
 
25509 tejbeer 600
			List<Refferal> pendingofCurrentMonth = refferalRepository
601
					.selectByEmailIdAndStatusAndBetweenDates(refereeEmail, RefferalStatus.pending, YearMonth.now());
25488 tejbeer 602
			List<Refferal> approvedofCurrentMonth = refferalRepository.selectByEmailIdAndStatusAndDatesBetweenTimestamp(
603
					refereeEmail, RefferalStatus.approved, YearMonth.now());
604
			List<Refferal> transferredofCurrentMonth = refferalRepository
605
					.selectByEmailIdAndStatusAndDatesBetweenTimestamp(refereeEmail, RefferalStatus.transferred,
606
							YearMonth.now());
25490 tejbeer 607
			LOGGER.info("pendingofCurrentMonth" + pendingofCurrentMonth);
25509 tejbeer 608
			long pendingofCurrentMonthCount = pendingofCurrentMonth.size();
25488 tejbeer 609
			currentMonthEstimaterefferal = pendingofCurrentMonth.size() + approvedofCurrentMonth.size();
610
			currentMonthConfirmedrefferal = approvedofCurrentMonth.size() + transferredofCurrentMonth.size();
25509 tejbeer 611
 
25490 tejbeer 612
			rfm = refferAmountEarning(pendingofCurrentMonthCount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 613
 
614
			refferAmountModel.add(rfm);
615
 
616
		} else if (LocalDateTime.now().isAfter(ldt)) {
617
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(1));
25496 tejbeer 618
			drm.setEndDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
25488 tejbeer 619
 
620
			List<Refferal> previousMonthapprovedRefferalbeforeSixteen = refferalRepository
621
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
622
			List<Refferal> previousMonthtransferredRefferalbeforeSixteen = refferalRepository
623
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
624
 
625
			drm.setStartDate(LocalDateTime.now().minusMonths(1).withDayOfMonth(16));
626
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
627
 
628
			List<Refferal> previousAndcurrentMonthapprovedRefferal = refferalRepository
629
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
630
 
631
			LocalDateTime currentMonthdate = LocalDateTime.now().withDayOfMonth(1);
632
 
633
			List<Refferal> preCurrMonthapproved = previousAndcurrentMonthapprovedRefferal.stream()
634
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
635
			List<Refferal> previousAndcurrentMonthtransferredRefferal = refferalRepository
636
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
637
			List<Refferal> preCurrMonthtransferred = previousAndcurrentMonthtransferredRefferal.stream()
638
					.filter(x -> x.getCreatedTimestamp().isBefore(currentMonthdate)).collect(Collectors.toList());
639
 
640
			long approvedRefferal = previousMonthapprovedRefferalbeforeSixteen.size()
641
					+ previousMonthtransferredRefferalbeforeSixteen.size() + preCurrMonthapproved.size()
642
					+ preCurrMonthtransferred.size();
643
			rfm = new RefferalEarningModel();
644
			if (approvedRefferal <= 4) {
645
				rfm.setActualEarning(approvedRefferal * 5000);
646
			} else if (approvedRefferal >= 5 && approvedRefferal <= 9) {
647
				rfm.setActualEarning(approvedRefferal * 10000);
648
			} else if (approvedRefferal > 10) {
649
				rfm.setActualEarning(approvedRefferal * 200000);
650
			}
651
			rfm.setYearMonth(YearMonth.now().minusMonths(1));
25490 tejbeer 652
			rfm.setPendingRefferal(0);
25509 tejbeer 653
			rfm.setApprovedRefferal(approvedRefferal);
25488 tejbeer 654
			refferAmountModel.add(rfm);
655
			List<Refferal> allpendingRefferal = refferalRepository.selectByEmailIdAndStatus(refereeEmail,
656
					RefferalStatus.pending);
657
			LOGGER.info("allpendingRefferal" + allpendingRefferal);
658
 
659
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(16));
660
			drm.setEndDate(LocalDateTime.now().plusMonths(1).withDayOfMonth(1));
661
 
662
			List<Refferal> currentMonthapprovedRefferalAfterSixteen = refferalRepository
663
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.approved, drm);
664
			List<Refferal> currentMonthtransferredRefferalAfterSixteen = refferalRepository
665
					.selectByEmailIdAndStatusAndDateRange(refereeEmail, RefferalStatus.transferred, drm);
666
			LOGGER.info("currentMonthapprovedRefferalAfterSixteen" + currentMonthapprovedRefferalAfterSixteen);
667
			drm.setStartDate(LocalDateTime.now().withDayOfMonth(1));
668
			drm.setEndDate(LocalDateTime.now().withDayOfMonth(16));
669
 
670
			List<Refferal> currentMonthapprovedRefferalbeforeSixteen = refferalRepository
671
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.approved, drm);
672
			List<Refferal> currentMonthtransferredRefferalbeforeSixteen = refferalRepository
673
					.selectByEmailIdAndStatusAndDateRanges(refereeEmail, RefferalStatus.transferred, drm);
674
			LOGGER.info("currentMonthapprovedRefferalbeforeSixteen" + currentMonthapprovedRefferalbeforeSixteen);
25509 tejbeer 675
			long pendingrefferalcount = allpendingRefferal.size();
25488 tejbeer 676
			currentMonthConfirmedrefferal = currentMonthapprovedRefferalAfterSixteen.size()
677
					+ currentMonthtransferredRefferalAfterSixteen.size()
678
					+ currentMonthapprovedRefferalbeforeSixteen.size()
679
					+ currentMonthtransferredRefferalbeforeSixteen.size();
25509 tejbeer 680
 
681
			rfm = refferAmountEarning(pendingrefferalcount, currentMonthConfirmedrefferal, YearMonth.now());
25488 tejbeer 682
			refferAmountModel.add(rfm);
683
			LOGGER.info("currentMonthpendingApprovedrefferal" + currentMonthEstimaterefferal);
684
 
685
			LOGGER.info("currentMonthapprovedTransferredrefferal" + currentMonthConfirmedrefferal);
686
 
687
		}
688
		RefferalEarning re = new RefferalEarning();
689
		re.setTimestamp(LocalDateTime.now());
690
		re.setRefferalEarningModel(refferAmountModel);
691
		return responseSender.ok(re);
692
	}
693
 
25490 tejbeer 694
	private RefferalEarningModel refferAmountEarning(long pendingRefferalValue, long confirmedRefferalValue,
25488 tejbeer 695
			YearMonth yearMonth) {
696
		RefferalEarningModel rfm = new RefferalEarningModel();
697
		rfm.setYearMonth(yearMonth);
25490 tejbeer 698
		rfm.setPendingRefferal(pendingRefferalValue);
699
		rfm.setApprovedRefferal(confirmedRefferalValue);
25509 tejbeer 700
		long estimateRefferalValue = pendingRefferalValue + confirmedRefferalValue;
25488 tejbeer 701
		if (estimateRefferalValue <= 4) {
702
			rfm.setMaximumEarning(estimateRefferalValue * 5000);
703
		} else if (estimateRefferalValue >= 5 && estimateRefferalValue <= 9) {
704
			rfm.setMaximumEarning(estimateRefferalValue * 10000);
25640 tejbeer 705
		} else if (estimateRefferalValue >= 10) {
25488 tejbeer 706
			rfm.setMaximumEarning(200000);
707
		}
708
 
709
		if (confirmedRefferalValue <= 4) {
710
			rfm.setMinimumEarning(confirmedRefferalValue * 5000);
711
		} else if (confirmedRefferalValue >= 5 && confirmedRefferalValue <= 9) {
712
			rfm.setMinimumEarning(confirmedRefferalValue * 10000);
25640 tejbeer 713
		} else if (confirmedRefferalValue >= 10) {
25488 tejbeer 714
			rfm.setMinimumEarning(200000);
715
		}
716
		return rfm;
717
	}
25979 tejbeer 718
 
25622 amit.gupta 719
	@RequestMapping(value = "/user/partnerTarget", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
720
	@ApiImplicitParams({
721
			@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header") })
722
	public ResponseEntity<?> PartnerTarget(HttpServletRequest request) throws Exception {
723
		int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
724
		int retailerId = userAccountRepository.selectRetailerIdByUserId(userId);
725
		PartnerType partnerType = partnerTypeChangeService.getTypeOnDate(retailerId, LocalDate.now());
25979 tejbeer 726
 
25622 amit.gupta 727
		return responseSender.ok(partnerType);
728
	}
25488 tejbeer 729
 
21248 ashik.ali 730
}