@financial-times/g-deploy
CLI for deploying FT Graphics projects
Last updated 8 months ago by aendrew .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ cnpm install @financial-times/g-deploy 
SYNC missed versions from official npm registry.

g-deploy Build Status npm

CLI for deploying built static websites to an S3 bucket.

How to use

Requires Node 8 or higher.

To install:

$ npm i @financial-times/g-deploy

Command line usage

$ g-deploy --help

  CLI for deploying FT Graphics projects

  > g-deploy [FLAGS...]
  ────────────────────────────────────────────────────────────────────
  All flags are optional when this command is run from a typical FT
  Graphics project repo in CI.
  ────────────────────────────────────────────────────────────────────
  Vault settings
  If not provided these will be inferred from environment variables following
  each flag.
  --vault-endpoint ($VAULT_ENDPOINT)
  --vault-role ($VAULT_ROLE)
  --vault-secret ($VAULT_SECRET)
  --vault-secret-path ($VAULT_SECRET_PATH)

  AWS settings (Deprecated for FT projects — use Vault instead)
  If not provided, these settings are taken from env vars
  ("AWS_KEY_PROD", "AWS_SECRET_PROD", etc.)
    --aws-key
    --aws-secret
    --aws-region
    --bucket-name

  Upload settings
  If not provided, these are deduced from the git status in the CWD.
    --project-name
    --sha - unique reference for this commit
    --branch-name - name of the branch you are deploying
    --local-dir - what to upload; defaults to ./dist
    --path - ignore path logic and use a specified path instead. *_DANGER ZONE_ BE CAREFUL*
    --preview - upload files to preview folder
    --assets-prefix - base for asset URLs; affects the rev-manifest and all
                      HTML/CSS files

  Other
    --help - show this help and exit
    --get-branch-url - instead of deploying, just print the URL it would deploy to
    --get-commit-url - as above, but get the commit-specific URL
    --confirm - skip the confirmation dialogue when deploying

JavaScript API

The most straightforward way:

import deploy from "@financial-times/g-deploy";

deploy(options).then(baseURLs => {
  console.log("uploaded to:", baseURLs);
});

For more fine-grained control:

import { Deployer } from "@financial-times/g-deploy";

const deployer = new Deployer(options);

deployer.execute().then(baseURLs => {
  console.log("uploaded to:", baseURLs);
});

The JavaScript API does not do any git-sniffing or use any environment variables to configure the deployment – you must pass in all required options manually. See the Deployer class source for the full options.

Development

Clone this repo and run yarn to install dependencies.

Add a .env file that defines AWS_KEY_DEV, AWS_SECRET_DEV, AWS_REGION_DEV and BUCKET_NAME_DEV. (These are used in tests.)

Run yarn build -- --watch and yarn test -- --watch in separate terminal tabs while developing. (The first one watches src and builds to dist. The second one runs ava tests in dist.)

Publishing a new version to npm

  • Make sure you're on master: git checkout master
  • git fetch --tags
  • git tag v<new version number>
  • git push origin v<new version number>

CircleCI will do the rest.

Current Tags

  • 3.0.10                                ...           latest (8 months ago)

14 Versions

  • 3.0.10                                ...           8 months ago
  • 3.0.9                                ...           8 months ago
  • 3.0.8                                ...           10 months ago
  • 3.0.7                                ...           10 months ago
  • 3.0.6                                ...           10 months ago
  • 3.0.5                                ...           a year ago
  • 3.0.4                                ...           a year ago
  • 3.0.3                                ...           a year ago
  • 3.0.2                                ...           a year ago
  • 3.0.1                                ...           a year ago
  • 3.0.0-rc4                                ...           a year ago
  • 3.0.0-rc3                                ...           a year ago
  • 3.0.0-rc2                                ...           a year ago
  • 3.0.0-rc1                                ...           a year ago
Downloads
Today 14
This Week 14
This Month 14
Last Day 0
Last Week 0
Last Month 3
Dependencies (16)
Dev Dependencies (31)
Dependents (0)
None

Copyright 2014 - 2016 © taobao.org |