Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
24417 govind 1
package com.spice.profitmandi.web.controller;
2
 
3
import java.time.LocalDateTime;
24572 amit.gupta 4
import java.util.ArrayList;
24417 govind 5
import java.util.HashSet;
6
import java.util.List;
7
import java.util.Map;
8
import java.util.Optional;
24572 amit.gupta 9
import java.util.Set;
24500 govind 10
import java.util.stream.Collectors;
24417 govind 11
 
12
import javax.servlet.http.HttpServletRequest;
24699 govind 13
import javax.swing.SortOrder;
24417 govind 14
 
15
import org.apache.logging.log4j.LogManager;
16
import org.apache.logging.log4j.Logger;
17
import org.springframework.beans.factory.annotation.Autowired;
24620 govind 18
import org.springframework.mail.javamail.JavaMailSender;
24417 govind 19
import org.springframework.stereotype.Controller;
20
import org.springframework.transaction.annotation.Transactional;
21
import org.springframework.ui.Model;
24471 govind 22
import org.springframework.web.bind.annotation.DeleteMapping;
24417 govind 23
import org.springframework.web.bind.annotation.GetMapping;
24
import org.springframework.web.bind.annotation.PostMapping;
25
import org.springframework.web.bind.annotation.RequestBody;
26
import org.springframework.web.bind.annotation.RequestParam;
27
 
28
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
29
import com.spice.profitmandi.common.model.CustomRetailer;
24620 govind 30
import com.spice.profitmandi.common.util.Utils;
24417 govind 31
import com.spice.profitmandi.dao.entity.auth.AuthUser;
32
import com.spice.profitmandi.dao.entity.cs.Activity;
33
import com.spice.profitmandi.dao.entity.cs.Position;
34
import com.spice.profitmandi.dao.entity.cs.Region;
35
import com.spice.profitmandi.dao.entity.cs.Ticket;
24500 govind 36
import com.spice.profitmandi.dao.entity.cs.TicketAssigned;
24417 govind 37
import com.spice.profitmandi.dao.entity.cs.TicketCategory;
24747 govind 38
import com.spice.profitmandi.dao.entity.cs.TicketSearchType;
24417 govind 39
import com.spice.profitmandi.dao.entity.cs.TicketSubCategory;
40
import com.spice.profitmandi.dao.entity.fofo.ActivityType;
41
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
24699 govind 42
import com.spice.profitmandi.dao.enumuration.cs.TicketStatus;
24417 govind 43
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
44
import com.spice.profitmandi.dao.repository.cs.ActivityRepository;
45
import com.spice.profitmandi.dao.repository.cs.CsService;
24557 govind 46
import com.spice.profitmandi.dao.repository.cs.PartnerRegionRepository;
24417 govind 47
import com.spice.profitmandi.dao.repository.cs.PositionRepository;
48
import com.spice.profitmandi.dao.repository.cs.RegionRepository;
24500 govind 49
import com.spice.profitmandi.dao.repository.cs.TicketAssignedRepository;
24417 govind 50
import com.spice.profitmandi.dao.repository.cs.TicketCategoryRepository;
51
import com.spice.profitmandi.dao.repository.cs.TicketRepository;
52
import com.spice.profitmandi.dao.repository.cs.TicketSubCategoryRepository;
53
import com.spice.profitmandi.service.authentication.RoleManager;
54
import com.spice.profitmandi.service.slab.TargetSlabService;
55
import com.spice.profitmandi.service.user.RetailerService;
56
import com.spice.profitmandi.web.model.LoginDetails;
57
import com.spice.profitmandi.web.util.CookiesProcessor;
58
import com.spice.profitmandi.web.util.MVCResponseSender;
59
 
60
@Controller
61
@Transactional(rollbackFor = Throwable.class)
62
public class CsController {
63
 
64
	private static final Logger LOGGER = LogManager.getLogger(CsController.class);
65
 
24620 govind 66
	private static final String ACTIVITY_SUBJECT = "Message related ticketId#%s";
24699 govind 67
	private static final String PARTNER_RESOLVED_TICKET_MAIL = "Dear Partner , we have resolved your ticket # %s , request to kindly accept the same. In case you still have any concerns regarding the same pls click on %s so that we can help you.Regards\nSmartdukaan";
68
	private static final String PARTNER_REOPEN = "Dear Partner , Your ticket # %s has been re-opened as per your confirmation & we are committed to resolve it on priority.Regards\nSmartdukaan";
69
	private static final String INTERNAL_REOPEN_MAIL = "Hi, Pls note that the ticket # %s has been re-opened by %s , pls respond on priority.";
70
	private static final String INTERNAL_REOPEN_ACTIVITY_MESSAGE = "Hi,My ticket is not resolved yet,so I am reopenning ticket";
71
 
24417 govind 72
	@Autowired
24620 govind 73
	JavaMailSender mailSender;
74
 
75
	@Autowired
24417 govind 76
	private CsService csService;
77
 
78
	@Autowired
79
	private CookiesProcessor cookiesProcessor;
80
 
81
	@Autowired
82
	private TicketCategoryRepository ticketCategoryRepository;
83
 
84
	@Autowired
85
	private TicketSubCategoryRepository ticketSubCategoryRepository;
86
 
87
	@Autowired
88
	private RegionRepository regionRepository;
89
 
90
	@Autowired
91
	private TargetSlabService targetSlabService;
92
 
93
	@Autowired
94
	private RetailerService retailerService;
95
 
96
	@Autowired
97
	private MVCResponseSender mvcResponseSender;
98
 
99
	@Autowired
100
	private AuthRepository authRepository;
101
 
102
	@Autowired
103
	private PositionRepository positionRepository;
104
 
105
	@Autowired
106
	private TicketRepository ticketRepository;
107
 
108
	@Autowired
109
	private RoleManager roleManager;
110
 
111
	@Autowired
112
	private ActivityRepository activityRepository;
113
 
24500 govind 114
	@Autowired
115
	private TicketAssignedRepository ticketAssignedRepository;
24569 govind 116
 
117
	@Autowired
24557 govind 118
	private PartnerRegionRepository partnerRegionRepository;
24500 govind 119
 
24417 govind 120
	@GetMapping(value = "/cs/createCategory")
121
	public String getCreateCategory(HttpServletRequest request, Model model) {
122
		List<TicketCategory> ticketCategories = ticketCategoryRepository.selectAll();
123
		model.addAttribute("ticketCategories", ticketCategories);
124
		return "create-ticket-category";
125
	}
126
 
127
	@PostMapping(value = "/cs/createCategory")
128
	public String createCategory(HttpServletRequest request, @RequestParam(name = "name") String name,
129
			@RequestParam(name = "description") String description, Model model) throws ProfitMandiBusinessException {
130
 
131
		TicketCategory ticketCategory = ticketCategoryRepository.selectByName(name);
132
		if (ticketCategory != null) {
133
			throw new ProfitMandiBusinessException("name", name, "already exists!");
134
		}
135
		ticketCategory = new TicketCategory();
136
		ticketCategory.setName(name);
137
		ticketCategory.setDescription(description);
138
		ticketCategoryRepository.persist(ticketCategory);
139
		return "create-ticket-category";
140
	}
141
 
142
	@GetMapping(value = "/cs/createSubCategory")
143
	public String getCreateSubCategory(HttpServletRequest request, Model model) {
144
		List<TicketCategory> ticketCategories = ticketCategoryRepository.selectAll();
145
		model.addAttribute("ticketCategories", ticketCategories);
146
		return "create-ticket-sub-category";
147
	}
148
 
149
	@GetMapping(value = "/cs/getSubCategoryByCategoryId")
150
	public String getSubCategoryByCategoryId(HttpServletRequest request,
151
			@RequestParam(name = "ticketCategoryId", defaultValue = "") int ticketCategoryId, Model model) {
152
		List<TicketSubCategory> ticketSubCategories = ticketSubCategoryRepository.selectAll(ticketCategoryId);
153
		TicketCategory ticketCategory = ticketCategoryRepository.selectById(ticketCategoryId);
154
		model.addAttribute("ticketSubCategories", ticketSubCategories);
155
		model.addAttribute("ticketCategory", ticketCategory);
156
		return "ticket-sub-category";
157
	}
158
 
159
	@PostMapping(value = "/cs/createSubCategory")
160
	public String createSubCategory(HttpServletRequest request,
161
			@RequestParam(name = "categoryId", defaultValue = "0") int categoryId,
162
			@RequestParam(name = "name") String name, @RequestParam(name = "description") String description,
163
			Model model) throws ProfitMandiBusinessException {
164
 
165
		TicketSubCategory ticketSubCategory = ticketSubCategoryRepository.selectTicketSubCategory(categoryId, name);
166
		if (ticketSubCategory != null) {
167
			throw new ProfitMandiBusinessException("name & categoryId", name + "  " + categoryId, "already exists!");
168
		}
169
 
170
		ticketSubCategory = new TicketSubCategory();
171
		ticketSubCategory.setcategoryId(categoryId);
172
		ticketSubCategory.setName(name);
173
		ticketSubCategory.setDescription(description);
174
		ticketSubCategoryRepository.persist(ticketSubCategory);
175
		return "create-ticket-sub-category";
176
	}
177
 
178
	@GetMapping(value = "/cs/createRegion")
179
	public String createRegion(HttpServletRequest request, Model model) {
180
		List<Region> regions = regionRepository.selectAll();
181
		model.addAttribute("regions", regions);
182
		return "create-region";
183
	}
184
 
185
	@PostMapping(value = "/cs/createRegion")
186
	public String createRegion(HttpServletRequest request, @RequestParam(name = "name") String name,
187
			@RequestParam(name = "description") String description, Model model) throws Exception {
188
		Region region = regionRepository.selectByName(name);
189
		if (region != null) {
190
			throw new ProfitMandiBusinessException("name", name, "already exists!");
191
		}
192
		region = new Region();
193
		region.setName(name);
194
		region.setDescription(description);
195
		regionRepository.persist(region);
196
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
197
		return "response";
198
	}
199
 
24557 govind 200
	@GetMapping(value = "/cs/getPartners")
24569 govind 201
	public String getPartners(HttpServletRequest request,
202
			@RequestParam(name = "regionId", defaultValue = "0") int regionId, Model model) {
24557 govind 203
		List<Integer> fofoIds = targetSlabService.getfofoIdsFromfofoStore();
24569 govind 204
		List<Integer> addedfofoIds = partnerRegionRepository.selectByRegionId(regionId).stream().map(x -> x.getFofoId())
205
				.collect(Collectors.toList());
24557 govind 206
		Map<Integer, CustomRetailer> fofoRetailers = retailerService.getFofoRetailers(fofoIds);
207
		model.addAttribute("fofoRetailers", fofoRetailers);
208
		model.addAttribute("addedfofoIds", addedfofoIds);
209
		return "added-region-partners";
210
	}
24569 govind 211
 
24417 govind 212
	@GetMapping(value = "/cs/createPartnerRegion")
213
	public String createPartnerRegion(HttpServletRequest request, Model model) {
214
		List<Region> regions = regionRepository.selectAll();
215
		model.addAttribute("regions", regions);
216
		return "create-partner-region";
217
	}
218
 
219
	@PostMapping(value = "/cs/createPartnerRegion")
220
	public String createPartnerRegion(HttpServletRequest request, @RequestParam(name = "regionId") int regionId,
221
			@RequestBody List<Integer> selectedFofoIds, Model model) throws Exception {
24557 govind 222
		partnerRegionRepository.delete(regionId);
223
		LOGGER.info("successfully removed");
224
		LOGGER.info(selectedFofoIds.size());
24417 govind 225
		csService.addPartnerToRegion(regionId, selectedFofoIds);
226
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
227
		return "response";
228
	}
229
 
230
	@GetMapping(value = "/cs/createPosition")
24500 govind 231
	public String createPosition(HttpServletRequest request,
232
			@RequestParam(name = "offset", defaultValue = "0") int offset,
24471 govind 233
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model) {
24417 govind 234
		List<AuthUser> authUsers = authRepository.selectAll();
235
		List<TicketCategory> ticketCategories = ticketCategoryRepository.selectAll();
236
		List<Region> regions = regionRepository.selectAll();
237
		model.addAttribute("escalationTypes", EscalationType.values());
238
		model.addAttribute("authUsers", authUsers);
239
		model.addAttribute("ticketCategories", ticketCategories);
240
		model.addAttribute("regions", regions);
24500 govind 241
 
242
		List<Position> positions = positionRepository.selectAll(offset, limit);
243
		LOGGER.info(positions);
244
		Map<Integer, AuthUser> authUserIdAndAuthUserMap = csService
245
				.getAuthUserIdAndAuthUserMapUsingPositions(positions);
246
		Map<Integer, TicketCategory> categoryIdAndCategoryMap = csService
247
				.getCategoryIdAndCategoryUsingPositions(positions);
248
		Map<Integer, Region> regionIdAndRegionMap = csService.getRegionIdAndRegionMap(positions);
249
		long size = positionRepository.selectAllCount();
250
 
24471 govind 251
		if (size < limit) {
252
			model.addAttribute("end", offset + size);
253
		} else {
254
			model.addAttribute("end", offset + limit);
255
		}
256
		model.addAttribute("start", offset + 1);
257
		model.addAttribute("size", size);
258
		model.addAttribute("positions", positions);
259
		model.addAttribute("authUserIdAndAuthUserMap", authUserIdAndAuthUserMap);
260
		model.addAttribute("categoryIdAndCategoryMap", categoryIdAndCategoryMap);
261
		model.addAttribute("regionIdAndRegionMap", regionIdAndRegionMap);
24417 govind 262
		return "create-position";
263
	}
24500 govind 264
 
24471 govind 265
	@GetMapping(value = "/cs/position-paginated")
24500 govind 266
	public String positionPaginated(HttpServletRequest request,
267
			@RequestParam(name = "offset", defaultValue = "0") int offset,
24471 govind 268
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model) {
24500 govind 269
 
270
		List<Position> positions = positionRepository.selectAll(offset, limit);
271
		Map<Integer, AuthUser> authUserIdAndAuthUserMap = csService
272
				.getAuthUserIdAndAuthUserMapUsingPositions(positions);
273
		Map<Integer, TicketCategory> categoryIdAndCategoryMap = csService
274
				.getCategoryIdAndCategoryUsingPositions(positions);
275
		Map<Integer, Region> regionIdAndRegionMap = csService.getRegionIdAndRegionMap(positions);
24471 govind 276
		model.addAttribute("positions", positions);
277
		model.addAttribute("authUserIdAndAuthUserMap", authUserIdAndAuthUserMap);
278
		model.addAttribute("categoryIdAndCategoryMap", categoryIdAndCategoryMap);
279
		model.addAttribute("regionIdAndRegionMap", regionIdAndRegionMap);
280
		return "position-paginated";
281
	}
24417 govind 282
 
283
	@PostMapping(value = "/cs/createPosition")
284
	public String createPosition(HttpServletRequest request, @RequestParam(name = "authUserId") int authUserId,
285
			@RequestParam(name = "categoryId") int categoryId,
286
			@RequestParam(name = "escalationType") EscalationType escalationType,
287
			@RequestParam(name = "regionId") int regionId, Model model) throws Exception {
288
 
289
		Position position = positionRepository.selectPosition(authUserId, categoryId, regionId, escalationType);
290
		if (position == null) {
291
			position = new Position();
292
			position.setAuthUserId(authUserId);
293
			position.setCategoryId(categoryId);
294
			position.setEscalationType(escalationType);
295
			position.setRegionId(regionId);
296
			position.setCreateTimestamp(LocalDateTime.now());
297
			positionRepository.persist(position);
298
			model.addAttribute("response", mvcResponseSender.createResponseString(true));
299
		} else {
300
			throw new ProfitMandiBusinessException("Position", authUserId, "already exists!");
301
		}
302
		return "response";
303
	}
304
 
305
	@GetMapping(value = "/cs/createTicket")
306
	public String createTicket(HttpServletRequest request, Model model) {
24500 govind 307
		List<TicketCategory> ticketCategories = csService.getAllTicketCategotyFromSubCategory();
24417 govind 308
		model.addAttribute("ticketCategories", ticketCategories);
309
		return "create-ticket";
310
	}
311
 
312
	@GetMapping(value = "/cs/getSubCategoriesByCategoryId")
313
	public String getSubCategoriesByCategoryId(HttpServletRequest request,
314
			@RequestParam(name = "categoryId", defaultValue = "0") int categoryId, Model model) {
315
		List<TicketSubCategory> ticketSubCategories = ticketSubCategoryRepository.selectAll(categoryId);
316
		LOGGER.info(ticketSubCategories);
317
		model.addAttribute("ticketSubCategories", ticketSubCategories);
318
		return "ticket-sub-categories";
319
	}
320
 
321
	@PostMapping(value = "/cs/createTicket")
322
	public String createTicket(HttpServletRequest request, @RequestParam(name = "categoryId") int categoryId,
323
			@RequestParam(name = "subCategoryId") int subCategoryId, @RequestParam(name = "message") String message,
324
			Model model) throws Exception {
325
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
24747 govind 326
		List<Ticket> tickets = ticketRepository.selectAllByCreator(loginDetails.getFofoId(), Optional.of(true),
327
				SortOrder.DESCENDING, 0, 10);
24620 govind 328
		if (tickets.size() > 3 || tickets.size() == 3) {
329
			model.addAttribute("response", mvcResponseSender.createResponseString(false));
330
		} else {
331
			csService.createTicket(loginDetails.getFofoId(), categoryId, subCategoryId, message);
332
			model.addAttribute("response", mvcResponseSender.createResponseString(true));
333
		}
24417 govind 334
		return "response";
335
	}
336
 
337
	@GetMapping(value = "/cs/myticket")
24699 govind 338
	public String getTicket(HttpServletRequest request,
339
			@RequestParam(name = "orderby", defaultValue = "DESCENDING") SortOrder sortOrder,
340
			@RequestParam(name = "ticketStatus", defaultValue = "OPENED") TicketStatus ticketStatus,
24787 govind 341
			@RequestParam(name = "ticketSearchType", defaultValue = "") TicketSearchType ticketSearchType,
342
			@RequestParam(name = "searchTerm", defaultValue = "0") int searchTerm,
24699 govind 343
			@RequestParam(name = "offset", defaultValue = "0") int offset,
24417 govind 344
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
345
			throws ProfitMandiBusinessException {
346
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
347
		List<Ticket> tickets = null;
24500 govind 348
		List<TicketAssigned> ticketAssigneds = null;
24747 govind 349
		// List<Integer> ticketIds = null;
24417 govind 350
		long size = 0;
24500 govind 351
		Map<Integer, AuthUser> authUserIdAndAuthUserMap = null;
352
		// LOGGER.info(roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds()))));
24417 govind 353
		if (roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds()))) {
354
			AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
24787 govind 355
			if (ticketSearchType == null) {
356
					tickets = ticketRepository.selectAllByAssignee(authUser.getId(),
357
							Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, null, searchTerm, offset,
358
							limit);
359
					size = ticketRepository.selectAllCountByAssignee(authUser.getId(),
360
							Optional.of(TicketStatus.OPENED.equals(ticketStatus)), null, searchTerm);
361
 
362
			} else {
363
 
364
					tickets = ticketRepository.selectAllByAssignee(authUser.getId(),
365
							Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, ticketSearchType,
366
							searchTerm, offset, limit);
367
					size = ticketRepository.selectAllCountByAssignee(authUser.getId(),
368
							Optional.of(TicketStatus.OPENED.equals(ticketStatus)), ticketSearchType, searchTerm);
369
 
370
			}
24620 govind 371
			LOGGER.info(size + "size");
24787 govind 372
			if(tickets.size()>0) {
24747 govind 373
			ticketAssigneds = ticketAssignedRepository
374
					.selectByTicketIds(tickets.stream().map(x -> x.getId()).collect(Collectors.toList()));
24500 govind 375
			authUserIdAndAuthUserMap = csService.getAuthUserIdAndAuthUserMap(ticketAssigneds);
24620 govind 376
			Map<Integer, CustomRetailer> fofoIdsAndCustomRetailer = csService.getPartnerByFofoIds(tickets);
377
			model.addAttribute("fofoIdsAndCustomRetailer", fofoIdsAndCustomRetailer);
24787 govind 378
			}
24620 govind 379
 
24417 govind 380
		} else {
24699 govind 381
			LOGGER.info(ticketStatus);
382
			LOGGER.info(sortOrder);
24751 govind 383
			LOGGER.info(TicketStatus.OPENED.equals(ticketStatus));
24699 govind 384
			tickets = ticketRepository.selectAllByCreator(loginDetails.getFofoId(),
24751 govind 385
					Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, offset, limit);
24699 govind 386
			size = ticketRepository.selectAllCountByCreator(loginDetails.getFofoId(),
24751 govind 387
					Optional.of(TicketStatus.OPENED.equals(ticketStatus)));
24699 govind 388
		}
389
		authUserIdAndAuthUserMap = csService.getTicketIdAndAuthUserMapUsingTickets(tickets);
24500 govind 390
 
24417 govind 391
		if (size < limit) {
392
			model.addAttribute("end", offset + size);
393
		} else {
394
			model.addAttribute("end", offset + limit);
395
		}
396
		model.addAttribute("start", offset + 1);
397
		model.addAttribute("size", size);
24500 govind 398
		model.addAttribute("roleType", roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds())));
24417 govind 399
		Map<Integer, TicketSubCategory> subCategoryIdAndSubCategoryMap = csService
400
				.getSubCategoryIdAndSubCategoryMap(tickets);
401
		model.addAttribute("tickets", tickets);
24620 govind 402
		model.addAttribute("resolved", ActivityType.RESOLVED);
403
		model.addAttribute("resolved-accepted", ActivityType.RESOLVED_ACCEPTED);
404
		model.addAttribute("resolved-rejected", ActivityType.RESOLVED_REJECTED);
24417 govind 405
		model.addAttribute("authUserIdAndAuthUserMap", authUserIdAndAuthUserMap);
406
		model.addAttribute("subCategoryIdAndSubCategoryMap", subCategoryIdAndSubCategoryMap);
24699 govind 407
		model.addAttribute("ticketStatusValues", TicketStatus.values());
408
		model.addAttribute("orderByValues", SortOrder.values());
409
		model.addAttribute("selectedticketStatus", ticketStatus);
410
		model.addAttribute("selectedorderby", sortOrder);
24787 govind 411
		model.addAttribute("ticketSearchTypes", TicketSearchType.values());
412
		model.addAttribute("ticketSearchType", ticketSearchType);
413
		model.addAttribute("searchTerm", searchTerm);
24417 govind 414
		return "ticket";
415
	}
24500 govind 416
 
24417 govind 417
	@GetMapping(value = "/cs/myticketPaginated")
24500 govind 418
	public String getMyTicketPaginated(HttpServletRequest request,
24699 govind 419
			@RequestParam(name = "orderby", defaultValue = "DESCENDING") SortOrder sortOrder,
420
			@RequestParam(name = "ticketStatus", defaultValue = "OPENED") TicketStatus ticketStatus,
24787 govind 421
			@RequestParam(name = "ticketSearchType", defaultValue = "") TicketSearchType ticketSearchType,
422
			@RequestParam(name = "searchTerm", defaultValue = "0") int searchTerm,
24500 govind 423
			@RequestParam(name = "offset", defaultValue = "0") int offset,
24417 govind 424
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
425
			throws ProfitMandiBusinessException {
426
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
427
		List<Ticket> tickets = null;
24500 govind 428
		List<TicketAssigned> ticketAssigneds = null;
24747 govind 429
		// List<Integer> ticketIds = null;
24500 govind 430
		Map<Integer, AuthUser> authUserIdAndAuthUserMap = null;
431
		// LOGGER.info(roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds()))));
24417 govind 432
		if (roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds()))) {
433
			AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
24787 govind 434
 
435
			if (ticketSearchType == null) {
436
				tickets = ticketRepository.selectAllByAssignee(authUser.getId(),
437
						Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, null, searchTerm, offset,
438
						limit);
439
			} else {
440
				tickets = ticketRepository.selectAllByAssignee(authUser.getId(),
441
						Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, ticketSearchType, searchTerm,
442
						offset, limit);
443
			}
24747 govind 444
			ticketAssigneds = ticketAssignedRepository
445
					.selectByTicketIds(tickets.stream().map(x -> x.getId()).collect(Collectors.toList()));
24620 govind 446
			authUserIdAndAuthUserMap = csService.getAuthUserIdAndAuthUserMap(ticketAssigneds);
447
			Map<Integer, CustomRetailer> fofoIdsAndCustomRetailer = csService.getPartnerByFofoIds(tickets);
448
			model.addAttribute("fofoIdsAndCustomRetailer", fofoIdsAndCustomRetailer);
24417 govind 449
		} else {
24747 govind 450
			tickets = ticketRepository.selectAllByCreator(loginDetails.getFofoId(),
24751 govind 451
					Optional.of(TicketStatus.OPENED.equals(ticketStatus)), sortOrder, offset, limit);
24500 govind 452
			authUserIdAndAuthUserMap = csService.getTicketIdAndAuthUserMapUsingTickets(tickets);
24417 govind 453
		}
