Skip to content

Instantly share code, notes, and snippets.

@martinbean
Created June 28, 2017 13:11
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save martinbean/a9699bf12e0cbfe459bff21ed49c5cec to your computer and use it in GitHub Desktop.
Save martinbean/a9699bf12e0cbfe459bff21ed49c5cec to your computer and use it in GitHub Desktop.
Redirect non-secure requests on Heroku
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class ForceSecure
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
$request->setTrustedProxies([
'127.0.0.1',
$request->server->get('REMOTE_ADDR'),
]);
$request->setTrustedHeaderName(Request::HEADER_FORWARDED, null);
$request->setTrustedHeaderName(Request::HEADER_CLIENT_IP, 'X_FORWARDED_FOR');
$request->setTrustedHeaderName(Request::HEADER_CLIENT_HOST, null);
$request->setTrustedHeaderName(Request::HEADER_CLIENT_PROTO, 'X_FORWARDED_PROTO');
$request->setTrustedHeaderName(Request::HEADER_CLIENT_PORT, 'X_FORWARDED_PORT');
if (! app()->isLocal() && ! $request->secure()) {
return redirect()->secure($request->path(), 301);
}
return $next($request);
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment