broilerpan
TypeScript icon, indicating that this package has built-in type declarations

0.5.1 • Public • Published

BroilerPan

BroilerPan is a command line interface for bootstrapping and deploying scalable, production-ready web apps! It works with projects using BroilerKit development kit library!

The command line interface includes commands to deploy your web app to Amazon Web Services cloud platform, with minimal setup and very low costs! The hosting is almost free on low-traffic sites.

(Disclaimer: By using this utility you are taking the responsibility for any incurring expenses.)

Development features

  • Quickly bootstrap your project with Broilerplate templates
  • Write your code in TypeScript! It will be compiled to ES5 JavaScript
  • Write your stylesheets in SASS! It will be compiled to CSS
  • Lint your code style with TSLint and ESLint
  • Generate static HTML pages from Pug templates
  • Automatically bundle and optimize any images from your HTML, Pug, or Markdown files.
  • Include Markdown to your Pug templates. You may include with filters but != require("foo.md") is preferred because it will also require any images.
  • Generate favicons and related asset files from a single icon image file, and insert references to the HTML pages
  • Refer to your current GIT version with __COMMIT_HASH__, __VERSION__ and __BRANCH__ constants

Deployment features

  • Deploy your compressed, production-ready web app to AWS platform, hosted on S3, served globally through CloudFront, and managed with CloudFormation
  • Make your app available on your custom domain (required)
  • Your app is served using HTTPS! Creation of required certificates are done automatically with Amazon Certificate Manager
  • Host static assets on separate cookieless domain with infinite caching, for maximum performance scoring and reliability
  • Separate stages for your releases, e.g. the production version (prod) and the development version (dev)

What do I need?

To use this utility, you need the following:

Installing

Install the command line utility:

npm i -g broilerpan

After this you can use the broil command. To get the overview of the available commands, run broil help:

$ broil help
Commands:
  init [directory]      Bootstrap your project with Broilerplate template.           [aliases: pull]
  deploy <stage>        Deploy the web app for the given stage.
  undeploy <stage>      Deletes the previously deployed web app.
  logs <stage> [since]  Print app logs.
  compile <stage>       Compile the web app.                                        [aliases: build]
  preview <stage>       Preview the changes that would be deployed.
  describe <stage>      Describes the deployed resources.
  serve [stage]         Run the local development server.

Options:
  --appConfigPath  Path to the app configuration                        [string] [default: "app.ts"]
  --debug          Compile assets for debugging                                            [boolean]
  --no-color       Print output without colors                                             [boolean]
  --help           Show help                                                               [boolean]
  --version        Show version number                                                     [boolean]

Creating a web app

You can easily bootstrap a new web app:

broil init myapp

This will create a folder myapp and initialize it as a GIT repository, if not already initialized. Then it will apply the Broilerplate template to your project. It will then also install node dependencies for you!

If you have already created a GIT repository for you app, just run this in the directory:

broil init

After bootstrapping your project, you should add the metadata to the package.json file, for example, name, author, description.

NOTE: If installing node dependencies fails on OSX you may try to install libpng with Homebrew.

Configuring the app

You should change the configuration in app.ts according to your web app's needs.

  • name: A distinct name of your app. Recommended to be in lower case and separate words with dashes, because the name will be used in Amazon resource names and internal host names.
  • stages: Configuration for each different stage that your app has. By default there are dev stage for a development version and prod stage for the production version. You should change the siteDomain and assetsDomain to the domain names that you would like to use for each stage. There is also a special stage local that is used for the locally run development server.

Running locally

To run the app locally, start the local HTTP server and the build watch process:

broil serve

Then navigate your browser to the website address as defined in your local stage configuration, which is http://localhost:1111/ by default!

The web page is automatically reloaded when the app is re-built.

Deployment

Prerequisities

Set up AWS credentials

First, create a user and an access key from AWS Identity and Access Management Console.

Then you need to set up your AWS credentials to your development machine. This can be done with aws-cli command line tool, which you may need to install first:

# Install if not already installed 
pip install awscli
# Optional: enable command line completion 
complete -C aws_completer aws
# Configure your credentials 
aws configure

Create a Hosted Zone

NOTE: You need to create a Hosted Zone for Amazon Route53 for your custom domain first! Also, if you are using other domain name provider, such as GoDaddy, then you need to set up the DNS records for your domain.

Running deployment

Deployments are run with the following command:

broil deploy <stage>

For example, to deploy the development version to the dev stage:

broil deploy dev

To deploy the production version to the prod stage:

broil deploy prod

IMPORTANT: When deploying for the first time, you will receive email for confirming the certificate for the domain names! The deployment continues only after you approve the certificate!

The deployment will build your app files, and then upload them to Amazon S3 buckets.

The assets (JavaScript, CSS, images) are uploaded first. Their names will contain hashes, so they won't conflict with existing files. They will be cached infinitely with HTTP headers. The HTML files are uploaded last and they are cached for a short time.

Package Sidebar

Install

npm i broilerpan

Weekly Downloads

0

Version

0.5.1

License

ISC

Unpacked Size

27.3 kB

Total Files

10

Last publish

Collaborators

  • kiiski