Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21292 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
22495 amit.gupta 3
import java.util.Date;
21448 ashik.ali 4
import java.util.Set;
5
 
21292 ashik.ali 6
import javax.servlet.http.HttpServletRequest;
7
 
8
import org.slf4j.Logger;
9
import org.slf4j.LoggerFactory;
10
import org.springframework.beans.factory.annotation.Autowired;
22355 ashik.ali 11
import org.springframework.beans.factory.annotation.Qualifier;
21292 ashik.ali 12
import org.springframework.http.ResponseEntity;
13
import org.springframework.stereotype.Controller;
21692 amit.gupta 14
import org.springframework.transaction.annotation.Transactional;
21309 ashik.ali 15
import org.springframework.web.bind.annotation.RequestBody;
21292 ashik.ali 16
import org.springframework.web.bind.annotation.RequestMapping;
17
import org.springframework.web.bind.annotation.RequestMethod;
18
import org.springframework.web.bind.annotation.RequestParam;
19
 
20
import com.spice.profitmandi.common.ResponseCodeHolder;
21
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
22
import com.spice.profitmandi.common.model.ProfitMandiConstants;
21463 ashik.ali 23
import com.spice.profitmandi.common.model.UserInfo;
22473 ashik.ali 24
import com.spice.profitmandi.common.util.StringUtils;
25
import com.spice.profitmandi.common.util.Utils;
21740 ashik.ali 26
import com.spice.profitmandi.common.web.util.ResponseSender;
21735 ashik.ali 27
import com.spice.profitmandi.dao.entity.dtr.Brand;
22473 ashik.ali 28
import com.spice.profitmandi.dao.entity.dtr.DistrictMaster;
21735 ashik.ali 29
import com.spice.profitmandi.dao.entity.dtr.Document;
30
import com.spice.profitmandi.dao.entity.dtr.Retailer;
31
import com.spice.profitmandi.dao.entity.dtr.RetailerBrand;
32
import com.spice.profitmandi.dao.entity.dtr.RetailerRegisteredAddress;
33
import com.spice.profitmandi.dao.entity.dtr.Shop;
34
import com.spice.profitmandi.dao.entity.dtr.ShopAddress;
35
import com.spice.profitmandi.dao.entity.dtr.User;
21768 amit.gupta 36
import com.spice.profitmandi.dao.entity.dtr.UserAccounts;
37
import com.spice.profitmandi.dao.entity.dtr.UserRole;
22656 ashik.ali 38
import com.spice.profitmandi.dao.entity.fofo.FofoStore;
39
import com.spice.profitmandi.dao.entity.fofo.FofoStoreSequenceGeneration;
21735 ashik.ali 40
import com.spice.profitmandi.dao.entity.user.Address;
22355 ashik.ali 41
import com.spice.profitmandi.dao.entity.user.Cart;
42
import com.spice.profitmandi.dao.entity.user.Counter;
43
import com.spice.profitmandi.dao.entity.user.PrivateDealUser;
44
import com.spice.profitmandi.dao.entity.user.PrivateDealUserAddressId;
45
import com.spice.profitmandi.dao.entity.user.PrivateDealUserAddressMapping;
21768 amit.gupta 46
import com.spice.profitmandi.dao.enumuration.dtr.AccountType;
47
import com.spice.profitmandi.dao.enumuration.dtr.RoleType;
22495 amit.gupta 48
import com.spice.profitmandi.dao.model.RetailerFofoInterest;
21735 ashik.ali 49
import com.spice.profitmandi.dao.repository.dtr.BrandRepository;
22473 ashik.ali 50
import com.spice.profitmandi.dao.repository.dtr.DistrictMasterRepository;
21735 ashik.ali 51
import com.spice.profitmandi.dao.repository.dtr.DocumentRepository;
22473 ashik.ali 52
import com.spice.profitmandi.dao.repository.dtr.FofoStoreRepository;
53
import com.spice.profitmandi.dao.repository.dtr.FofoStoreSequenceGenerationRepository;
22495 amit.gupta 54
import com.spice.profitmandi.dao.repository.dtr.Mongo;
21735 ashik.ali 55
import com.spice.profitmandi.dao.repository.dtr.RetailerAddressRepository;
56
import com.spice.profitmandi.dao.repository.dtr.RetailerBrandRepository;
57
import com.spice.profitmandi.dao.repository.dtr.RetailerRegisteredAddressRepository;
58
import com.spice.profitmandi.dao.repository.dtr.RetailerRepository;
59
import com.spice.profitmandi.dao.repository.dtr.ShopAddressRepository;
60
import com.spice.profitmandi.dao.repository.dtr.ShopRepository;
21768 amit.gupta 61
import com.spice.profitmandi.dao.repository.dtr.UserAccountRepository;
21735 ashik.ali 62
import com.spice.profitmandi.dao.repository.dtr.UserRepository;
21768 amit.gupta 63
import com.spice.profitmandi.dao.repository.dtr.UserRoleRepository;
21735 ashik.ali 64
import com.spice.profitmandi.dao.repository.user.AddressRepository;
22355 ashik.ali 65
import com.spice.profitmandi.dao.repository.user.CartRepository;
66
import com.spice.profitmandi.dao.repository.user.CounterRepository;
67
import com.spice.profitmandi.dao.repository.user.PrivateDealUserAddressMappingRepository;
68
import com.spice.profitmandi.dao.repository.user.PrivateDealUserRepository;
21431 ashik.ali 69
import com.spice.profitmandi.web.req.Category;
21426 ashik.ali 70
import com.spice.profitmandi.web.req.CreateRetailerAddressRequest;
71
import com.spice.profitmandi.web.req.CreateRetailerRequest;
72
import com.spice.profitmandi.web.req.RetailerAddBrandRequest;
21292 ashik.ali 73
 
