2013-06-13 09:21:14 -05:00
|
|
|
# path to a directory with all packages
|
|
|
|
storage: ./storage
|
2018-07-18 07:53:08 -05:00
|
|
|
# path to a directory with plugins to include
|
|
|
|
plugins: ./plugins
|
2013-06-13 09:21:14 -05:00
|
|
|
|
2014-09-06 14:53:28 -05:00
|
|
|
web:
|
2017-08-28 09:42:26 -05:00
|
|
|
# WebUI is enabled as default, if you want disable it, just uncomment this line
|
|
|
|
#enable: false
|
2014-09-06 14:53:28 -05:00
|
|
|
|
2016-08-20 11:46:54 -05:00
|
|
|
title: Verdaccio
|
2017-06-17 03:50:49 -05:00
|
|
|
|
2018-07-29 11:30:08 -05:00
|
|
|
#logo: logo.png
|
|
|
|
|
|
|
|
# If you're using this registry for a specific module scope,
|
2018-07-31 03:58:43 -05:00
|
|
|
# specify that scope to set it in the webui instructions header (note: escape @ with \@)
|
2018-07-29 11:30:08 -05:00
|
|
|
#scope: \@myscope
|
2017-06-17 03:50:49 -05:00
|
|
|
|
2014-09-01 19:27:04 -05:00
|
|
|
auth:
|
|
|
|
htpasswd:
|
2014-09-14 10:57:39 -05:00
|
|
|
file: ./htpasswd
|
2017-08-28 09:42:26 -05:00
|
|
|
# Maximum amount of users allowed to register, defaults to "+infinity".
|
2014-09-30 02:53:22 -05:00
|
|
|
# You can set this to -1 to disable registration.
|
2014-09-01 19:27:04 -05:00
|
|
|
#max_users: 1000
|
2014-06-26 11:21:23 -05:00
|
|
|
|
2018-06-28 11:33:37 -05:00
|
|
|
# Configure plugins that can register custom middlewares
|
|
|
|
# To use `npm audit` uncomment the following section
|
|
|
|
middlewares:
|
|
|
|
audit:
|
|
|
|
enabled: true
|
2018-05-21 04:28:04 -05:00
|
|
|
|
2013-09-23 23:27:47 -05:00
|
|
|
# a list of other known repositories we can talk to
|
2013-06-13 09:21:14 -05:00
|
|
|
uplinks:
|
|
|
|
npmjs:
|
|
|
|
url: https://registry.npmjs.org/
|
|
|
|
|
2014-03-07 22:49:59 -05:00
|
|
|
# amount of time to wait for repository to respond
|
2013-12-07 17:37:27 -05:00
|
|
|
# before giving up and use the local cached copy
|
2014-03-07 22:49:59 -05:00
|
|
|
#timeout: 30s
|
2013-12-04 14:39:29 -05:00
|
|
|
|
2014-03-07 22:49:59 -05:00
|
|
|
# maximum time in which data is considered up to date
|
2013-10-22 03:34:07 -05:00
|
|
|
#
|
|
|
|
# default is 2 minutes, so server won't request the same data from
|
|
|
|
# uplink if a similar request was made less than 2 minutes ago
|
2014-03-07 22:49:59 -05:00
|
|
|
#maxage: 2m
|
2013-10-22 03:34:07 -05:00
|
|
|
|
2014-03-13 13:32:44 -05:00
|
|
|
# if two subsequent requests fail, no further requests will be sent to
|
|
|
|
# this uplink for five minutes
|
|
|
|
#max_fails: 2
|
|
|
|
#fail_timeout: 5m
|
|
|
|
|
|
|
|
# timeouts are defined in the same way as nginx, see:
|
|
|
|
# http://wiki.nginx.org/ConfigNotation
|
|
|
|
|
2016-10-05 05:56:03 -05:00
|
|
|
# add/override HTTP headers sent to the uplink server
|
|
|
|
# this allows for HTTP Basic auth for example:
|
|
|
|
#headers:
|
|
|
|
# authorization: "Basic YourBase64EncodedCredentials=="
|
|
|
|
|
2017-03-03 18:39:26 -05:00
|
|
|
# set this to false to prevent tarballs from this upstream
|
|
|
|
# to be stored in the local storage (defaults to true)
|
|
|
|
#cache: false
|
|
|
|
|
2018-03-17 09:47:28 -05:00
|
|
|
# set this to false to disable strict SSL cert check (defaults to true)
|
|
|
|
#strict_ssl: false
|
|
|
|
|
2013-06-13 09:21:14 -05:00
|
|
|
packages:
|
2017-08-02 13:46:06 -05:00
|
|
|
'@*/*':
|
|
|
|
# scoped packages
|
|
|
|
access: $all
|
|
|
|
publish: $authenticated
|
|
|
|
proxy: npmjs
|
2014-01-13 13:56:36 -05:00
|
|
|
# uncomment this for packages with "local-" prefix to be available
|
2013-09-23 23:36:43 -05:00
|
|
|
# for admin only, it's a recommended way of handling private packages
|
|
|
|
#'local-*':
|
2015-04-08 15:54:59 -05:00
|
|
|
# access: admin
|
|
|
|
# publish: admin
|
2014-01-13 13:56:36 -05:00
|
|
|
# # you can override storage directory for a group of packages this way:
|
|
|
|
# storage: 'local_storage'
|
2013-09-23 23:36:43 -05:00
|
|
|
|
2016-09-26 06:48:36 -05:00
|
|
|
'**':
|
2014-09-01 19:27:04 -05:00
|
|
|
# allow all users to read packages (including non-authenticated users)
|
|
|
|
#
|
|
|
|
# you can specify usernames/groupnames (depending on your auth plugin)
|
2014-09-14 10:49:15 -05:00
|
|
|
# and three keywords: "$all", "$anonymous", "$authenticated"
|
2015-04-08 15:54:59 -05:00
|
|
|
access: $all
|
2013-06-13 09:21:14 -05:00
|
|
|
|
2013-09-23 23:27:47 -05:00
|
|
|
# allow 'admin' to publish packages
|
2017-08-02 13:46:06 -05:00
|
|
|
publish: $authenticated
|
2013-09-23 23:27:47 -05:00
|
|
|
|
|
|
|
# if package is not available locally, proxy requests to 'npmjs' registry
|
2013-12-28 19:54:46 -05:00
|
|
|
proxy: npmjs
|
2013-09-23 23:36:43 -05:00
|
|
|
|
|
|
|
#####################################################################
|
|
|
|
# Advanced settings
|
|
|
|
#####################################################################
|
|
|
|
|
2017-06-19 13:45:09 -05:00
|
|
|
## Special packages publish configurations
|
|
|
|
#publish:
|
|
|
|
## This will allow the publisher to publish packages even if any uplink is down.
|
|
|
|
# allow_offline: true
|
|
|
|
|
2013-09-23 23:36:43 -05:00
|
|
|
# if you use nginx with custom path, use this to override links
|
2016-08-20 11:46:54 -05:00
|
|
|
#url_prefix: https://dev.company.local/verdaccio/
|
2013-09-23 23:36:43 -05:00
|
|
|
|
2015-03-28 09:38:39 -05:00
|
|
|
# You can specify listen address (or simply a port).
|
2016-08-20 11:46:54 -05:00
|
|
|
# If you add multiple values, verdaccio will listen on all of them.
|
2015-03-28 09:38:39 -05:00
|
|
|
#
|
|
|
|
# Examples:
|
|
|
|
#
|
|
|
|
#listen:
|
|
|
|
# - localhost:4873 # default value
|
|
|
|
# - http://localhost:4873 # same thing
|
|
|
|
# - 0.0.0.0:4873 # listen on all addresses (INADDR_ANY)
|
|
|
|
# - https://example.org:4873 # if you want to use https
|
|
|
|
# - [::1]:4873 # ipv6
|
2016-08-20 11:46:54 -05:00
|
|
|
# - unix:/tmp/verdaccio.sock # unix socket
|
2015-03-28 09:38:39 -05:00
|
|
|
|
|
|
|
# Configure HTTPS, it is required if you use "https" protocol above.
|
|
|
|
#https:
|
|
|
|
# key: path/to/server.key
|
|
|
|
# cert: path/to/server.crt
|
2017-05-13 04:23:05 -05:00
|
|
|
# ca: path/to/server.pem
|
2013-09-23 23:40:46 -05:00
|
|
|
|
2013-10-11 00:32:59 -05:00
|
|
|
# type: file | stdout | stderr
|
|
|
|
# level: trace | debug | info | http (default) | warn | error | fatal
|
|
|
|
#
|
|
|
|
# parameters for file: name is filename
|
2016-08-20 11:46:54 -05:00
|
|
|
# {type: 'file', path: 'verdaccio.log', level: 'debug'},
|
2013-10-11 00:32:59 -05:00
|
|
|
#
|
2016-10-06 02:35:10 -05:00
|
|
|
# parameters for stdout and stderr: format: json | pretty | pretty-timestamped
|
2013-10-11 00:32:59 -05:00
|
|
|
# {type: 'stdout', format: 'pretty', level: 'debug'},
|
2013-10-12 09:37:47 -05:00
|
|
|
logs:
|
2013-10-11 00:32:59 -05:00
|
|
|
- {type: stdout, format: pretty, level: http}
|
2016-08-20 11:46:54 -05:00
|
|
|
#- {type: file, path: verdaccio.log, level: info}
|
2013-11-24 12:07:54 -05:00
|
|
|
|
|
|
|
# you can specify proxy used with all requests in wget-like manner here
|
|
|
|
# (or set up ENV variables with the same name)
|
|
|
|
#http_proxy: http://something.local/
|
|
|
|
#https_proxy: https://something.local/
|
|
|
|
#no_proxy: localhost,127.0.0.1
|
|
|
|
|
2014-01-18 14:04:12 -05:00
|
|
|
# maximum size of uploaded json document
|
|
|
|
# increase it if you have "request entity too large" errors
|
|
|
|
#max_body_size: 1mb
|
2016-05-20 08:48:29 -05:00
|
|
|
|
|
|
|
# Notify Settings
|
|
|
|
# Notify was built primarily to use with Slack's Incoming
|
|
|
|
# webhooks, but will also deliver a simple payload to
|
|
|
|
# any endpoint. Currently only active for publish / create
|
|
|
|
# commands.
|
2018-06-28 11:33:37 -05:00
|
|
|
#notify:
|
2016-05-20 08:48:29 -05:00
|
|
|
# Choose a method. Technically this will accept any HTTP
|
|
|
|
# request method, but probably stick to GET or POST
|
2018-06-28 11:33:37 -05:00
|
|
|
# method: POST
|
2017-01-10 03:30:56 -05:00
|
|
|
# Only run this notification if the package name matches the regular
|
|
|
|
# expression
|
2018-06-28 11:33:37 -05:00
|
|
|
# packagePattern: ^example-package$
|
2017-01-10 03:30:56 -05:00
|
|
|
# Any flags to be used with the regular expression
|
2018-06-28 11:33:37 -05:00
|
|
|
# packagePatternFlags: i
|
2016-05-20 08:48:29 -05:00
|
|
|
# If this endpoint requires specific headers, set them here
|
|
|
|
# as an array of key: value objects.
|
2018-06-28 11:33:37 -05:00
|
|
|
# headers: [{'Content-type': 'application/x-www-form-urlencoded'}]
|
2016-05-20 08:48:29 -05:00
|
|
|
# set the URL endpoint for this call
|
2018-06-28 11:33:37 -05:00
|
|
|
# endpoint: https://hooks.slack.com/...
|
2016-05-20 08:48:29 -05:00
|
|
|
# Finally, the content you will be sending in the body.
|
|
|
|
# This data will first be run through Handlebars to parse
|
|
|
|
# any Handlebar expressions. All data housed in the metadata object
|
|
|
|
# is available for use within the expressions.
|
2018-06-28 11:33:37 -05:00
|
|
|
# content: ' {{ handlebar-expression }}'
|
2016-05-20 08:48:29 -05:00
|
|
|
# For Slack, follow the following format:
|
|
|
|
# content: '{ "text": "Package *{{ name }}* published to version *{{ dist-tags.latest }}*", "username": "Verdaccio", "icon_emoji": ":package:" }'
|
2017-01-10 03:30:56 -05:00
|
|
|
|
|
|
|
# Multiple notification endpoints can be created by specifying a collection
|
2018-06-28 11:33:37 -05:00
|
|
|
# 'example-package-1':
|
|
|
|
# method: POST
|
2017-01-10 03:30:56 -05:00
|
|
|
# Only run this notification if the package name matches the regular
|
|
|
|
# expression
|
2018-06-28 11:33:37 -05:00
|
|
|
# packagePattern: ^example-package-regex$
|
2017-01-10 03:30:56 -05:00
|
|
|
# Any flags to be used with the regular expression
|
2017-07-01 17:07:42 -05:00
|
|
|
# since verdaccio 2.2.2 this property has been disabled read #108
|
|
|
|
# it will be re-enabled after 2.5.0
|
|
|
|
# packagePatternFlags: i
|
2017-01-10 03:30:56 -05:00
|
|
|
# If this endpoint requires specific headers, set them here
|
|
|
|
# as an array of key: value objects.
|
2017-07-01 17:07:42 -05:00
|
|
|
# headers supports as well a literal object
|
2018-06-28 11:33:37 -05:00
|
|
|
# headers: {'Content-type': 'application/x-www-form-urlencoded'}
|
2017-01-10 03:30:56 -05:00
|
|
|
# set the URL endpoint for this call
|
2018-06-28 11:33:37 -05:00
|
|
|
# endpoint: https://hooks.slack.com/...
|
2017-01-10 03:30:56 -05:00
|
|
|
# Finally, the content you will be sending in the body.
|
|
|
|
# This data will first be run through Handlebars to parse
|
|
|
|
# any Handlebar expressions. All data housed in the metadata object
|
|
|
|
# is available for use within the expressions.
|
2018-06-28 11:33:37 -05:00
|
|
|
# content: ' {{ handlebar-expression }}'
|
2017-01-10 03:30:56 -05:00
|
|
|
# For Slack, follow the following format:
|
|
|
|
# content: '{ "text": "Package *{{ name }}* published to version *{{ dist-tags.latest }}*", "username": "Verdaccio", "icon_emoji": ":package:" }'
|
2017-10-24 09:02:08 -05:00
|
|
|
|