Quickly deploy Punchcard CMS to Heroku, or use this repository as an example to deploy Punchcard anywhere.
Ensure that PostgreSQL is available on the command line and accessible via the
postgres command. Create a user that has a password
W@ts0n and ensure that there is a
punchcard database created.
If working on a Mac, Homebrew is a convenient way to install PostgreSQL up and running. After installing Homebrew, do the following:
brew install postgres
postgres -D /user/local/var/postgres
W@ts0nwhen prompted -
createuser punchcard -P
createdb -0 punchcard punchcard
When working locally, there are two things that need to run: the database and the server. There are a number of helper scripts that ship with this repository to help with that:
npm run dev:database- Runs PostgreSQL, assuming it's been installed via Homebrew
npm run dev:start- Runs Gulp default task, as defined in the Punchcard Runner
npm run dev- Runs
npm run lint- Runs the Gulp
linttask, as defined in the Punchcard Runner
npm run build- Runs the Gulp
buildtask, as defined in the Punchcard Runner
npm test- Runs
lint, then tests, then
browser). Sass is linted using Sass Lint.
The basic test that ships with this repository checks to ensure that Punchcard can run with any modifications an end-user may want to make to the application coming from Punchcard. Custom input plugins are tested using Punchcard Shared Tests.
The following files and folders represent a fairly basic example of Punchcard Boilerplate to get Punchcard up and running. They are divided in to server, browser, test, and config. There are also generated files that can be mostly ignored.
Server boilerplate are required (marked with
*) and optional files and folders to get Punchcard running. All files and folders are relative to the running root of the application.
index.js* - The main file to actually run. The file presented is the bare minimum file recommended to make Punchcard both run and be testable. Punchcard is a Promise that returns a configured Express application that can be extended as if it were a local Express application.
config* - Punchcard config configuration files
config/default.js* - Default configuration to be shared regardless of environment. Extends the core Punchcard config to provide all default configuration. Without this configuration extension, Punchcard will not run.
config/test.js- Configuration to be used when the Node Environment is
test. Recommended to use
sqlite3for testing as it's faster than a full PostgreSQL database. Options present here override the default config and fall back to the default if not present.
config/production.js- Configuration to be used the Node Environment is
production. Recommend for production environments, with Environment Variables used to hold keys and other secrets. Options present here override the default config and fall back to the default if not present.
content-types* - The folder to hold Content Types for use with Punchcard. Punchcard extends the Content Type definition with a top-level attribute
workflowthat should be set to an ID of a provided workflow (below).
content-types/article.yml- A basic content type for an article. Includes file upload, repeatable, and reference attributes.
content-types/author.yml- A basic content type for a content author. Includes a file upload attribute, as well as an attribute from a custom input plugin.
workflows* -The folder to hold workflows for use with defined content types. Workflows can be set for a given content type by adding
workflow: IDin a Content Type, with
IDreplaced by the ID of the approval workflow.
workflows/self-publish.yml- A workflow with one step that allows the individual who authored a piece of content to approve it
input-plugins- The folder to hold custom Input Plugins for use in Punchcard. A sample input plugin is provided.
input-plugins/utils.js- Helpful functions for creating custom input plugins
input-plugins/input-plugin-address- Custom Address input plugin
input-plugins/input-plugin-address/README.md- README for Address input plugin
input-plugins/input-plugin-address/index.js- Input plugin definition file
input-plugins/input-plugin-address/package.json- Basic Node configuration for custom input plugin. Custom input plugin dependencies should be saved to the main Node configuration
views- Nunjucks templates to be made available to Punchcard. Putting an identically named template at the identical relative path to a template in the core Punchcard module will overwrite the core template with the provided one
Browser boilerplate is based on the default source and destination targets using Punchcard Runner. These can be modified, and methods for compiling can be changed, as long as settings are updated as appropriate for Punchcard Runner.
src- The folder to hold static files that will be served to the browser. Compiled versions will be made available in the
src/images- Images to be available in the browser. Will render to
public/imagesand available in the
/imagesfolder from the browser
public/jsand available in the
/jsfolder from the browser
src/sass- Sass files to be rendered to CSS and available in the browser. Will render to
public/cssand available in the
/cssfolder from the browser
src/sass/style.scss- Sass file that imports the Punchcard styling as an eyeglass module. Will render to
public/css/style.cssand available at
/css/style.cssfrom the browser
Gulpfile.js- Gulp task running file. The
tasks.nodemonconfigurations are for the server, whereas
tasks.buildis for the browser files. The two additional tasks,
Tests, while not required to run Punchcard, are recommended in order to ensure Punchcard runs and is extended as expected.
tests- Folder to run all tests
.eslintrc.yml- ESLint configuration for all Node code
.sass-lint.yml- Sass Lint configuration for all Sass code
src/js/.eslintrc.yml- ESLint configuration for all Browser code
tests/.eslintrc.yml- ESLint configuration for all Test code
There is a handful of general configuration files. Files that are required are marked with
.editorconfig- EditorConfig to hint to text editors how to behave
.gitignore- Files and file patterns for Git to ignore
.nvmrc- Node version for Node Version Manager to use. Helps ensure that the correct version of Node is being used given multiple versions of Node available on a system
.slugignore- Files and file patterns to be ignored when Heroku (or Heroku-compatible system) builds the server deployment
.travis.yml- Configuration file for Travis Continuous Integration. Configures Travis to use Node 6, cache
node_modules, run tests, and on success send code coverage to Coveralls, create a new semantic release, update labels using Reparo, and deploy to Heroku after successful tests are run on the
masterbranch, all while ignoring running any CI on release branches
Procfile- Configuration file to tell Heroku (or Heroku-compatible system) what command to run for different contexts. Configures Heroku to run
package.json) when in a
app.json- Heroku (or Heroku-compatible system) application manifest
package.json* - Node configuration. In a production environment where deploys can happen from a Continuous Integration server,
punchcard-runnershould all be
prestartscript should not exist. All
dependenciesthat start with
input-plugin-, as well as
lodash, are dependencies for the sample content types and the custom input plugin