22473 ashik.ali 74
import in.shop2020.model.v1.inventory.StateInfo;
22355 ashik.ali 75
import in.shop2020.model.v1.user.CartStatus;
21302 ashik.ali 76
import io.swagger.annotations.ApiImplicitParam;
77
import io.swagger.annotations.ApiImplicitParams;
78
import io.swagger.annotations.ApiOperation;
79
 
21292 ashik.ali 80
@Controller
22037 amit.gupta 81
@Transactional(rollbackFor=Throwable.class)
21292 ashik.ali 82
public class RetailerController {
83
 
84
	private static final Logger LOGGER=LoggerFactory.getLogger(RetailerController.class);
85
 
86
	@Autowired
22355 ashik.ali 87
	@Qualifier("userRepository")
21463 ashik.ali 88
	UserRepository userRepository;
89
 
90
	@Autowired
22355 ashik.ali 91
	@Qualifier("userUserRepository")
92
	com.spice.profitmandi.dao.repository.user.UserRepository userUserRepository;
93
 
94
	@Autowired
21768 amit.gupta 95
	UserRoleRepository userRoleRepository;
96
 
97
	@Autowired
21440 ashik.ali 98
	ResponseSender<?> responseSender;
99
 
100
	@Autowired
21292 ashik.ali 101
	RetailerRepository retailerRepository;
102
 
21390 ashik.ali 103
	@Autowired
104
	BrandRepository brandRepository;
105
 
106
	@Autowired
107
	AddressRepository addressRepository;
108
 
109
	@Autowired
110
	DocumentRepository documentRepository;
111
 
112
	@Autowired
113
	ShopRepository shopRepository;
114
 
115
	@Autowired
21768 amit.gupta 116
	UserAccountRepository userAccountRepository;
117
 
118
	@Autowired
21390 ashik.ali 119
	RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
120
 
121
	@Autowired
21426 ashik.ali 122
	RetailerAddressRepository retailerAddressRepository;
123
 
124
	@Autowired
21390 ashik.ali 125
	ShopAddressRepository shopAddressRepository;
126
 
127
	@Autowired
128
	RetailerBrandRepository retailerBrandRepository;
129
 
22355 ashik.ali 130
	@Autowired
131
	CounterRepository counterRepository;
132
 
133
	@Autowired
134
	PrivateDealUserRepository privateDealUserRepository;
135
 
136
	@Autowired
137
	PrivateDealUserAddressMappingRepository privateDealUserAddressMappingRepository;
138
 
139
	@Autowired
140
	CartRepository cartRepository;
141
 
22473 ashik.ali 142
	@Autowired
143
	DistrictMasterRepository districtMasterRepository;
144
 
145
	@Autowired
146
	FofoStoreRepository fofoStoreRepository;
147
 
148
	@Autowired
22495 amit.gupta 149
	private Mongo mongoClient;
150
 
151
	@Autowired
22473 ashik.ali 152
	FofoStoreSequenceGenerationRepository fofoStoreSequenceGenerationRepository;
153
 
21302 ashik.ali 154
	@ApiImplicitParams({
155
		@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", 
156
				required = true, dataType = "string", paramType = "header")
157
	})
21309 ashik.ali 158
 
21302 ashik.ali 159
	@ApiOperation(value = "Create Retailer")
160
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER, method=RequestMethod.POST)
22473 ashik.ali 161
	public ResponseEntity<?> createRetailer(HttpServletRequest request, @RequestBody CreateRetailerRequest createRetailerRequest) throws ProfitMandiBusinessException, Exception{
22355 ashik.ali 162
		LOGGER.info("request received with body [{}] at url {{}}: ", createRetailerRequest, request.getRequestURL().toString());
21440 ashik.ali 163
		try{
21691 amit.gupta 164
			UserInfo userInfo = (UserInfo)request.getAttribute("userInfo");
22355 ashik.ali 165
			LOGGER.info("requestAttribute [userInfo={}]", userInfo);
21463 ashik.ali 166
			User user = userRepository.selectById(userInfo.getUserId());
21768 amit.gupta 167
			this.createRetailer(user, createRetailerRequest);
21440 ashik.ali 168
			return responseSender.ok(ResponseCodeHolder.getMessage("RTLR_OK_1000"));
169
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
170
			LOGGER.error("ProfitMandi error: ", profitMandiBusinessException);
22355 ashik.ali 171
			throw profitMandiBusinessException;
172
			//return responseSender.badRequest(profitMandiBusinessException);
21440 ashik.ali 173
		}
174
	}
