From b963595ab4ab0170b5f4e0233d5c3ce9183d19b1 Mon Sep 17 00:00:00 2001
From: Phan Huy Tran
Date: Wed, 2 Apr 2025 11:04:20 +0200
Subject: [PATCH] feat: manage balance
---
backend/requests/lootboxes.http | 5 ++
.../de/szut/casino/CasinoApplication.java | 21 +++----
.../casino/lootboxes/LootBoxController.java | 62 ++++++++++++++++++-
.../src/main/resources/application.properties | 2 +-
4 files changed, 75 insertions(+), 15 deletions(-)
diff --git a/backend/requests/lootboxes.http b/backend/requests/lootboxes.http
index 2c7fe2e..126d237 100644
--- a/backend/requests/lootboxes.http
+++ b/backend/requests/lootboxes.http
@@ -2,3 +2,8 @@ GET http://localhost:8080/lootboxes
Authorization: Bearer {{token}}
Content-Type: application/json
+###
+
+POST http://localhost:8080/lootboxes/1
+Authorization: Bearer {{token}}
+Content-Type: application/json
\ No newline at end of file
diff --git a/backend/src/main/java/de/szut/casino/CasinoApplication.java b/backend/src/main/java/de/szut/casino/CasinoApplication.java
index 2499781..4b47f5c 100644
--- a/backend/src/main/java/de/szut/casino/CasinoApplication.java
+++ b/backend/src/main/java/de/szut/casino/CasinoApplication.java
@@ -33,12 +33,12 @@ public class CasinoApplication {
if (lootBoxRepository.count() == 0) {
LootBoxEntity basicLootBox = new LootBoxEntity();
basicLootBox.setName("Basic LootBox");
- basicLootBox.setPrice(new BigDecimal("1.99"));
+ basicLootBox.setPrice(new BigDecimal("2"));
basicLootBox.setRewards(new ArrayList<>()); // Initialize the list
LootBoxEntity premiumLootBox = new LootBoxEntity();
premiumLootBox.setName("Premium LootBox");
- premiumLootBox.setPrice(new BigDecimal("4.99"));
+ premiumLootBox.setPrice(new BigDecimal("5"));
premiumLootBox.setRewards(new ArrayList<>()); // Initialize the list
// Save the loot boxes first
@@ -46,27 +46,27 @@ public class CasinoApplication {
RewardEntity commonReward = new RewardEntity();
commonReward.setValue(new BigDecimal("0.50"));
- commonReward.setProbability(new BigDecimal("70.00"));
+ commonReward.setProbability(new BigDecimal("0.7"));
RewardEntity rareReward = new RewardEntity();
rareReward.setValue(new BigDecimal("2.00"));
- rareReward.setProbability(new BigDecimal("25.00"));
+ rareReward.setProbability(new BigDecimal("0.25"));
RewardEntity epicReward = new RewardEntity();
epicReward.setValue(new BigDecimal("5.00"));
- epicReward.setProbability(new BigDecimal("5.00"));
+ epicReward.setProbability(new BigDecimal("0.5"));
RewardEntity premiumCommon = new RewardEntity();
premiumCommon.setValue(new BigDecimal("2.00"));
- premiumCommon.setProbability(new BigDecimal("60.00"));
+ premiumCommon.setProbability(new BigDecimal("0.6"));
RewardEntity premiumRare = new RewardEntity();
premiumRare.setValue(new BigDecimal("5.00"));
- premiumRare.setProbability(new BigDecimal("30.00"));
+ premiumRare.setProbability(new BigDecimal("0.3"));
RewardEntity legendaryReward = new RewardEntity();
legendaryReward.setValue(new BigDecimal("15.00"));
- legendaryReward.setProbability(new BigDecimal("10.00"));
+ legendaryReward.setProbability(new BigDecimal("0.10"));
// Save all rewards
rewardRepository.saveAll(Arrays.asList(
@@ -75,10 +75,9 @@ public class CasinoApplication {
));
// Add relationships from the owning side (LootBox)
- basicLootBox.getRewards().add(rareReward);
- basicLootBox.getRewards().add(epicReward);
+ basicLootBox.getRewards().add(commonReward);
+ basicLootBox.getRewards().add(premiumRare);
- premiumLootBox.getRewards().add(commonReward);
premiumLootBox.getRewards().add(premiumCommon);
premiumLootBox.getRewards().add(premiumRare);
premiumLootBox.getRewards().add(legendaryReward);
diff --git a/backend/src/main/java/de/szut/casino/lootboxes/LootBoxController.java b/backend/src/main/java/de/szut/casino/lootboxes/LootBoxController.java
index c885b5d..716b02a 100644
--- a/backend/src/main/java/de/szut/casino/lootboxes/LootBoxController.java
+++ b/backend/src/main/java/de/szut/casino/lootboxes/LootBoxController.java
@@ -1,20 +1,76 @@
package de.szut.casino.lootboxes;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RestController;
+import de.szut.casino.user.UserEntity;
+import de.szut.casino.user.UserRepository;
+import de.szut.casino.user.UserService;
+import org.springframework.http.ResponseEntity;
+import org.springframework.web.bind.annotation.*;
+import java.math.BigDecimal;
+import java.util.HashMap;
import java.util.List;
+import java.util.Map;
+import java.util.Optional;
@RestController
public class LootBoxController {
private final LootBoxRepository lootBoxRepository;
+ private final UserRepository userRepository;
+ private final UserService userService;
- public LootBoxController(LootBoxRepository lootBoxRepository) {
+ public LootBoxController(LootBoxRepository lootBoxRepository, UserRepository userRepository, UserService userService) {
this.lootBoxRepository = lootBoxRepository;
+ this.userRepository = userRepository;
+ this.userService = userService;
}
@GetMapping("/lootboxes")
public List getAllLootBoxes() {
return lootBoxRepository.findAll();
}
+
+ @PostMapping("/lootboxes/{id}")
+ public ResponseEntity