24500 govind 454
		model.addAttribute("roleType", roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds())));
24417 govind 455
		Map<Integer, TicketSubCategory> subCategoryIdAndSubCategoryMap = csService
456
				.getSubCategoryIdAndSubCategoryMap(tickets);
457
		model.addAttribute("tickets", tickets);
458
		model.addAttribute("authUserIdAndAuthUserMap", authUserIdAndAuthUserMap);
459
		model.addAttribute("subCategoryIdAndSubCategoryMap", subCategoryIdAndSubCategoryMap);
24699 govind 460
		model.addAttribute("resolved", ActivityType.RESOLVED);
461
		model.addAttribute("resolved-accepted", ActivityType.RESOLVED_ACCEPTED);
462
		model.addAttribute("resolved-rejected", ActivityType.RESOLVED_REJECTED);
24417 govind 463
		return "ticket-paginated";
464
	}
465
 
466
	@GetMapping(value = "/cs/getActivities")
467
	public String getActivity(HttpServletRequest request,
468
			@RequestParam(name = "ticketId", defaultValue = "0") int ticketId, Model model) throws Exception {
469
		List<Activity> activities = activityRepository.selectAll(ticketId);
24572 amit.gupta 470
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
24620 govind 471
		if (roleManager.isAdmin(loginDetails.getRoleIds())) {
472
			Set<Integer> authUserIds = activities.stream().map(x -> x.getCreatedBy()).collect(Collectors.toSet());
24572 amit.gupta 473
			List<AuthUser> users = authRepository.selectAllAuthUserByIds(new ArrayList<>(authUserIds));
24620 govind 474
			Map<Integer, String> authUserNameMap = users.stream()
475
					.collect(Collectors.toMap(AuthUser::getId, x -> x.getFirstName() + " " + x.getLastName()));
476
			activities.stream().forEach(x -> x.setName(authUserNameMap.get(x.getCreatedBy())));
24572 amit.gupta 477
		}
24417 govind 478
		if (activities == null) {
479
			throw new ProfitMandiBusinessException("Activity", ticketId, "No Activity Found");
480
		}
481
		model.addAttribute("response", mvcResponseSender.createResponseString(activities));
482
		return "response";
483
 
484
	}
485
 
486
	@PostMapping(value = "/cs/createActivity")
487
	public String createActivity(HttpServletRequest request,
488
			@RequestParam(name = "ticketId", defaultValue = "0") int ticketId,
24500 govind 489
			@RequestParam(name = "assigneeId", defaultValue = "0") int assigneeId,
24417 govind 490
			@RequestParam(name = "message", defaultValue = "") String message, Model model) throws Exception {
491
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
24500 govind 492
		Ticket ticket = ticketRepository.selectById(ticketId);
493
		if (ticket.getCloseTimestamp() == null) {
494
			if (!roleManager.isAdmin(new HashSet<>(loginDetails.getRoleIds()))) {
495
				Activity activity = new Activity();
496
				activity.setMessage(message);
497
				activity.setCreatedBy(0);
498
				activity.setCreateTimestamp(LocalDateTime.now());
499
				activity.setType(ActivityType.COMMUNICATION_IN);
500
				csService.addActivity(ticketId, activity);
24620 govind 501
				AuthUser authUser = authRepository.selectById(ticket.getL1AuthUser());
502
				String subject = String.format(ACTIVITY_SUBJECT, ticket.getId());
503
				String[] cc = { authRepository.selectById(ticket.getL2AuthUser()).getEmailId(),
504
						authRepository.selectById(ticket.getL3AuthUser()).getEmailId() };
505
				// LOGGER.info(authUser.getEmailId()+" "+cc+" "+subject+" "+message);
506
				this.activityRelatedMail(authUser.getEmailId(), cc, subject, message);
24500 govind 507
				model.addAttribute("response", mvcResponseSender.createResponseString(authUser));
508
			} else {
509
				AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
510
				Activity activity = new Activity();
511
				activity.setMessage(message);
512
				activity.setCreatedBy(authUser.getId());
513
				activity.setCreateTimestamp(LocalDateTime.now());
514
				activity.setType(ActivityType.COMMUNICATION_OUT);
515
				csService.addActivity(ticketId, activity);
24620 govind 516
				String subject = String.format(ACTIVITY_SUBJECT, ticket.getId());
517
				LOGGER.info(authUser.getEmailId() + " " + subject + " " + message);
518
				this.activityRelatedMail(retailerService.getFofoRetailer(ticket.getFofoId()).getEmail(), null, subject,
519
						message);
24500 govind 520
				model.addAttribute("response", mvcResponseSender.createResponseString(authUser));
521
			}
24417 govind 522
		} else {
523
			throw new ProfitMandiBusinessException("Ticket", ticket.getId(), "Already closed ticket");
524
		}
525
		return "response";
526
	}