175
 
21768 amit.gupta 176
	private void createRetailer(User user, CreateRetailerRequest createRetailerRequest) 
22473 ashik.ali 177
			throws ProfitMandiBusinessException, Exception{
21390 ashik.ali 178
		Retailer retailer = new Retailer();
21426 ashik.ali 179
		retailer.setName(createRetailerRequest.getName());
180
		retailer.setNumber(createRetailerRequest.getNumber());
181
		retailer.setType(createRetailerRequest.getType());
182
		retailer.setMonthlySaleValue(createRetailerRequest.getMonthlySaleValue());
22732 ashik.ali 183
		retailer.setMonthlySaleVolume(createRetailerRequest.getMonthlySaleVolume());
21426 ashik.ali 184
		retailer.setRecharge(createRetailerRequest.getLineOfBusiness().isRecharge());
185
		retailer.setMobile(createRetailerRequest.getLineOfBusiness().isMobile());
186
		retailer.setAccessories(createRetailerRequest.getLineOfBusiness().isAccessories());
21431 ashik.ali 187
		retailer.setOther1(createRetailerRequest.getLineOfBusiness().getOther1());
188
		retailer.setOther2(createRetailerRequest.getLineOfBusiness().getOther2());
21440 ashik.ali 189
		Document retailerDocument = documentRepository.selectById(createRetailerRequest.getDocumentId());
190
		if(retailerRepository.isExistByDocumentId(retailerDocument.getId())){
191
			LOGGER.error("documet is already mapped with another retailer");
21448 ashik.ali 192
			throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, retailerDocument.getId(), "DCMNT_1000");
21440 ashik.ali 193
		}
194
		retailer.setDocumentId(retailerDocument.getId());
195
		final Document shopDocument = documentRepository.selectById(createRetailerRequest.getShop().getDocumentId());
196
		if(shopRepository.isExistByDocumentId(shopDocument.getId())){
21448 ashik.ali 197
			throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, shopDocument.getId(), "DCMNT_1000");
21440 ashik.ali 198
		}
21463 ashik.ali 199
		documentRepository.markDocumentAsPersisted(retailerDocument.getId());
22743 amit.gupta 200
		//This validation is not required
201
		/*if(retailerRepository.isExistByNumberAndType(retailer.getNumber(), retailer.getType())){
21448 ashik.ali 202
			throw new ProfitMandiBusinessException(ProfitMandiConstants.NUMBER + ", " + ProfitMandiConstants.TYPE, retailer.getNumber() + ", " + retailer.getType(), "RTLR_1001");
22743 amit.gupta 203
		}*/
21463 ashik.ali 204
		documentRepository.markDocumentAsPersisted(shopDocument.getId());
22355 ashik.ali 205
 
206
		com.spice.profitmandi.dao.entity.user.User saholicUser = null;
207
		boolean foundRetailer = false;
208
		saholicUser = userUserRepository.selectByEmailId(user.getEmailId());
209
		if(saholicUser == null){
210
			Cart cart = new Cart();
211
			cart.setCartStatus(CartStatus.ACTIVE);
212
			cartRepository.persist(cart);
213
			saholicUser = new com.spice.profitmandi.dao.entity.user.User();
214
			saholicUser.setEmailId(user.getEmailId());
215
			saholicUser.setName(createRetailerRequest.getName());
216
			saholicUser.setActiveCartId(cart.getId());
217
			userUserRepository.persist(saholicUser);
218
		}else{
219
			foundRetailer = true;
220
		}
221
		//in.shop2020.model.v1.user.User saholicUser = Utils.createSaholicUser(user.getEmailId()); 
222
		retailer.setId(saholicUser.getId());
21440 ashik.ali 223
		retailerRepository.persist(retailer);
22355 ashik.ali 224
 
21440 ashik.ali 225
		Shop shop = new Shop();
226
		shop.setName(createRetailerRequest.getShop().getName());
227
		shop.setDocumentId(shopDocument.getId());
228
		shop.setRetailerId(retailer.getId());
229
		shopRepository.persist(shop);
21448 ashik.ali 230
		this.addBrandWithRetailer(retailer.getId(), createRetailerRequest.getCategories());
21440 ashik.ali 231
		final Address addressRetailer = this.createAddress(createRetailerRequest.getAddress());
21706 amit.gupta 232
		addressRetailer.setRetaierId(retailer.getId());
22041 amit.gupta 233
		addressRepository.persist(addressRetailer);
22355 ashik.ali 234
 
21440 ashik.ali 235
		final RetailerRegisteredAddress retailerRegisteredAddress = new RetailerRegisteredAddress();
236
		retailerRegisteredAddress.setRetailerId(retailer.getId());
237
		retailerRegisteredAddress.setAddressId(addressRetailer.getId());
238
		retailerRegisteredAddressRepository.persist(retailerRegisteredAddress);
