npm-cache-resource
a Concourse resource for caching dependencies downloaded by NPM - built on mhart/alpine-node and git-resource.
Versions
Tag | From | Bower | Yarn | Maintained |
---|---|---|---|---|
latest | mhart/alpine-node:latest | Yes | Yes | Yes |
15 | mhart/alpine-node:15 | Yes | Yes | Yes |
14 | mhart/alpine-node:14 | Yes | Yes | Yes |
12 | mhart/alpine-node:12 | Yes | Yes | Yes |
10 | mhart/alpine-node:10 | Yes | Yes | Yes |
9 | mhart/alpine-node:9 | No | Yes | No |
8 | mhart/alpine-node:8 | No | Yes | No |
7 | mhart/alpine-node:7 | No | No | No |
6 | mhart/alpine-node:6 | No | No | No |
4 | mhart/alpine-node:4 | No | No | No |
0.12 | mhart/alpine-node:0.12 | No | No | No |
0.10 | mhart/alpine-node:0.10 | No | No | No |
Resource Configuration
resource_types:
- name: npm-cache
type: docker-image
source: {repository: ymedlop/npm-cache-resource, tag: "12"}
Source Configuration
<<:
: Required. The source is the same as the corresponding git resource
Configuration to access a Git Private Repo
SSH:
private_key
: Required. Private key.
HTTP(S):
username_key
: Required. Username for HTTP(S) auth. This is needed when only HTTP/HTTPS protocol for git is available (which does not support private key auth) and auth is required.password_key
: Required. Password for HTTP(S) auth.skip_ssl_verification
: Optional. Skips git ssl verification by exporting GIT_SSL_NO_VERIFY=true.
Configuration to access a NPM Registry or Private Registry by User and Password.
registry-url
: Optional. Private NPM registry to log in to (Default: https://registry.npmjs.org)registry-user
: Required. Registry Username.registry-pass
: Required. Registry User Password.registry-email
: Required. Registry User Email.registry-scope
: Optional. Registry Scope.
Configuration to access a Private Registry by Base64 Token
registry
: Required. The location our private npm registry.token
: Required. Our npm token.
Node.js Environment variables
node-env
: Set NODE_ENV. (Default: development)
Configuration for projects living in subdirectories
project-path
: Optional Relative path of subdirectory containing the project (i.e. where thepackage.json
is).
Configuration use for npm
npm-args
: Optional Allow to add extra args to npm i / npm ci command. (Default: “-q”)
Configuration use npm ci command
npm-ci-support
: Optional Allow to use npm ci instead of npm install to install the npm modules into our resource. (Default: false)
Configuration use yarn cli
yarn-support
: Optional Allow to use yarn to install the npm modules into our resource. (Default: false)yarn-args
: Optional Allow to add extra args to yarn install command. (Default: “”)
Configuration use bower cli
bower-support
: Optional Allow to use bower to install packages into our resource (Bower dependency has to be in our package.json). (Default: false)bower-args
: Optional Allow to add extra args to bower install command. (Default: “-q –allow-root”)
Whatever tool you use to generate the encoded username and password string, try to encode the string admin:admin123, which should result in YWRtaW46YWRtaW4xMjM=. `
Another example for a valid setup is jane:testpassword123 resulting in amFuZTp0ZXN0cGFzc3dvcmQxMjM=.
In our demo we are using admin:123456 resulting in YWRtaW46MTIzNDU2
Example
resources:
# a perfectly normal source repository with lashings and lashings of dependencies
- name: repo
type: git
source: &repo-source # apply a YAML anchor so we can refer to this in the cache resource
uri: https://github.com/ymedlop/npm-cache-resource.git
branch: npm-package-example
# a resource caching the dependencies listed in the source repository
- name: npm-repo-cache
type: npm-cache # as defined above
source:
<<: *repo-source # the source is the same as the corresponding git resource ...
paths: # ... except that it's only interested in files listing dependencies
- package.json
Behavior
check
: Check for new commits
The repository is cloned (or pulled if already present), and any commits from the given version on are returned. If no version is given, the ref for HEAD is returned.
Any commits that contain the string [ci skip] will be ignored. This allows you to commit to your repository without triggering a new version.
in
: Pulls a package from npm
Clones the repository to the destination, and locks it down to a given ref. It will return the same given ref as version. And fetch npm package from the package.json`.
Examples
jobs:
- name: cache
plan:
- get: repo
trigger: true
- get: npm-repo-cache
- name: test
plan:
- get: repo
trigger: true
passed: [cache]
- get: npm-repo-cache
passed: [cache]
- task: run tests
config:
platform: linux
image_resource:
type: docker-image
source: {repository: mhart/alpine-node, tag: "12"}
inputs:
- name: repo
path: /src
- name: npm-repo-cache
path: /cache
run:
path: sh
args:
- -exc
- |
mv cache/node_modules src
cd src && npm test
- name: build
plan:
- get: repo
trigger: true
passed: [cache]
- get: npm-repo-cache
passed: [cache]
- task: run build
config:
platform: linux
image_resource:
type: docker-image
source: {repository: mhart/alpine-node, tag: "12"}
inputs:
- name: repo
path: /src
- name: npm-repo-cache
path: /cache
run:
path: sh
args:
- -exc
- |
mv cache/node_modules src
cd src && npm run build
out
: Nothing to do here….
Getting Started
You can see more examples here.
Credits:
- concourse git resource
- projectfalcon/gradle-cache-resource We are following this resource to create our npm cache resource.
License
See the LICENSE file for license text and copyright information.