24500 govind 527
 
24620 govind 528
	private void activityRelatedMail(String to, String[] cc, String subject, String message)
529
			throws ProfitMandiBusinessException {
530
		try {
531
			Utils.sendMailWithAttachments(mailSender, to, cc, subject, message, null);
532
		} catch (Exception e) {
533
			throw new ProfitMandiBusinessException("Ticket Activity", to, "Could not send ticket activity mail");
534
		}
535
	}
536
 
24500 govind 537
	@PostMapping(value = "/cs/closeTicket")
24417 govind 538
	public String closeTicket(HttpServletRequest request,
24439 govind 539
			@RequestParam(name = "ticketId", defaultValue = "0") int ticketId,
24500 govind 540
			@RequestParam(name = "happyCode") String happyCode, Model model) throws Exception {
541
		Ticket ticket = ticketRepository.selectById(ticketId);
542
		if (ticket.getHappyCode().equals(happyCode)) {
543
			ticket.setCloseTimestamp(LocalDateTime.now());
544
			ticketRepository.persist(ticket);
545
			model.addAttribute("response", mvcResponseSender.createResponseString(true));
546
		} else {
547
			throw new ProfitMandiBusinessException("Ticket", ticketId, "Happy Code can't match");
24439 govind 548
		}
24417 govind 549
		return "response";
550
	}
24500 govind 551
 
552
	@GetMapping(value = "/cs/managerTicket")
553
	public String getL2L3AndL4Tickets(HttpServletRequest request,
24699 govind 554
			@RequestParam(name = "orderby", defaultValue = "DESCENDING") SortOrder sortOrder,
555
			@RequestParam(name = "ticketStatus", defaultValue = "OPENED") TicketStatus ticketStatus,
24747 govind 556
			@RequestParam(name = "ticketSearchType", defaultValue = "") TicketSearchType ticketSearchType,
557
			@RequestParam(name = "searchTerm", defaultValue = "0") int searchTerm,
24500 govind 558
			@RequestParam(name = "offset", defaultValue = "0") int offset,
559
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
560
			throws ProfitMandiBusinessException {
24439 govind 561
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
562
		long size = 0;
24500 govind 563
		AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
564
		List<Ticket> tickets = null;
24569 govind 565
		Map<Integer, List<AuthUser>> authUserListMap = null;
24500 govind 566
		if (loginDetails.getEmailId().equals("amandeep.singh@smartdukaan.com")) {
567
			tickets = ticketRepository.selectAll(offset, limit, Optional.empty());
24620 govind 568
			authUserListMap = csService.getAuthUserList(tickets, authUser);
24500 govind 569
			size = ticketRepository.selectAllCount();
570
		} else {
24747 govind 571
			if (ticketSearchType == null) {
24787 govind 572
				if (ticketStatus.equals(TicketStatus.RESOLVED)) {
573
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder, Optional.empty(),
574
							null, searchTerm, offset, limit);
575
					size = ticketRepository.selectAllCountByManagerTicket(authUser.getId(), Optional.empty(), null, 0);
576
				} else {
577
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder,
578
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), null, searchTerm, offset, limit);
579
					size = ticketRepository.selectAllCountByManagerTicket(authUser.getId(),
580
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), null, 0);
581
				}
24747 govind 582
			} else {
24787 govind 583
				if (ticketStatus.equals(TicketStatus.RESOLVED)) {
584
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder, Optional.empty(),
585
							ticketSearchType, searchTerm, offset, limit);
586
					size = ticketRepository.selectAllCountByManagerTicket(authUser.getId(), Optional.empty(),
587
							ticketSearchType, searchTerm);
588
				} else {
589
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder,
590
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), ticketSearchType, searchTerm, offset,
591
							limit);
592
					size = ticketRepository.selectAllCountByManagerTicket(authUser.getId(),
593
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), ticketSearchType, searchTerm);
594
				}
595
 
24747 govind 596
			}
24620 govind 597
			authUserListMap = csService.getAuthUserList(tickets, authUser);
24747 govind 598
 
24620 govind 599
			if (tickets.size() > 0) {
600
				Map<Integer, CustomRetailer> fofoIdsAndCustomRetailer = csService.getPartnerByFofoIds(tickets);
601
				model.addAttribute("fofoIdsAndCustomRetailer", fofoIdsAndCustomRetailer);
24439 govind 602
			}
603
		}
604
		if (size < limit) {
605
			model.addAttribute("end", offset + size);
606
		} else {
607
			model.addAttribute("end", offset + limit);
608
		}
609
		model.addAttribute("start", offset + 1);
610
		model.addAttribute("size", size);
611
		model.addAttribute("tickets", tickets);
24500 govind 612
 
24439 govind 613
		Map<Integer, TicketSubCategory> subCategoryIdAndSubCategoryMap = csService