21463 ashik.ali 239
		if(!createRetailerRequest.isShopAddressSameAsRetailerAddress() && createRetailerRequest.getAddress() == null){
240
			throw new ProfitMandiBusinessException(ProfitMandiConstants.ADDRESS, "", "");
21440 ashik.ali 241
		}
21463 ashik.ali 242
		if(createRetailerRequest.isShopAddressSameAsRetailerAddress()){
243
			ShopAddress shopAddress = new ShopAddress();
244
			shopAddress.setShopId(shop.getId());
245
			shopAddress.setAddressId(addressRetailer.getId());
246
			shopAddressRepository.persist(shopAddress);
247
		}else{
248
			final Address addressShop = this.createAddress(createRetailerRequest.getShop().getAddress());
22041 amit.gupta 249
			addressRepository.persist(addressShop);
21463 ashik.ali 250
			ShopAddress shopAddress = new ShopAddress();
251
			shopAddress.setShopId(shop.getId());
252
			shopAddress.setAddressId(addressShop.getId());
253
			shopAddressRepository.persist(shopAddress);
254
		}
21768 amit.gupta 255
		UserAccounts ua = new UserAccounts();
22355 ashik.ali 256
		ua.setAccount_key(String.valueOf(saholicUser.getId()));
21768 amit.gupta 257
		ua.setUser_id(user.getId());
21769 amit.gupta 258
		ua.setAccount_type(AccountType.saholic);
21768 amit.gupta 259
		userAccountRepository.persist(ua);
260
 
261
		UserAccounts ua2 = new UserAccounts();
262
		ua2.setAccount_key(String.valueOf(saholicUser.getActiveCartId()));
263
		ua2.setUser_id(user.getId());
264
		ua2.setAccount_type(AccountType.cartId);
265
		userAccountRepository.persist(ua2);
266
 
267
		UserRole ur = new UserRole();
22011 ashik.ali 268
		ur.setRoleType(RoleType.RETAILER);
21768 amit.gupta 269
		ur.setUserId(user.getId());
270
		userRoleRepository.persist(ur);
22355 ashik.ali 271
 
272
		if(foundRetailer){
273
			LOGGER.info("\n\n\n****retailer found\n\n\n");
22604 ashik.ali 274
			PrivateDealUser privateDealUser = null;
275
			try{
276
				privateDealUser = privateDealUserRepository.selectById(saholicUser.getId());
277
			}catch(ProfitMandiBusinessException profitMandiBusinessException){
278
				LOGGER.error("PrivateDealUser not found : ", profitMandiBusinessException);
279
			}
22503 amit.gupta 280
			if(privateDealUser == null) {
281
				privateDealUser = new PrivateDealUser();
282
				privateDealUser.setActive(true);
283
				privateDealUser.setBulkShipmentAmountLimit(50000);
284
				privateDealUser.setId(saholicUser.getId());
285
				privateDealUserRepository.persist(privateDealUser);
286
				PrivateDealUserAddressMapping privateDealUserAddressMapping = new PrivateDealUserAddressMapping();
287
				PrivateDealUserAddressId privateDealUserAddressId = new PrivateDealUserAddressId();
288
				privateDealUserAddressId.setUserId(retailer.getId());
289
				privateDealUserAddressId.setAddressId(addressRetailer.getId());
290
				privateDealUserAddressMapping.setId(privateDealUserAddressId);
291
				privateDealUserAddressMappingRepository.persist(privateDealUserAddressMapping);
292
			}
22355 ashik.ali 293
			if(privateDealUser.getCounterId() == null){
294
				Integer counterId = this.createCounter(user.getEmailId(), createRetailerRequest.getGstNumber(), user.getMobileNumber(), retailer.getName(), addressRetailer.getId());
295
				privateDealUser.setCounterId(counterId);
296
				privateDealUserRepository.persist(privateDealUser);
297
			}
298
		}else{
299
			LOGGER.info("retailer not found");
300
			//gst number intergration with counter
301
			Integer counterId = this.createCounter(user.getEmailId(), createRetailerRequest.getGstNumber(), user.getMobileNumber(), retailer.getName(), addressRetailer.getId());
302
 
303
 
22604 ashik.ali 304
			PrivateDealUser privateDealUser = null;
305
			try{
306
				privateDealUser = privateDealUserRepository.selectById(saholicUser.getId());
307
			}catch(ProfitMandiBusinessException profitMandiBusinessException){
308
				LOGGER.error("PrivateDealUser not found : ", profitMandiBusinessException);
309
			}
310
 
22355 ashik.ali 311
			if(privateDealUser != null){
312
				//LOGGER.info("PrivateDealUser found with id [{}]", saholicUser.getId());
313
				privateDealUser.setCounterId(counterId);
314
				privateDealUserRepository.update(privateDealUser);
315
			}else{	
316
				LOGGER.info("PrivateDealUser not found with id [{}]", saholicUser.getId());
317
				privateDealUser = new PrivateDealUser();
318
				privateDealUser.setActive(true);
319
				privateDealUser.setBulkShipmentAmountLimit(50000);
320
				privateDealUser.setId(saholicUser.getId());
321
				privateDealUser.setCounterId(counterId);
322
				privateDealUserRepository.persist(privateDealUser);
323
			}
324
			PrivateDealUserAddressMapping privateDealUserAddressMapping = new PrivateDealUserAddressMapping();
325
			PrivateDealUserAddressId privateDealUserAddressId = new PrivateDealUserAddressId();
326
			privateDealUserAddressId.setUserId(retailer.getId());
327
			privateDealUserAddressId.setAddressId(addressRetailer.getId());
328
			privateDealUserAddressMapping.setId(privateDealUserAddressId);
329
			privateDealUserAddressMappingRepository.persist(privateDealUserAddressMapping);
330
 
331
			saholicUser.setAddressId(addressRetailer.getId());
332
			userUserRepository.persist(saholicUser);
333
		}
