ad: handling of payment notifications
This commit is contained in:
@@ -1,5 +1,10 @@
|
|||||||
package _11.asktpk.artisanconnectbackend.controller;
|
package _11.asktpk.artisanconnectbackend.controller;
|
||||||
|
|
||||||
|
import _11.asktpk.artisanconnectbackend.entities.Notice;
|
||||||
|
import _11.asktpk.artisanconnectbackend.entities.Order;
|
||||||
|
import _11.asktpk.artisanconnectbackend.entities.Payment;
|
||||||
|
import _11.asktpk.artisanconnectbackend.repository.PaymentRepository;
|
||||||
|
import _11.asktpk.artisanconnectbackend.utils.Enums;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
@@ -12,7 +17,9 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@@ -24,6 +31,12 @@ public class PaymentController {
|
|||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(PaymentController.class);
|
private static final Logger log = LoggerFactory.getLogger(PaymentController.class);
|
||||||
|
|
||||||
|
private final PaymentRepository paymentRepository;
|
||||||
|
|
||||||
|
public PaymentController(PaymentRepository paymentRepository) {
|
||||||
|
this.paymentRepository = paymentRepository;
|
||||||
|
}
|
||||||
|
|
||||||
@PostMapping(value = "/notification", consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE)
|
@PostMapping(value = "/notification", consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE)
|
||||||
public ResponseEntity<String> handleTpayNotification(@RequestParam Map<String, String> params) {
|
public ResponseEntity<String> handleTpayNotification(@RequestParam Map<String, String> params) {
|
||||||
log.info("=== ODEBRANO NOTYFIKACJĘ Tpay ===");
|
log.info("=== ODEBRANO NOTYFIKACJĘ Tpay ===");
|
||||||
@@ -45,10 +58,37 @@ public class PaymentController {
|
|||||||
return ResponseEntity.status(400).body("INVALID CHECKSUM");
|
return ResponseEntity.status(400).body("INVALID CHECKSUM");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ("true".equals(trStatus)) {
|
Optional<Payment> optionalPayment = paymentRepository.findByTransactionId(trId);
|
||||||
log.info("✅ Transakcja opłacona: tr_id={}, kwota={}", trId, params.get("tr_paid"));
|
if (optionalPayment.isPresent()) {
|
||||||
} else if ("chargeback".equals(trStatus)) {
|
Payment payment = optionalPayment.get();
|
||||||
log.warn("⚠️ Chargeback: {}", trId);
|
|
||||||
|
if ("true".equalsIgnoreCase(trStatus) || "PAID".equalsIgnoreCase(trStatus)) {
|
||||||
|
log.info("✅ Transakcja opłacona: tr_id={}, kwota={}", trId, params.get("tr_paid"));
|
||||||
|
payment.setStatus(Enums.PaymentStatus.CORRECT);
|
||||||
|
|
||||||
|
if (payment.getOrder() != null) {
|
||||||
|
Order order = payment.getOrder();
|
||||||
|
order.setStatus(Enums.OrderStatus.COMPLETED);
|
||||||
|
Notice notice = order.getNotice();
|
||||||
|
if (order.getOrderType() == Enums.OrderType.ACTIVATION) {
|
||||||
|
notice.setStatus(Enums.Status.ACTIVE);
|
||||||
|
} else if (order.getOrderType() == Enums.OrderType.BOOST) {
|
||||||
|
notice.setPublishDate(LocalDateTime.now());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if ("false".equalsIgnoreCase(trStatus)) {
|
||||||
|
log.warn("❌ Transakcja nieudana: {}", trId);
|
||||||
|
payment.setStatus(Enums.PaymentStatus.INCORRECT);
|
||||||
|
|
||||||
|
if (payment.getOrder() != null) {
|
||||||
|
payment.getOrder().setStatus(Enums.OrderStatus.CANCELLED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
paymentRepository.save(payment);
|
||||||
|
} else {
|
||||||
|
log.warn("⚠️ Brak płatności o tr_id={}", trId);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResponseEntity.ok("TRUE");
|
return ResponseEntity.ok("TRUE");
|
||||||
|
|||||||
@@ -4,7 +4,9 @@ import _11.asktpk.artisanconnectbackend.entities.Payment;
|
|||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
public interface PaymentRepository extends JpaRepository<Payment, Long> {
|
public interface PaymentRepository extends JpaRepository<Payment, Long> {
|
||||||
|
Optional<Payment> findByTransactionId(String transactionId);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user