614
				.getSubCategoryIdAndSubCategoryMap(tickets);
24699 govind 615
		model.addAttribute("ticketStatusValues", TicketStatus.values());
616
		model.addAttribute("orderByValues", SortOrder.values());
617
		model.addAttribute("selectedticketStatus", ticketStatus);
618
		model.addAttribute("selectedorderby", sortOrder);
24439 govind 619
		model.addAttribute("tickets", tickets);
24747 govind 620
		model.addAttribute("ticketSearchTypes", TicketSearchType.values());
24750 govind 621
		model.addAttribute("ticketSearchType", ticketSearchType);
24747 govind 622
		model.addAttribute("searchTerm", searchTerm);
24500 govind 623
		model.addAttribute("authUserListMap", authUserListMap);
24439 govind 624
		model.addAttribute("subCategoryIdAndSubCategoryMap", subCategoryIdAndSubCategoryMap);
625
		return "managerTicket";
626
	}
24500 govind 627
 
628
	@GetMapping(value = "/cs/managerTicket-paginated")
629
	public String getL2L3AndL4TicketsPaginated(HttpServletRequest request,
24699 govind 630
			@RequestParam(name = "orderby", defaultValue = "DESCENDING") SortOrder sortOrder,
631
			@RequestParam(name = "ticketStatus", defaultValue = "OPENED") TicketStatus ticketStatus,
24747 govind 632
			@RequestParam(name = "ticketSearchType", defaultValue = "") TicketSearchType ticketSearchType,
633
			@RequestParam(name = "searchTerm", defaultValue = "0") int searchTerm,
24500 govind 634
			@RequestParam(name = "offset", defaultValue = "0") int offset,
635
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
636
			throws ProfitMandiBusinessException {
24467 govind 637
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
24500 govind 638
		AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
24557 govind 639
		Map<Integer, List<AuthUser>> authUserListMap = null;
24500 govind 640
		List<Ticket> tickets = null;
641
		if (loginDetails.getEmailId().equals("amandeep.singh@smartdukaan.com")) {
642
			tickets = ticketRepository.selectAll(offset, limit, Optional.empty());
24620 govind 643
			authUserListMap = csService.getAuthUserList(tickets, authUser);
24500 govind 644
		} else {
24747 govind 645
			if (ticketSearchType == null) {
24787 govind 646
				if (ticketStatus.equals(TicketStatus.RESOLVED)) {
647
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder, Optional.empty(),
648
							null, searchTerm, offset, limit);
649
 
650
				} else {
651
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder,
652
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), null, searchTerm, offset, limit);
653
 
654
				}
24747 govind 655
			} else {
24787 govind 656
				if (ticketStatus.equals(TicketStatus.RESOLVED)) {
657
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder, Optional.empty(),
658
							ticketSearchType, searchTerm, offset, limit);
659
 
660
				} else {
661
					tickets = ticketRepository.selectAllManagerTicket(authUser.getId(), sortOrder,
662
							Optional.of(TicketStatus.CLOSED.equals(ticketStatus)), ticketSearchType, searchTerm, offset,
663
							limit);
664
				}
665
 
24747 govind 666
			}
24620 govind 667
			authUserListMap = csService.getAuthUserList(tickets, authUser);
668
			if (tickets.size() > 0) {
24500 govind 669
				Map<Integer, CustomRetailer> fofoIdsAndCustomRetailer = csService.getPartnerByFofoIds(tickets);
24467 govind 670
				model.addAttribute("fofoIdsAndCustomRetailer", fofoIdsAndCustomRetailer);
24620 govind 671
			}
24467 govind 672
		}
673
		model.addAttribute("tickets", tickets);
674
		Map<Integer, TicketSubCategory> subCategoryIdAndSubCategoryMap = csService
675
				.getSubCategoryIdAndSubCategoryMap(tickets);
676
		model.addAttribute("tickets", tickets);
24500 govind 677
		model.addAttribute("authUserListMap", authUserListMap);
24467 govind 678
		model.addAttribute("subCategoryIdAndSubCategoryMap", subCategoryIdAndSubCategoryMap);
679
		return "managerTicket-paginated";
680
	}
24500 govind 681
 
682
	@GetMapping(value = "/cs/edit-ticket")
683
	public String getEditTicket(HttpServletRequest request,
684
			@RequestParam(name = "ticketId", defaultValue = "0") int ticketId, Model model) {
685
		Ticket ticket = ticketRepository.selectById(ticketId);
686
		List<TicketCategory> ticketCategories = csService.getAllTicketCategotyFromSubCategory();
687
		TicketSubCategory ticketSubCategory = ticketSubCategoryRepository.selectById(ticket.getSubCategoryId());
688
		List<TicketSubCategory> ticketSubCategories = ticketSubCategoryRepository
689
				.selectAll(ticketSubCategory.getcategoryId());
24569 govind 690
		List<AuthUser> authUsers = authRepository.selectAll();
24467 govind 691
		model.addAttribute("ticket", ticket);
692
		model.addAttribute("ticketCategories", ticketCategories);
693
		model.addAttribute("ticketSubCategories", ticketSubCategories);
24575 govind 694
		model.addAttribute("ticketSubCategory", ticketSubCategory);
24500 govind 695
		model.addAttribute("authUsers", authUsers);
24467 govind 696
		return "edit-ticket-modal";
697
	}
24500 govind 698
 
699
	@PostMapping(value = "/cs/edit-ticket")
700
	public String editTicket(HttpServletRequest request,
701
			@RequestParam(name = "ticketId", defaultValue = "0") int ticketId,
702
			@RequestParam(name = "subCategoryId", defaultValue = "0") int subCategoryId,
703
			@RequestParam(name = "categoryId", defaultValue = "0") int categoryId,
704
			@RequestParam(name = "authUserId", defaultValue = "0") int authUserId, Model model) throws Exception {
24467 govind 705
		LOGGER.info(ticketId);
24500 govind 706
		Ticket ticket = ticketRepository.selectById(ticketId);
24569 govind 707
		ticketAssignedRepository.deleteByTicketId(ticketId);
708
		if (ticket.getSubCategoryId() == subCategoryId) {
709
			LOGGER.info(ticket);
710
			TicketAssigned ticketAssigned = new TicketAssigned();
24500 govind 711
			ticketAssigned.setTicketId(ticketId);
712
			ticketAssigned.setAssineeId(authUserId);
713
			ticketAssignedRepository.persist(ticketAssigned);
24569 govind 714
			ticket.setL1AuthUser(authUserId);
715
			ticket.setSubCategoryId(subCategoryId);
716
			ticket.setUpdateTimestamp(LocalDateTime.now());
717
			ticket.setL2EscalationTimestamp(ticket.getUpdateTimestamp().plusDays(2));
718
			ticket.setL3EscalationTimestamp(ticket.getL2EscalationTimestamp().plusDays(2));
719
			ticket.setLastEscalationTimestamp(ticket.getL3EscalationTimestamp().plusDays(2));
720
			ticketRepository.persist(ticket);
721
			csService.sendAssignedTicketMail(authRepository.selectById(authUserId), ticket);
24500 govind 722
			model.addAttribute("response", mvcResponseSender.createResponseString(true));
24569 govind 723
		} else {
724
			csService.updateTicket(categoryId, subCategoryId, ticket);
725
			model.addAttribute("response", mvcResponseSender.createResponseString(true));
24500 govind 726
		}
24467 govind 727
		return "response";
728
	}
24500 govind 729
 
730
	@DeleteMapping(value = "/cs/removePosition")
731
	public String removePosition(HttpServletRequest request,
732
			@RequestParam(name = "positionId", defaultValue = "0") int positionId, Model model) throws Exception {
24471 govind 733
		positionRepository.delete(positionId);
734
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
735
		return "response";
736
	}
24620 govind 737
 
738
	@PostMapping(value = "/cs/create-last-activity")
739
	public String createlastActivity(HttpServletRequest request, @RequestParam(name = "ticketId") int ticketId,
740
			@RequestParam(name = "lastactivity") ActivityType lastActivity, Model model) throws Exception {
741
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
742
		Ticket ticket = ticketRepository.selectById(ticketId);
743
		Activity activity = new Activity();
744
		String subject = String.format(ACTIVITY_SUBJECT, ticket.getId());
745
		if (roleManager.isAdmin(loginDetails.getRoleIds())) {
746
			ticket.setLastActivity(lastActivity);
747
			String to = retailerService.getFofoRetailer(ticket.getFofoId()).getEmail();
24699 govind 748
			String message = String.format(PARTNER_RESOLVED_TICKET_MAIL, ticketId, "REOPEN");
24620 govind 749
			activity.setMessage(message);
750
			activity.setCreatedBy(authRepository.selectByEmailOrMobile(loginDetails.getEmailId()).getId());
751
			activity.setTicketId(ticketId);
752
			activity.setCreateTimestamp(LocalDateTime.now());
753
			activity.setType(ActivityType.COMMUNICATION_OUT);
24621 govind 754
			this.activityRelatedMail(to, null, subject, message);
24620 govind 755
		} else {
756
			if (ActivityType.RESOLVED_ACCEPTED == lastActivity) {
757
				ticket.setLastActivity(lastActivity);
758
				ticket.setCloseTimestamp(LocalDateTime.now());
759
				activity.setMessage(ActivityType.RESOLVED.toString());
760
				activity.setCreatedBy(0);
761
				activity.setTicketId(ticketId);
762
				activity.setType(ActivityType.COMMUNICATION_IN);
763
				activity.setCreateTimestamp(LocalDateTime.now());
764
			} else {
24699 govind 765
				String message = String.format(INTERNAL_REOPEN_MAIL, ticketId,
766
						retailerService.getFofoRetailer(loginDetails.getFofoId()).getBusinessName());
24620 govind 767
				String to = authRepository.selectById(ticket.getL1AuthUser()).getEmailId();
768
				String cc[] = { authRepository.selectById(ticket.getL2AuthUser()).getEmailId(),
769
						authRepository.selectById(ticket.getL3AuthUser()).getEmailId() };
770
				ticket.setLastActivity(lastActivity);
24638 govind 771
				ticket.setUpdateTimestamp(LocalDateTime.now());
772
				ticket.setL2EscalationTimestamp(ticket.getUpdateTimestamp().plusDays(2));
773
				ticket.setL3EscalationTimestamp(ticket.getL2EscalationTimestamp().plusDays(2));
774
				ticket.setLastEscalationTimestamp(ticket.getL3EscalationTimestamp().plusDays(2));
775
				ticketAssignedRepository.deleteByTicketId(ticketId);
24699 govind 776
				TicketAssigned ticketAssigned = new TicketAssigned();
24638 govind 777
				ticketAssigned.setAssineeId(ticket.getL1AuthUser());
778
				ticketAssigned.setTicketId(ticketId);
779
				ticketAssignedRepository.persist(ticketAssigned);
24620 govind 780
				activity.setMessage(INTERNAL_REOPEN_ACTIVITY_MESSAGE);
781
				activity.setCreatedBy(0);
782
				activity.setTicketId(ticketId);
783
				activity.setType(ActivityType.COMMUNICATION_IN);
784
				activity.setCreateTimestamp(LocalDateTime.now());
24621 govind 785
				this.activityRelatedMail(to, cc, subject, message);
24699 govind 786
				this.activityRelatedMail(retailerService.getFofoRetailer(loginDetails.getFofoId()).getEmail(), null,
787
						subject, String.format(PARTNER_REOPEN, ticketId));
24620 govind 788
			}
789
 
790
		}
791
		ticketRepository.persist(ticket);
792
		activityRepository.persist(activity);
793
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
794
		return "response";
795
	}
796
 
24417 govind 797
}