22495 amit.gupta 334
		/*StateInfo stateInfo = Utils.getStateInfo(addressRetailer.getState());
22473 ashik.ali 335
		DistrictMaster districtMaster = districtMasterRepository.selectByNameAndStateShortName(createRetailerRequest.getDistrict(), stateInfo.getShortName());
336
		FofoStoreSequenceGeneration fofoStoreSequenceGeneration = null;
337
		boolean foundFofoStoreSequence = false;
338
		try{
339
			fofoStoreSequenceGeneration = fofoStoreSequenceGenerationRepository.selectByStateShortName(stateInfo.getShortName());
340
			foundFofoStoreSequence = true;
341
		}catch(ProfitMandiBusinessException profitMandiBusinessException){
342
			fofoStoreSequenceGeneration = new FofoStoreSequenceGeneration();
343
			fofoStoreSequenceGeneration.setSequence(1);
344
			fofoStoreSequenceGeneration.setStateShortName(stateInfo.getShortName());
345
			fofoStoreSequenceGenerationRepository.persist(fofoStoreSequenceGeneration);
346
		}
347
		FofoStore fofoStore = new FofoStore();
348
		fofoStore.setId(retailer.getId());
349
		String fofoStoreCode = StringUtils.generateFofoStoreSequence(districtMaster.getStateShortName() + districtMaster.getShortName(), fofoStoreSequenceGeneration.getSequence());
350
		if(foundFofoStoreSequence){
351
			fofoStoreSequenceGeneration.setSequence(fofoStoreSequenceGeneration.getSequence() + 1);
352
			fofoStoreSequenceGenerationRepository.persist(fofoStoreSequenceGeneration);
353
		}
354
		fofoStore.setCode(fofoStoreCode);
22495 amit.gupta 355
		fofoStoreRepository.persist(fofoStore);*/
21292 ashik.ali 356
	}
357
 
22355 ashik.ali 358
	private Integer createCounter(String emailId, String gstNumber, String mobileNumber, String name, int addressId){
359
		if(gstNumber != null && !gstNumber.isEmpty()){
360
			Counter counter = new Counter();
361
			counter.setEmailId(emailId);
362
			counter.setGstin(gstNumber);
363
			counter.setMobileNumber(mobileNumber);
364
			counter.setName(name);
365
			counter.setAddressId(addressId);
366
			counterRepository.persist(counter);
367
			return counter.getId();
368
		}else{
369
			return null;
370
		}
21463 ashik.ali 371
	}
22355 ashik.ali 372
 
373
 
21448 ashik.ali 374
	private void addBrandWithRetailer(int retailerId, Set<Category> categories)
375
		throws ProfitMandiBusinessException{
376
		for(Category category : categories){
377
			for(com.spice.profitmandi.web.req.Brand brandModel : category.getBrands()){
378
				Brand brand = brandRepository.selectByIdAndName(brandModel.getId(), brandModel.getName());
379
				final RetailerBrand retailerBrand = new RetailerBrand();
380
				retailerBrand.setRetailerId(retailerId);
381
				retailerBrand.setBrandId(brand.getId());
382
				retailerBrandRepository.persist(retailerBrand);
383
			}
384
		}
385
	}
22524 ashik.ali 386
 
387
	@ApiOperation(value = "Create Fofo Store")
388
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_FOFO_FOFO_STORE, method=RequestMethod.POST)
389
	public ResponseEntity<?> createFofoStore(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.DISTRICT_NAME) String districtName) throws ProfitMandiBusinessException, Exception{
390
		try{
391
			UserInfo userInfo = (UserInfo)request.getAttribute("userInfo");
392
			LOGGER.info("requestAttribute [userInfo={}]", userInfo);
393
			User user = userRepository.selectById(userInfo.getUserId());
22604 ashik.ali 394
			// = userAccountRepository.selectRetailerIdByUserId(user.getId());
22524 ashik.ali 395
			UserAccounts userAccounts = userAccountRepository.selectSaholicByUserId(user.getId());
22604 ashik.ali 396
			Retailer retailer = retailerRepository.selectById(Integer.parseInt(userAccounts.getAccount_key()));
397
			try{
398
				userRoleRepository.selectByUserIdAndRoleType(user.getId(), RoleType.FOFO);
399
			}catch(ProfitMandiBusinessException profitMandiBusinessException){
22524 ashik.ali 400
				throw new ProfitMandiBusinessException(ProfitMandiConstants.USER_ID, user.getId(), "USR_1013");
22554 amit.gupta 401
			}
22604 ashik.ali 402
 
22524 ashik.ali 403
			boolean foundFofoStore = false;
404
			try{
405
				fofoStoreRepository.selectByRetailerId(retailer.getId());
406
				foundFofoStore = true;
407
			}catch (ProfitMandiBusinessException profitMandiBusinessException) {
408
 
409
			}
410
 
411
			if(foundFofoStore){
412
				throw new ProfitMandiBusinessException(ProfitMandiConstants.RETAILER_ID, retailer.getId(), "USR_1014");
413
			}			
414
 
415
			int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(retailer.getId());
416
			Address retailerAddress = addressRepository.selectById(retailerAddressId);
417
 
418
			StateInfo stateInfo = Utils.getStateInfo(retailerAddress.getState());
419
			DistrictMaster districtMaster = districtMasterRepository.selectByNameAndStateShortName(districtName, stateInfo.getShortName());
420
			FofoStoreSequenceGeneration fofoStoreSequenceGeneration = null;
421
			boolean foundFofoStoreSequence = false;
422
			try{
423
				fofoStoreSequenceGeneration = fofoStoreSequenceGenerationRepository.selectByStateShortName(stateInfo.getShortName());
424
				foundFofoStoreSequence = true;
425
			}catch(ProfitMandiBusinessException profitMandiBusinessException){
426
				fofoStoreSequenceGeneration = new FofoStoreSequenceGeneration();
427
				fofoStoreSequenceGeneration.setSequence(1);
428
				fofoStoreSequenceGeneration.setStateShortName(stateInfo.getShortName());
429
				fofoStoreSequenceGenerationRepository.persist(fofoStoreSequenceGeneration);
430
			}
431
 
432
			FofoStore fofoStore = new FofoStore();
433
			fofoStore.setId(retailer.getId());
434
			String fofoStoreCode = StringUtils.generateFofoStoreSequence(districtMaster.getStateShortName() + districtMaster.getShortName(), fofoStoreSequenceGeneration.getSequence());
435
			if(foundFofoStoreSequence){
436
				fofoStoreSequenceGeneration.setSequence(fofoStoreSequenceGeneration.getSequence() + 1);
437
				fofoStoreSequenceGenerationRepository.persist(fofoStoreSequenceGeneration);
438
			}
439
			fofoStore.setCode(fofoStoreCode);
440
			fofoStoreRepository.persist(fofoStore);
441
 
442
			return responseSender.ok(ResponseCodeHolder.getMessage("RTLR_OK_1003"));
443
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
444
			LOGGER.error("ProfitMandi error: ", profitMandiBusinessException);
445
			throw profitMandiBusinessException;
446
			//return responseSender.badRequest(profitMandiBusinessException);
447
		}
448
	}
449
 
21292 ashik.ali 450
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ALL,method=RequestMethod.GET)
21496 ashik.ali 451
	public ResponseEntity<?> getAll(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.PAGE_NUMBER) int pageNumber, @RequestParam(name = ProfitMandiConstants.PAGE_SIZE) int pageSize){
21292 ashik.ali 452
		LOGGER.info("requested url : "+request.getRequestURL().toString());
21496 ashik.ali 453
		return responseSender.ok(retailerRepository.selectAll(pageNumber, pageSize));
21292 ashik.ali 454
	}
455
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ID, method=RequestMethod.GET)
21431 ashik.ali 456
	public ResponseEntity<?> getById(HttpServletRequest request, @RequestParam(name = "id") int id){
21292 ashik.ali 457
		LOGGER.info("requested url : "+request.getRequestURL().toString());
458
		try {
21440 ashik.ali 459
			return responseSender.ok(retailerRepository.selectById(id));
460
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
461
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
462
			return responseSender.badRequest(profitMandiBusinessException);
21292 ashik.ali 463
		}
464
	}
465
 
466
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_NAME, method=RequestMethod.GET)
467
	public ResponseEntity<?> getByName(HttpServletRequest request, @RequestParam(name = "name") String name){
468
		LOGGER.info("requested url : "+request.getRequestURL().toString());
469
		try {
21440 ashik.ali 470
			return responseSender.ok(retailerRepository.selectByName(name));
471
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
472
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
473
			return responseSender.badRequest(profitMandiBusinessException);
21292 ashik.ali 474
		}
475
	}
476
 
477
 
478
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ID,method=RequestMethod.DELETE)
21431 ashik.ali 479
	public ResponseEntity<?> removeById(HttpServletRequest request, @RequestParam(name = "id") int id){
21292 ashik.ali 480
		LOGGER.info("requested url : "+request.getRequestURL().toString());
481
		try {
482
			retailerRepository.deleteById(id);
21440 ashik.ali 483
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
484
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
485
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
486
			return responseSender.badRequest(profitMandiBusinessException);
21292 ashik.ali 487
		}
488
	}
