/Next-js-preview-server

AWS Next.js Preview Server

Primary LanguageJavaScript

Next.js Preview Server Deploy Next.js Preview Server

This project provides the AWS infrastructure to deploy a Next.js project and expose a server running Next.js Preview Mode.

Note: This project only deploy the Next.js project, I will support WordPress in the infrastructure in the future.

Infrastructure:

AWS CDK is been used to creates the infrastructure. Some of the resources created by the project are:

  • IAM Roles & Policies
  • SecurityGroup
  • Application Load Balancer
  • Target Group
  • Auto Scaling Group
  • EC2 Instances
  • Code Deploy Application
  • Code Deploy Deployment Groups

Note: Before deploying, read the infrastructure documentation in ./infrastructure

Next.js Headless WordPress (WP) Template:

To use this service with Headless WP, you can start with the startup template cms-wordpress from Vercel/Next.js. If the Next.js server is going to be running in the same environment/endpoint as WordPress, then follow the template instructions.

Using Next.js Preview Mode outside WordPress Environment

To point the WP Preview to Next.js server, we will need to modify/hack the WP Preview Button behavior using WP 'previewpostlink' hook.

WordPress Hook

Add the filter below in the wordpress/wp-content/themes/templateName/functions.php

add_filter('preview_post_link', function ($link) {
	global $post;
	$post_ID = $post->post_parent;        
    return 'http://previewServerEndPoint.com:3000/api/'
		. 'preview?id='
		. $post_slug . '&wpnonce='
		. wp_create_nonce('wp_rest');
});

CI/CD Pipeline:

With the CI/CD pipeline we are deploying the AWS CDK infrastructure automatically on every commit to the master branch (if any change). Once the infrastructure is created, then we push the code to an S3, Bucket, and create a Code Deploy Deployment to push the code into the EC2 instances and start the Next.js Preview Mode.

Requirement:

For any CI/CD you will need to provide environment variables with the AWS Credentials of a user with Admin Permissions. The following variables are:

  • AWS_ACCESS_KEY_ID
  • AWS_SECRET_ACCESS_KEY

GitHub Action

In the file .github/workflows/main.yml you will find the deployment steps.


CircleCI

— TODO —

Resources: