auf success_url/cancel_url weiter. Gleichzeitig werden diese URLs jetzt in custom_data bei Add‑ons, Package‑Checkout und Gift‑Vouchern gespeichert, damit der Return‑Handler sie kennt. Details (relevant): - app/Http/Controllers/PaddleReturnController.php verarbeitet _ptxn, prüft Status, schützt vor Open‑Redirects. - routes/web.php neue Route paddle.return (öffentlich). - app/Services/Addons/EventAddonCheckoutService.php, app/Services/Paddle/PaddleCheckoutService.php, app/Services/ GiftVouchers/GiftVoucherCheckoutService.php speichern success_url/cancel_url in custom_data. - tests/Feature/PaddleReturnTest.php prüft Success/Cancel‑Redirects. - Tests aktualisiert: tests/Unit/PaddleCheckoutServiceTest.php. Wichtig für die Rückleitung: - Bitte in Paddle (Sandbox + Live) die Checkout‑Success/Cancel URL auf http://fotospiel-app.test/paddle/return setzen. Ohne diese Einstellung schickt Paddle den Nutzer nicht zu unserem Return‑Handler. Nebenwirkung: Add‑on‑Checkout gibt jetzt als checkout_id die Transaktions‑ID (txn_…) zurück (statt chk_…).
61 lines
2.2 KiB
PHP
61 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature;
|
|
|
|
use Illuminate\Support\Facades\Config;
|
|
use Illuminate\Support\Facades\Http;
|
|
use Tests\TestCase;
|
|
|
|
class PaddleReturnTest extends TestCase
|
|
{
|
|
public function test_return_redirects_to_success_url_for_completed_transaction(): void
|
|
{
|
|
Config::set('paddle.api_key', 'test_key');
|
|
Config::set('paddle.base_url', 'https://paddle.test');
|
|
Config::set('paddle.environment', 'sandbox');
|
|
Config::set('app.url', 'https://fotospiel-app.test');
|
|
|
|
Http::fake([
|
|
'https://paddle.test/transactions/txn_123' => Http::response([
|
|
'data' => [
|
|
'id' => 'txn_123',
|
|
'status' => 'completed',
|
|
'custom_data' => [
|
|
'success_url' => 'https://fotospiel-app.test/event-admin/mobile/events/slug/photos?addon_success=1',
|
|
'cancel_url' => 'https://fotospiel-app.test/event-admin/mobile/events/slug/photos',
|
|
],
|
|
],
|
|
], 200),
|
|
]);
|
|
|
|
$response = $this->get('/paddle/return?_ptxn=txn_123');
|
|
|
|
$response->assertRedirect('https://fotospiel-app.test/event-admin/mobile/events/slug/photos?addon_success=1');
|
|
}
|
|
|
|
public function test_return_redirects_to_cancel_url_when_not_completed(): void
|
|
{
|
|
Config::set('paddle.api_key', 'test_key');
|
|
Config::set('paddle.base_url', 'https://paddle.test');
|
|
Config::set('paddle.environment', 'sandbox');
|
|
Config::set('app.url', 'https://fotospiel-app.test');
|
|
|
|
Http::fake([
|
|
'https://paddle.test/transactions/txn_456' => Http::response([
|
|
'data' => [
|
|
'id' => 'txn_456',
|
|
'status' => 'failed',
|
|
'custom_data' => [
|
|
'success_url' => 'https://fotospiel-app.test/event-admin/mobile/events/slug/photos?addon_success=1',
|
|
'cancel_url' => 'https://fotospiel-app.test/event-admin/mobile/events/slug/photos',
|
|
],
|
|
],
|
|
], 200),
|
|
]);
|
|
|
|
$response = $this->get('/paddle/return?_ptxn=txn_456');
|
|
|
|
$response->assertRedirect('https://fotospiel-app.test/event-admin/mobile/events/slug/photos');
|
|
}
|
|
}
|