489
 
21426 ashik.ali 490
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_SHOP_ADD, method=RequestMethod.POST)
21431 ashik.ali 491
	public ResponseEntity<?> addShop(HttpServletRequest request, @RequestBody com.spice.profitmandi.web.req.Shop createShop, @RequestParam(name = "retailerId") int retailerId){
21426 ashik.ali 492
		LOGGER.info("requested url : "+request.getRequestURL().toString());
493
		try {
494
			Document document = documentRepository.selectById(createShop.getDocumentId());
495
			if(shopRepository.isExistByDocumentId(createShop.getDocumentId())){
496
				LOGGER.error("documet is already mapped with another shop");
497
				throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, document.getId(), "");
498
			}
499
			retailerRepository.selectById(retailerId);
500
			Shop shop = new Shop();
501
			shop.setRetailerId(retailerId);
502
			Address address = this.createAddress(createShop.getAddress());
503
			addressRepository.persist(address);
504
			shop.setAddressId(address.getId());
505
			shop.setDocumentId(document.getId());
506
			shopRepository.persist(shop);
507
			ShopAddress shopAddress = new ShopAddress();
508
			shopAddress.setAddressId(address.getId());
509
			shopAddress.setShopId(shop.getId());
510
			shopAddressRepository.persist(shopAddress);
21440 ashik.ali 511
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
512
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
513
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
514
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 515
		}
516
	}
517
 
518
 
21302 ashik.ali 519
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_SHOP_REMOVE, method=RequestMethod.DELETE)
21431 ashik.ali 520
	public ResponseEntity<?> removeShop(HttpServletRequest request, @RequestParam(name = "shopId") int shopId, @RequestParam(name = "retailerId") int retailerId){
21292 ashik.ali 521
		LOGGER.info("requested url : "+request.getRequestURL().toString());
522
		try {
523
			retailerRepository.removeShop(shopId, retailerId);
21440 ashik.ali 524
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
525
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
526
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
527
			return responseSender.badRequest(profitMandiBusinessException);
21292 ashik.ali 528
		}
529
	}
530
 
21426 ashik.ali 531
	private Address createAddress(com.spice.profitmandi.web.req.Address createAddress){
532
		Address address = new Address();
533
		address.setName(createAddress.getName());
534
		address.setLine1(createAddress.getLine1());
535
		address.setLine2(createAddress.getLine2());
536
		address.setLandmark(createAddress.getLandmark());
537
		address.setCity(createAddress.getCity());
538
		address.setState(createAddress.getState());
539
		address.setPinCode(createAddress.getPinCode());
540
		address.setCountry(createAddress.getCountry());
541
		address.setPhoneNumber(createAddress.getPhoneNumber());
21706 amit.gupta 542
 
21426 ashik.ali 543
		return address;
544
	}
21440 ashik.ali 545
 
21426 ashik.ali 546
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ADDRESS_ADD, method=RequestMethod.POST)
547
	public ResponseEntity<?> addAddress(HttpServletRequest request, @RequestBody CreateRetailerAddressRequest createRetailerAddress){
548
		LOGGER.info("requested url : "+request.getRequestURL().toString());
549
		try {
550
			retailerRepository.addAddress(this.createAddress(createRetailerAddress.getAddress()), createRetailerAddress.getRetailerId());
21440 ashik.ali 551
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
552
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
553
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
554
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 555
		}
556
	}
21292 ashik.ali 557
 
21426 ashik.ali 558
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ADDRESS_REMOVE, method=RequestMethod.DELETE)
21431 ashik.ali 559
	public ResponseEntity<?> removeAddress(HttpServletRequest request, @RequestParam(name = "addressId") int addressId, @RequestParam(name = "retailerId") int retailerId){
21426 ashik.ali 560
		LOGGER.info("requested url : "+request.getRequestURL().toString());
561
		try {
562
			retailerRepository.removeAddress(addressId, retailerId);
21440 ashik.ali 563
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
564
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
565
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
566
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 567
		}
568
	}
569
 
570
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_BRAND_ADD, method=RequestMethod.POST)
571
	public ResponseEntity<?> addBrand(HttpServletRequest request, @RequestBody RetailerAddBrandRequest retailerAddBrandRequest){
572
		LOGGER.info("requested url : "+request.getRequestURL().toString());
573
		try {
21448 ashik.ali 574
			retailerRepository.selectById(retailerAddBrandRequest.getRetailerId());
575
			this.addBrandWithRetailer(retailerAddBrandRequest.getRetailerId(), retailerAddBrandRequest.getCategories());
21440 ashik.ali 576
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
577
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
578
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
579
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 580
		}
581
	}
582
 
