@mightyacorndigital/lambda-edge-proxy
v0.3.2
Published
Provides auth capabilities for lambda@edge viewer-request functions
Downloads
12
Readme
Lambda Authentication Proxy
This nodejs library provides a simple authentication proxy for AWS Cloudfront distributions using Lambda@Edge.
Basic Setup
A typical setup is to use an AWS Lambda handler triggered by a CloudFront Distribution behavior.
Lambda Handler
The Lambda handler extracts the request, runs it through the desired proxy and either returns a response that triggers the authentication process, or passes the request through to the original destination if the user is authenticated.
A basic template for the lambda handler looks something like this example.
Configuration
The proxy is configured by passing in two arguments:
- The
@octokit/oauth-app
Application you wish to use. This can be either a regular OAuth app, or a Github app. - The configuration options for the proxy:
- REQUIRED
hashKey
: A unique string used for generating a hash. baseUrl
: The base url for the site that requires authentication- Default:
false
- If not provided the proxy will attempt to determine the base url itself.
- Default:
authCookieName
: The name of the cookie used to indicate that the user is authenticated.- Default:
_auth
- Default:
pathLogin
: The path that an unauthenticated user is redirected to that initiates authentication for logged out users.- Default:
/oauth/login
- Default:
pathCallback
: The callback path that Oauth2 authentication is performed at.- Default:
/oauth/callback
- Default:
pathLogout
: The path a user can visit to log out- Default:
/oauth/logout
- Default:
logger
: An object used for logging.- Default:
console
- Default:
CloudFront Distribution behavior
The Lambda above gets triggered by an AWS CloudFront distribution behavior.
- Create a CloudFront distribution that traffic to your site or application passes through.
- In the
Lambda Function Associations
section at the bottom of the page add a new CloudFront Event that triggers the lambda on theViewer Request
event. - Add the Lambda ARN identifier. This can be found in the top right corner of the Lambda function. You can not use the
$LATEST
version alias, so you must use a published version of the Lambda function as a part of the identifier.
Special Cloudfront Distribution Configuration
This proxy requires two additional options to be specified in the distribution:
- Allowed HTTP Methods: MUST be set to
GET, HEAD, OPTIONS, PUT, POST, PATCH, DELETE
, because the form submits a post request - The Lambda behavior MUST have the
include body
option checked, because information is passed in the POST request body.