mein-sterntours/app/Http/Controllers/HomeController.php
Phase-1-Rollback-Agent e3dc1afd8e WIP: Sicherheitsnetz vor Phase-1-R\u00fcckbau
Enth\u00e4lt gemischt: Laravel-10-Upgrade + Phase 1 (Contacts-Modul, Duplicats-Commands,
Soft-Delete+Merge-Fields) + Phase 2 Code-Umstellungen (inquiry_id, $table='contacts'/'inquiries')
+ Offers-Modul (Migrationen, Models, offer_id in Booking, offer-Disk in filesystems.php).

Phase 2 + Offers werden im folgenden Commit nach dev/backups/phase2-offers-2026-04-17/
verschoben, damit der Workspace auf Phase-1-only (= Test-System-Stand) reduziert ist
und direkt auf Live deploybar wird.

Tarball-Backup zus\u00e4tzlich unter: ../backups-safety/workspace-pre-phase1-rollback-2026-04-17.tar.gz

Made-with: Cursor
2026-04-17 13:40:31 +00:00

231 lines
6.6 KiB
PHP
Executable file

<?php
namespace App\Http\Controllers;
use App\Models\BookingNotice;
use App\Models\LeadNotice;
use App\Models\SfGuardUser;
use App\Models\TravelUserBookingFewoNotice;
use App\User;
use Auth;
use Carbon\Carbon;
use Config;
use Request;
class HomeController extends Controller
{
/**
* Show the application dashboard.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
if(!Auth::check()){
return redirect('login');
}
return redirect('home');
}
//login
public function show()
{
if(!Auth::check()){
return redirect('login');
}
$last_booking_notices = BookingNotice::orderBy('updated_at', 'DESC')->limit(10)->get();
$last_booking_fewo_notices = TravelUserBookingFewoNotice::orderBy('updated_at', 'DESC')->limit(10)->get();
$last_lead_notices = LeadNotice::orderBy('updated_at', 'DESC')->limit(10)->get();
$data = [
'user' => Auth::user(),
'last_booking_notices' => $last_booking_notices,
'last_booking_fewo_notices' => $last_booking_fewo_notices,
'last_lead_notices' => $last_lead_notices
];
return view('home', $data);
}
public function loadingModal(){
$data = Request::get('data');
$target = Request::get('target');
$response = "";
if($data == "data_protection"){
$response = view('legal.data_protect_de')->render();
}
if($data == "imprint"){
$response = view('legal.imprint_de')->render();
}
if(Request::ajax()) {
return response()->json(['response' => $response, 'target'=>$target]);
}
abort(404);
}
public function checkLogin($identify, $token, $show = false)
{
if($identify){
//user find by $identify
$user = User::where('identify', '=', $identify)->first();
if(!$user){
return abort(404);
}
//user - check für from $sf_guard_user - old system
$sf_guard_user = SfGuardUser::where('identify', '=', $identify)->first();
if(!$sf_guard_user){
return abort(404);
}
if($user->id != $sf_guard_user->user_id){
return abort(404);
}
if($sf_guard_user->token != $token){
return abort(404);
}
$time = Carbon::parse($sf_guard_user->token_at);
$now = Carbon::now();
$duration = $time->diffInSeconds($now);
if($duration > 3){
return abort(404);
}
$sf_guard_user->token = null;
$sf_guard_user->token_at = null;
$sf_guard_user->save();
if(!Auth::check()){
$user->last_login = now();
$user->save();
Auth::login($user);
}
if(Auth::check()){
if(!$show){
return redirect(route('home'));
}
if($show == 'drafts'){
return redirect(route('drafts'));
}
if(strpos($show, 'drafts_edit_booking_') !== false){
$booking_id = str_replace('drafts_edit_booking_', '', $show);
return redirect(route('booking_detail', [$booking_id]));
}
if(strpos($show, 'edit_booking_') !== false){
$booking_id = str_replace('edit_booking_', '', $show);
return redirect(route('booking_detail', [$booking_id]));
}
if($show == 'requests'){
return redirect(route('requests'));
}
if($show == 'travel_agenda'){
return redirect(route('admin_settings_travel_program'));
}
if($show == 'travel_country'){
return redirect(route('admin_settings_travel_country'));
}
if($show == 'cms_content_country'){
return redirect(route('cms_content_country'));
}
}
}
return abort(404);
}
public function verify($confirmation_code = false){
if( ! $confirmation_code)
{
return redirect('/status/error');
}
$user = User::whereConfirmationCode($confirmation_code)->whereConfirmed(0)->first();
if ( ! $user)
{
$user = User::whereConfirmationCode($confirmation_code)->whereActive(0)->first();
if ($user){
return redirect(route('register_active', [$confirmation_code]));
}
return redirect('/status/not/found');
}
$user->confirmed = 1;
$user->confirmation_date = now();
$user->confirmation_code = null;
$user->confirmation_code_to = null;
$user->confirmation_code_remider = 0;
$user->save();
//Login!
Auth::logout();
Auth::loginUsingId($user->id);
return redirect('/status/verify');
}
public function active($confirmation_code = false){
if( ! $confirmation_code)
{
return redirect('/status/error');
}
$user = User::whereConfirmationCode($confirmation_code)->whereActive(0)->first();
if ( ! $user)
{
$user = User::whereConfirmationCode($confirmation_code)->whereConfirmed(0)->first();
if ($user){
return redirect(route('register_verify', [$confirmation_code]));
}
return redirect('/status/not/found');
}
$user->active_date = null;
$user->confirmation_code = null;
$user->confirmation_code_to = null;
$user->confirmation_code_remider = 0;
$user->save();
//Login!
Auth::logout();
Auth::loginUsingId($user->id);
return redirect(route('status_active'));
}
public function statusRegister(){
return view('status.status_register');
}
public function statusVerify(){
return view('status.status_verify');
}
public function statusActive(){
return view('status.status_active');
}
public function statusError(){
return view('status.status_error');
}
public function notFound(){
return view('status.not_found');
}
public function legalDataProtected()
{
return view('legal.data_protected');
}
public function legalImprint()
{
return view('legal.imprint');
}
}