165 lines
7.1 KiB
PHP
165 lines
7.1 KiB
PHP
<?php
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Geteilte Routen (Shared Routes)
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Diese Routen sind auf allen Domains verfügbar, die die 'web' Middleware-Gruppe
|
|
| verwenden. Sie werden vom RouteServiceProvider geladen.
|
|
|
|
|
*/
|
|
|
|
// Rechtliche und Kontakt-Routen - Umleitung zur Shop-Domain für checkout.*
|
|
// Verwendet EarlyDomainParser für domain-awareness
|
|
if (\App\Domain\EarlyDomainParser::getCurrentDomainType() === 'checkout') {
|
|
// Shop-Domain aus Config laden
|
|
$shopHost = config('domains.domains.shop.host');
|
|
$protocol = config('domains.protocol', 'https://');
|
|
$shopBaseUrl = $protocol . $shopHost;
|
|
|
|
// Für Checkout-Domain: Umleitung zur Shop-Domain
|
|
Route::get('/datenschutz', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/datenschutz');
|
|
})->name('legal.data-protected');
|
|
|
|
Route::get('/impressum', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/impressum');
|
|
})->name('legal.imprint');
|
|
|
|
Route::get('/agb', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/agb');
|
|
})->name('legal.agb');
|
|
|
|
Route::get('/kontakt', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/kontakt');
|
|
})->name('contact.create');
|
|
|
|
Route::get('/zahlungsarten', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/zahlungsarten');
|
|
})->name('zahlungsarten');
|
|
|
|
Route::get('/versandkosten', function () use ($shopBaseUrl) {
|
|
return redirect()->away($shopBaseUrl . '/versandkosten');
|
|
})->name('versandkosten');
|
|
} else {
|
|
// Für alle anderen Domains: normale Controller-Routen
|
|
Route::get('/datenschutz', 'HomeController@legalDataProtected')->name('legal.data-protected');
|
|
Route::get('/impressum', 'HomeController@legalImprint')->name('legal.imprint');
|
|
Route::get('/agb', 'HomeController@legalAGB')->name('legal.agb');
|
|
Route::get('/kontakt', 'Web\ContactController@create')->name('contact.create');
|
|
Route::post('/kontakt', 'Web\ContactController@store')->name('contact.store');
|
|
Route::get('/zahlungsarten', 'HomeController@zahlungsarten')->name('zahlungsarten');
|
|
Route::get('/versandkosten', 'HomeController@versandkosten')->name('versandkosten');
|
|
}
|
|
|
|
// File storage route für alle Domains (Rechnungen, Downloads, etc.)
|
|
// Auth-Prüfung erfolgt im FileController selbst je nach Kontext
|
|
Route::get('/storage/file/{id}/{from}/{do?}', 'FileController@show')->name('storage_file');
|
|
|
|
// Sprachwechsler
|
|
Route::post('/change_website_lang', 'Web\SiteController@changeLang')->name('language.change');
|
|
|
|
// Route für den Sprachwechsel (aus alter utility.php wiederhergestellt)
|
|
Route::get('translation/{locale}', function ($locale) {
|
|
app()->setLocale($locale);
|
|
session()->put('locale', $locale);
|
|
|
|
// Optional: Sprache für eingeloggte Benutzer speichern
|
|
if (auth()->guard('user')->check()) {
|
|
auth()->guard('user')->user()->update(['lang' => $locale]);
|
|
}
|
|
if (auth()->guard('customers')->check()) {
|
|
auth()->guard('customers')->user()->update(['language' => $locale]);
|
|
}
|
|
|
|
return redirect()->back();
|
|
})->name('translation');
|
|
|
|
|
|
// Bild-Routen (aus alter utility.php wiederhergestellt)
|
|
Route::get('/product/image/{slug}', function ($slug = null) {
|
|
if ($image = \App\Models\ProductImage::where('slug', 'like', $slug)->first()) {
|
|
$path = storage_path('app/public') . '/images/product' . '/' . $image->product_id . '/' . $image->filename;
|
|
if (file_exists($path)) {
|
|
return response()->file($path);
|
|
}
|
|
}
|
|
abort(404);
|
|
})->name('product_image');
|
|
|
|
Route::get('storage/images/{from}/{slug}', function ($from = null, $slug = null) {
|
|
if ($from == 'shop') {
|
|
if ($image = \App\Models\UserShop::where('filename', $slug)->first()) {
|
|
$path = storage_path('app/public') . '/images/shop' . '/' . $image->filename;
|
|
if (file_exists($path)) {
|
|
return Response::file($path);
|
|
}
|
|
}
|
|
}
|
|
})->name('storage_images');
|
|
|
|
|
|
Route::get('/iq/image/{slug}', function ($slug = null) {
|
|
if ($image = \App\Models\IqImage::where('slug', $slug)->first()) {
|
|
$path = storage_path('app/public') . '/images/iq_images/' . $image->filename;
|
|
if (file_exists($path)) {
|
|
return Response::file($path);
|
|
}
|
|
}
|
|
})->name('iq_image');
|
|
|
|
Route::get('/user_shop/image/{slug}', function ($slug = null) {
|
|
if ($image = \App\Models\UserShopOnSite::where('slug', $slug)->first()) {
|
|
$path = storage_path('app/public') . '/images/user_shop' . '/' . $image->user_shop_id . '/' . $image->filename;
|
|
if (file_exists($path)) {
|
|
return Response::file($path);
|
|
}
|
|
}
|
|
})->name('user_shop_image');
|
|
|
|
Route::get('/shop/product/image/{slug}', function ($slug = null) {
|
|
if ($image = \App\Models\ProductImage::where('slug', $slug)->first()) {
|
|
$path = storage_path('app/public') . '/images/product' . '/' . $image->product_id . '/' . $image->filename;
|
|
if (file_exists($path)) {
|
|
return Response::file($path);
|
|
}
|
|
}
|
|
})->name('shop_product_image');
|
|
|
|
// Alias für /home, damit auch /home erreichbar ist
|
|
|
|
// Checkout-Weiterleitung nur für Domains, die NICHT checkout.* sind
|
|
if (\App\Domain\EarlyDomainParser::getCurrentDomainType() !== 'checkout') {
|
|
// Checkout-Domain aus Config laden
|
|
$checkoutHost = config('domains.domains.checkout.host');
|
|
$protocol = config('domains.protocol', 'https://');
|
|
$checkoutBaseUrl = $protocol . $checkoutHost;
|
|
|
|
Route::get('/checkout/card/{identifier?}', function ($identifier = null) use ($checkoutBaseUrl) {
|
|
$path = '/checkout/card/' . ($identifier ?: '');
|
|
return redirect()->away($checkoutBaseUrl . $path);
|
|
})->name('checkout.checkout_card');
|
|
|
|
Route::post('/checkout/card/final', function () use ($checkoutBaseUrl) {
|
|
return redirect()->away($checkoutBaseUrl . '/checkout/card/final');
|
|
})->name('checkout.checkout_card_final');
|
|
|
|
// Weiterleitung für Transaktionsstatus
|
|
Route::get('/transaction/status/{status?}/{reference?}', function ($status = null, $reference = null) use ($checkoutBaseUrl) {
|
|
$path = "/transaction/status/" . ($status ?: '') . "/" . ($reference ?: '');
|
|
return redirect()->away($checkoutBaseUrl . $path);
|
|
})->name('checkout.transaction_status');
|
|
|
|
Route::post('/transaction/status/{status?}/{reference?}', function ($status = null, $reference = null) use ($checkoutBaseUrl) {
|
|
$path = "/transaction/status/" . ($status ?: '') . "/" . ($reference ?: '');
|
|
return redirect()->away($checkoutBaseUrl . $path);
|
|
})->name('checkout.transaction_status_post');
|
|
|
|
Route::get('/transaction/approved/{transactionId}/{reference}', function ($transactionId, $reference) use ($checkoutBaseUrl) {
|
|
return redirect()->away($checkoutBaseUrl . "/transaction/approved/{$transactionId}/{$reference}");
|
|
})->name('checkout.transaction_approved');
|
|
}
|
|
|
|
|
|
Route::get('/register/verify/{confirmationCode}', 'HomeController@verify')->name('register_verify');
|