mein-sterntours/app/Http/Controllers/HomeController.php
2020-04-15 12:11:42 +02:00

228 lines
6.1 KiB
PHP
Executable file

<?php
namespace App\Http\Controllers;
use App\Models\SfGuardUser;
use App\User;
use Auth;
use Carbon\Carbon;
use Config;
use Request;
class HomeController extends Controller
{
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
}
/**
* 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');
}
$data = [
'user' => Auth::user(),
];
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');
}
}