invoiceninja/app/Http/Middleware/DatabaseLookup.php

41 lines
1.2 KiB
PHP
Raw Normal View History

2017-04-30 23:08:07 +03:00
<?php
namespace App\Http\Middleware;
use Illuminate\Http\Request;
use Closure;
2017-05-01 09:50:10 +03:00
use App\Models\LookupContact;
use App\Models\LookupInvitation;
2017-05-01 10:03:42 +03:00
use App\Models\LookupAccountToken;
2017-04-30 23:08:07 +03:00
class DatabaseLookup
{
2017-05-01 09:50:10 +03:00
public function handle(Request $request, Closure $next, $guard = 'user')
2017-04-30 23:08:07 +03:00
{
2017-05-01 09:50:10 +03:00
if (! env('MULTI_DB_ENABLED')) {
return $next($request);
}
if ($guard == 'user') {
2017-05-01 10:19:27 +03:00
// user's value is set when logging in
2017-05-01 15:17:52 +03:00
if (! session(SESSION_DB_SERVER)) {
2017-05-01 09:50:10 +03:00
return redirect('/logout');
}
2017-05-01 10:03:42 +03:00
} elseif ($guard == 'api') {
if ($token = $request->header('X-Ninja-Token')) {
LookupAccountToken::setServerByField('token', $token);
}
2017-05-01 10:19:27 +03:00
} elseif ($guard == 'contact') {
2017-05-01 09:50:10 +03:00
if (request()->invitation_key) {
LookupInvitation::setServerByField('invitation_key', request()->invitation_key);
} elseif (request()->contact_key) {
LookupContact::setServerByField('contact_key', request()->contact_key);
}
2017-05-01 15:17:52 +03:00
} elseif ($guard == 'postmark') {
LookupInvitation::setServerByField('message_id', request()->MessageID);
2017-04-30 23:08:07 +03:00
}
return $next($request);
}
}