583
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_BRAND_REMOVE, method=RequestMethod.DELETE)
21431 ashik.ali 584
	public ResponseEntity<?> removeBrand(HttpServletRequest request, @RequestParam(name = "brandId") int brandId, @RequestParam(name = "retailerId") int retailerId){
21426 ashik.ali 585
		LOGGER.info("requested url : "+request.getRequestURL().toString());
586
		try {
587
			brandRepository.selectById(brandId);
588
			retailerRepository.selectById(retailerId);
21448 ashik.ali 589
			retailerBrandRepository.deleteByRetailerAndBrandId(retailerId, brandId);
21440 ashik.ali 590
			return responseSender.ok(ResponseCodeHolder.getMessage("API_OK_1001"));
591
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
592
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
593
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 594
		}
595
	}
596
 
597
 
21448 ashik.ali 598
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_DOCUMENT, method=RequestMethod.GET)
599
	public ResponseEntity<?> getDocumentById(HttpServletRequest request, @RequestParam(name = "retailerId") int retailerId){
21426 ashik.ali 600
		LOGGER.info("requested url : "+request.getRequestURL().toString());
601
		try {
21448 ashik.ali 602
			return responseSender.ok(retailerRepository.selectDocumentById(retailerId));
21440 ashik.ali 603
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
604
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
605
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 606
		}
607
	}
608
 
21448 ashik.ali 609
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_REGISTERED_ADDRESS, method=RequestMethod.GET)
610
	public ResponseEntity<?> getRegisteredAddressById(HttpServletRequest request, @RequestParam(name = "retailerId") int retailerId){
611
		LOGGER.info("requested url : "+request.getRequestURL().toString());
612
		try {
21698 amit.gupta 613
			return responseSender.ok(retailerRegisteredAddressRepository.selectAddressIdByRetailerId(retailerId));
21448 ashik.ali 614
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
615
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
616
			return responseSender.badRequest(profitMandiBusinessException);
617
		}
618
	}
619
 
21426 ashik.ali 620
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_SHOP_ALL, method=RequestMethod.GET)
21431 ashik.ali 621
	public ResponseEntity<?> getAllShops(HttpServletRequest request, @RequestParam(name = "id") int id){
21426 ashik.ali 622
		LOGGER.info("requested url : "+request.getRequestURL().toString());
623
		try {
21440 ashik.ali 624
			return responseSender.ok(shopRepository.selectByRetailerId(id));
625
		}catch (ProfitMandiBusinessException profitMandiBusinessException) {
626
			LOGGER.error("ProfitMandi error: ",  profitMandiBusinessException);
627
			return responseSender.badRequest(profitMandiBusinessException);
21426 ashik.ali 628
		}
629
	}
630
 
631
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_ADDRESS_ALL, method=RequestMethod.GET)
21431 ashik.ali 632
	public ResponseEntity<?> getAllAddresses(HttpServletRequest request, @RequestParam(name = "id") int id){
21426 ashik.ali 633
		LOGGER.info("requested url : "+request.getRequestURL().toString());
21440 ashik.ali 634
		return responseSender.ok(retailerAddressRepository.selectAddressesByRetailerId(id));
21426 ashik.ali 635
	}
636
 
637
 
638
	@RequestMapping(value = ProfitMandiConstants.URL_RETAILER_BRAND_ALL, method=RequestMethod.GET)
21431 ashik.ali 639
	public ResponseEntity<?> getAllBrads(HttpServletRequest request, @RequestParam(name = "id") int id){
21426 ashik.ali 640
		LOGGER.info("requested url : "+request.getRequestURL().toString());
21440 ashik.ali 641
		return responseSender.ok(retailerBrandRepository.selectBrandNamesByRetailerId(id));
21426 ashik.ali 642
	}
22495 amit.gupta 643
 
644
	@RequestMapping(value = "/retailer/showFofoInterest", method=RequestMethod.GET)
645
	public ResponseEntity<?> showFofoInterest(HttpServletRequest request) throws Throwable{
646
		UserInfo userInfo = (UserInfo)request.getAttribute("userInfo");
647
		User user = userRepository.selectById(userInfo.getUserId());
648
		RetailerFofoInterest retailerInterest = new RetailerFofoInterest();
649
		retailerInterest.setCity(user.getCity());
650
		retailerInterest.setMobile(user.getMobileNumber());
651
		retailerInterest.setPinCode(user.getPinCode());
652
		retailerInterest.setUserId(userInfo.getUserId());
653
		retailerInterest.setPinCode(user.getPinCode());
654
		retailerInterest.setInterestShownOn(new Date());
655
		LOGGER.info("requested url : "+request.getRequestURL().toString());
656
		return responseSender.ok(mongoClient.saveRetailerInterestOnFofo(retailerInterest));
657
	}
658
 
659
	@RequestMapping(value = "/retailer/hasRetailerShownInterest", method=RequestMethod.GET)
660
	public ResponseEntity<?> getAllBrads(HttpServletRequest request) throws Throwable{
661
		UserInfo userInfo = (UserInfo)request.getAttribute("userInfo");
662
		LOGGER.info("requested url : "+request.getRequestURL().toString());
663
		return responseSender.ok(mongoClient.hasRetailerShownInterest(userInfo.getUserId()));
664
	}
21426 ashik.ali 665
 
21292 ashik.ali 666
}