mirror of
				https://github.com/MewoLab/AquaDX.git
				synced 2025-10-25 20:12:39 +00:00 
			
		
		
		
	[O] Rewrite chusan item handler
This commit is contained in:
		
							parent
							
								
									b41f3b9370
								
							
						
					
					
						commit
						15002c45d6
					
				| @ -1,67 +0,0 @@ | |||||||
| package icu.samnyan.aqua.sega.chusan.handler; |  | ||||||
| 
 |  | ||||||
| import com.fasterxml.jackson.core.JsonProcessingException; |  | ||||||
| import icu.samnyan.aqua.sega.general.BaseHandler; |  | ||||||
| import icu.samnyan.aqua.sega.chusan.model.userdata.UserItem; |  | ||||||
| import icu.samnyan.aqua.sega.chusan.service.UserItemService; |  | ||||||
| import icu.samnyan.aqua.sega.util.jackson.StringMapper; |  | ||||||
| import org.slf4j.Logger; |  | ||||||
| import org.slf4j.LoggerFactory; |  | ||||||
| import org.springframework.data.domain.Page; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
| 
 |  | ||||||
| import java.util.LinkedHashMap; |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.Map; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Handler for getting user item. |  | ||||||
|  * This get call before profile create. |  | ||||||
|  * |  | ||||||
|  * @author samnyan (privateamusement@protonmail.com) |  | ||||||
|  */ |  | ||||||
| @Component("ChusanGetUserItemHandler") |  | ||||||
| public class GetUserItemHandler implements BaseHandler { |  | ||||||
| 
 |  | ||||||
|     private static final Logger logger = LoggerFactory.getLogger(GetUserItemHandler.class); |  | ||||||
| 
 |  | ||||||
|     private final StringMapper mapper; |  | ||||||
| 
 |  | ||||||
|     private final UserItemService userItemService; |  | ||||||
| 
 |  | ||||||
|     public GetUserItemHandler(StringMapper mapper, UserItemService userItemService) { |  | ||||||
|         this.mapper = mapper; |  | ||||||
|         this.userItemService = userItemService; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public String handle(Map<String, Object> request) throws JsonProcessingException { |  | ||||||
|         String userId = (String) request.get("userId"); |  | ||||||
|         Long nextIndexVal = Long.parseLong((String) request.get("nextIndex")); |  | ||||||
|         int maxCount = Integer.parseInt((String) request.get("maxCount")); |  | ||||||
| 
 |  | ||||||
|         Long mul = 10000000000L; |  | ||||||
| 
 |  | ||||||
|         int kind = (int) (nextIndexVal / mul); |  | ||||||
|         int nextIndex = (int) (nextIndexVal % mul); |  | ||||||
|         int pageNum = nextIndex / maxCount; |  | ||||||
| 
 |  | ||||||
|         Page<UserItem> userItemPage = userItemService.getByUserAndItemKind(userId, kind, pageNum, maxCount); |  | ||||||
| 
 |  | ||||||
|         List<UserItem> userItemList = userItemPage.getContent(); |  | ||||||
| 
 |  | ||||||
|         long currentIndex = kind * mul + maxCount * pageNum + userItemPage.getNumberOfElements(); |  | ||||||
| 
 |  | ||||||
|         Map<String, Object> resultMap = new LinkedHashMap<>(); |  | ||||||
|         resultMap.put("userId", userId); |  | ||||||
|         resultMap.put("length", userItemPage.getNumberOfElements()); |  | ||||||
|         resultMap.put("nextIndex", userItemPage.getNumberOfElements() < maxCount ? -1 : currentIndex); |  | ||||||
|         resultMap.put("itemKind", kind); |  | ||||||
|         resultMap.put("userItemList", userItemList); |  | ||||||
| 
 |  | ||||||
|         String json = mapper.write(resultMap); |  | ||||||
|         logger.info("Response: " + json); |  | ||||||
|         return json; |  | ||||||
| 
 |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -0,0 +1,55 @@ | |||||||
|  | package icu.samnyan.aqua.sega.chusan.handler | ||||||
|  | 
 | ||||||
|  | import com.fasterxml.jackson.core.JsonProcessingException | ||||||
|  | import ext.int | ||||||
|  | import ext.long | ||||||
|  | import icu.samnyan.aqua.sega.chusan.service.UserItemService | ||||||
|  | import icu.samnyan.aqua.sega.general.BaseHandler | ||||||
|  | import icu.samnyan.aqua.sega.util.jackson.StringMapper | ||||||
|  | import org.slf4j.Logger | ||||||
|  | import org.slf4j.LoggerFactory | ||||||
|  | import org.springframework.stereotype.Component | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Handler for getting user item. | ||||||
|  |  * This get call before profile create. | ||||||
|  |  * | ||||||
|  |  * @author samnyan (privateamusement@protonmail.com) | ||||||
|  |  */ | ||||||
|  | @Component("ChusanGetUserItemHandler") | ||||||
|  | class GetUserItemHandler(private val mapper: StringMapper, private val userItemService: UserItemService) : BaseHandler { | ||||||
|  |     @Throws(JsonProcessingException::class) | ||||||
|  |     override fun handle(request: Map<String, Any>): String { | ||||||
|  |         val userId = request["userId"].toString() | ||||||
|  |         val nextIndexVal = request["nextIndex"]?.long() ?: 0 | ||||||
|  |         val maxCount = request["maxCount"]?.int() ?: 100 | ||||||
|  | 
 | ||||||
|  |         val mul = 10000000000L | ||||||
|  | 
 | ||||||
|  |         val kind = (nextIndexVal / mul).toInt() | ||||||
|  |         val nextIndex = (nextIndexVal % mul).toInt() | ||||||
|  |         val pageNum = nextIndex / maxCount | ||||||
|  | 
 | ||||||
|  |         val userItemPage = userItemService.getByUserAndItemKind(userId, kind, pageNum, maxCount) | ||||||
|  |         val userItemList = userItemPage.content | ||||||
|  |         val currentIndex = kind * mul + maxCount * pageNum + userItemPage.numberOfElements | ||||||
|  | 
 | ||||||
|  |         // TODO: Music unlock | ||||||
|  | 
 | ||||||
|  |         val resultMap = mapOf( | ||||||
|  |             "userId" to userId, | ||||||
|  |             "length" to userItemPage.numberOfElements, | ||||||
|  |             "nextIndex" to if (userItemPage.numberOfElements < maxCount) -1 else currentIndex, | ||||||
|  |             "itemKind" to kind, | ||||||
|  |             "userItemList" to userItemList | ||||||
|  |         ) | ||||||
|  | 
 | ||||||
|  |         val json = mapper.write(resultMap) | ||||||
|  |         logger.info("Response: $json") | ||||||
|  |         return json | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     companion object { | ||||||
|  |         private val logger: Logger = LoggerFactory.getLogger(GetUserItemHandler::class.java) | ||||||
|  |     } | ||||||
|  | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Azalea
						Azalea