Dokploy

Verdaccio

A lightweight Node.js private proxy registry

Verdaccio logo

Configuration

version: "3.8"

services:
  verdaccio:
    image: verdaccio/verdaccio:6
    environment:
      - VERDACCIO_PORT=4873
    ports:
      - 4873
    volumes:
      - verdaccio_storage:/verdaccio/storage
      - verdaccio_plugins:/verdaccio/plugins
      - ../files/conf:/verdaccio/conf

volumes:
  verdaccio_storage:
  verdaccio_plugins:
[variables]
main_domain = "${domain}"

[config]
[[config.domains]]
serviceName = "verdaccio"
port = 4873
host = "${main_domain}"

[[config.mounts]]
filePath = "/conf/config.yaml"
content = """
#
# This is the default configuration file. It allows all users to do anything,
# please read carefully the documentation and best practices to
# improve security.
#
# Look here for more config file examples:
# https://github.com/verdaccio/verdaccio/blob/master/docker-examples/README.md
#
# Read about the best practices
# https://verdaccio.org/docs/best

# Path to a directory with all packages
storage: /verdaccio/storage/data

# Path to a directory with plugins to include, the plugins folder has the higher priority for loading plugins
# Disable this folder to avoid warnings if is not used
plugins: /verdaccio/plugins

# Web UI settings
# https://verdaccio.org/docs/webui
web:
  title: Verdaccio
  # Disable complete web UI
  # enabled: false
  # Custom colors for header background and font
  # primaryColor: "#4b5e40"
  # Custom logos and favicon
  # logo: ./path/to/logo.png
  # logoDark: ./path/to/logoDark.png
  # favicon: ./path/to/favicon.ico
  # Disable gravatar support
  # gravatar: false
  # By default, packages are ordered ascending
  # sort_packages: asc | desc
  # Convert your UI to the dark side
  # darkMode: true
  # html_cache: true
  # By default, all features are displayed
  # login: true
  # showInfo: true
  # showSettings: true
  # In combination with darkMode you can force specific theme
  # showThemeSwitch: true
  # showFooter: true
  # showSearch: true
  # showRaw: true
  # showDownloadTarball: true
  # showUplinks: true
  #
  # HTML tags injected before ends </head>
  # metaScripts:
  #   - '<script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script>'
  #   - '<script type="text/javascript" src="https://browser.sentry-cdn.com/5.15.5/bundle.min.js"></script>'
  #   - '<meta name="robots" content="noindex">'
  #
  # HTML tags injected as first child in <body>
  # scriptsBodyBefore:
  #   - '<div id="myId">html before webpack scripts</div>'
  #
  # HTML tags injected as last child in </body>
  # scriptsBodyAfter:
  #   - '<script type="text/javascript" src="https://my.company.com/customJS.min.js"></script>'
  #
  # Public path for template manifest scripts (only manifest)
  # publicPath: http://somedomain.org/

# Settings for authentication plugin
# https://verdaccio.org/docs/configuration#authentication
auth:
  htpasswd:
    file: /verdaccio/storage/htpasswd
    # Maximum amount of users allowed to register, defaults to "+inf".
    # You can set this to -1 to disable registration.
    max_users: 1

# A list of other known repositories we can talk to
# https://verdaccio.org/docs/configuration#uplinks
uplinks:
  npmjs:
    url: https://registry.npmjs.org/

# Learn how to protect your packages
# https://verdaccio.org/docs/protect-your-dependencies/
# https://verdaccio.org/docs/configuration#packages
packages:
  '@*/*':
    # scoped packages
    access: $all
    publish: $authenticated
    unpublish: $authenticated
    proxy: npmjs

  '**':
    # allow all users (including non-authenticated users) to read and
    # publish all packages
    #
    # you can specify usernames/groupnames (depending on your auth plugin)
    # and three keywords: "$all", "$anonymous", "$authenticated"
    access: $all

    # allow all known users to publish/unpublish packages
    # (anyone can register by default, remember?)
    publish: $authenticated
    unpublish: $authenticated

    # if package is not available locally, proxy requests to 'npmjs' registry
    proxy: npmjs

# To improve your security configuration and avoid dependency confusion
# consider removing the proxy property for private packages
# https://verdaccio.org/docs/best#remove-proxy-to-increase-security-at-private-packages

# https://verdaccio.org/docs/configuration#server
# You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections.
# A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout.
# WORKAROUND: Through given configuration you can workaround following issue https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough.
server:
  keepAliveTimeout: 60
  # The pluginPrefix replaces the default plugins prefix which is `verdaccio`. Please don't include `-`. If `something` is provided
  # the resolved package will be `something-xxxx`.
  # pluginPrefix: something
  # A regex for the password validation /.{3}$/ (3 characters min)
  # An example to limit to 10 characters minimum
  # passwordValidationRegex: /.{10}$/
  # Allow `req.ip` to resolve properly when Verdaccio is behind a proxy or load-balancer
  # https://expressjs.com/en/guide/behind-proxies.html
  # trustProxy: '127.0.0.1'

# https://verdaccio.org/docs/configuration#offline-publish
# publish:
#   allow_offline: false
#   check_owners: false
#   keep_readmes: 'latest' | 'tagged' | 'all'

# Define public URL of registry in combination with VERDACCIO_PUBLIC_URL environment variable
# https://verdaccio.org/docs/configuration#url-prefix
# url_prefix: /verdaccio/
#
# Examples:
# VERDACCIO_PUBLIC_URL='https://somedomain.org'
# url_prefix: '/my_prefix'
# // url -> https://somedomain.org/my_prefix/
#
# VERDACCIO_PUBLIC_URL='https://somedomain.org'
# url_prefix: '/'
# // url -> https://somedomain.org/
#
# VERDACCIO_PUBLIC_URL='https://somedomain.org/first_prefix'
# url_prefix: '/second_prefix'
# // url -> https://somedomain.org/second_prefix/

# Security settings
# https://verdaccio.org/docs/configuration#security
# security:
#   api:
#     legacy: true
#     jwt:
#       sign:
#         expiresIn: 29d
#       verify:
#         someProp: [value]
#   web:
#     sign:
#       expiresIn: 1h # 1 hour by default
#     verify:
#       someProp: [value]

# https://verdaccio.org/docs/configuration#user-rate-limit
# userRateLimit:
#   windowMs: 50000
#   max: 1000

# https://verdaccio.org/docs/configuration#max-body-size
# max_body_size: 10mb

# https://verdaccio.org/docs/configuration#listen-port
# 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
#   - unix:/tmp/verdaccio.sock  # unix socket

# The HTTPS configuration is useful if you do not consider use a HTTP Proxy
# https://verdaccio.org/docs/configuration#https
# https:
#   key: ./path/verdaccio-key.pem
#   cert: ./path/verdaccio-cert.pem
#   ca: ./path/verdaccio-csr.pem

# https://verdaccio.org/docs/configuration#proxy
# http_proxy: http://something.local/
# https_proxy: https://something.local/
# no_proxy: localhost,127.0.0.1,server.local

# https://verdaccio.org/docs/configuration#notifications
# notify:
#   method: 'POST'
#   headers: '[{ "Content-Type": "application/json" }]'
#   endpoint: 'https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken'
#   content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}'

# Settings for middleware plugins
# https://verdaccio.org/docs/plugins#middleware-configuration
middlewares:
  audit:
    enabled: true
    # timeout: 10000

# Log settings
# https://verdaccio.org/docs/logger
# Redaction: https://getpino.io/#/docs/redaction
# Synchronous logging: https://getpino.io/#/docs/asynchronous
log:
  type: stdout
  format: pretty
  level: http
#  redact:
#    paths: ['req.header.authorization','req.header.cookie','req.remoteAddress','req.remotePort','ip','remoteIP','user','msg']
#    censor: '<redacted>'
#  sync: true

# Feature flags (experimental settings that can be changed or removed in the future)
# https://verdaccio.org/docs/configuration#experiments
# experiments:
#  # Support for npm token command
#  token: false
#  # Enable tarball URL redirect for hosting tarball with a different server.
#  # The tarball_url_redirect can be a template string
#  tarball_url_redirect: 'https://mycdn.com/verdaccio/${packageName}/${filename}'
#  # The tarball_url_redirect can be a function, takes packageName and filename and returns the url,
#  # when working with a js configuration file
#  tarball_url_redirect(packageName, filename) {
#    const signedUrl = // generate a signed url
#    return signedUrl;
#  }
# Renamed from "experiments" to "flags" in next major release
# flags:
#  changePassword: true
#  searchRemote: true

# Translate your registry, API and web UI
# List of the available translations https://github.com/verdaccio/verdaccio/blob/master/packages/plugins/ui-theme/src/i18n/ABOUT_TRANSLATIONS.md
i18n:
    web: en-US
"""

Base64

To import this template in Dokploy: create a Compose service → AdvancedBase64 import and paste the content below:

{
  "compose": "version: \"3.8\"\n\nservices:\n  verdaccio:\n    image: verdaccio/verdaccio:6\n    environment:\n      - VERDACCIO_PORT=4873\n    ports:\n      - 4873\n    volumes:\n      - verdaccio_storage:/verdaccio/storage\n      - verdaccio_plugins:/verdaccio/plugins\n      - ../files/conf:/verdaccio/conf\n\nvolumes:\n  verdaccio_storage:\n  verdaccio_plugins:",
  "config": "[variables]\nmain_domain = \"${domain}\"\n\n[config]\n[[config.domains]]\nserviceName = \"verdaccio\"\nport = 4873\nhost = \"${main_domain}\"\n\n[[config.mounts]]\nfilePath = \"/conf/config.yaml\"\ncontent = \"\"\"\n#\n# This is the default configuration file. It allows all users to do anything,\n# please read carefully the documentation and best practices to\n# improve security.\n#\n# Look here for more config file examples:\n# https://github.com/verdaccio/verdaccio/blob/master/docker-examples/README.md\n#\n# Read about the best practices\n# https://verdaccio.org/docs/best\n\n# Path to a directory with all packages\nstorage: /verdaccio/storage/data\n\n# Path to a directory with plugins to include, the plugins folder has the higher priority for loading plugins\n# Disable this folder to avoid warnings if is not used\nplugins: /verdaccio/plugins\n\n# Web UI settings\n# https://verdaccio.org/docs/webui\nweb:\n  title: Verdaccio\n  # Disable complete web UI\n  # enabled: false\n  # Custom colors for header background and font\n  # primaryColor: \"#4b5e40\"\n  # Custom logos and favicon\n  # logo: ./path/to/logo.png\n  # logoDark: ./path/to/logoDark.png\n  # favicon: ./path/to/favicon.ico\n  # Disable gravatar support\n  # gravatar: false\n  # By default, packages are ordered ascending\n  # sort_packages: asc | desc\n  # Convert your UI to the dark side\n  # darkMode: true\n  # html_cache: true\n  # By default, all features are displayed\n  # login: true\n  # showInfo: true\n  # showSettings: true\n  # In combination with darkMode you can force specific theme\n  # showThemeSwitch: true\n  # showFooter: true\n  # showSearch: true\n  # showRaw: true\n  # showDownloadTarball: true\n  # showUplinks: true\n  #\n  # HTML tags injected before ends </head>\n  # metaScripts:\n  #   - '<script type=\"text/javascript\" src=\"https://code.jquery.com/jquery-3.5.1.slim.min.js\"></script>'\n  #   - '<script type=\"text/javascript\" src=\"https://browser.sentry-cdn.com/5.15.5/bundle.min.js\"></script>'\n  #   - '<meta name=\"robots\" content=\"noindex\">'\n  #\n  # HTML tags injected as first child in <body>\n  # scriptsBodyBefore:\n  #   - '<div id=\"myId\">html before webpack scripts</div>'\n  #\n  # HTML tags injected as last child in </body>\n  # scriptsBodyAfter:\n  #   - '<script type=\"text/javascript\" src=\"https://my.company.com/customJS.min.js\"></script>'\n  #\n  # Public path for template manifest scripts (only manifest)\n  # publicPath: http://somedomain.org/\n\n# Settings for authentication plugin\n# https://verdaccio.org/docs/configuration#authentication\nauth:\n  htpasswd:\n    file: /verdaccio/storage/htpasswd\n    # Maximum amount of users allowed to register, defaults to \"+inf\".\n    # You can set this to -1 to disable registration.\n    max_users: 1\n\n# A list of other known repositories we can talk to\n# https://verdaccio.org/docs/configuration#uplinks\nuplinks:\n  npmjs:\n    url: https://registry.npmjs.org/\n\n# Learn how to protect your packages\n# https://verdaccio.org/docs/protect-your-dependencies/\n# https://verdaccio.org/docs/configuration#packages\npackages:\n  '@*/*':\n    # scoped packages\n    access: $all\n    publish: $authenticated\n    unpublish: $authenticated\n    proxy: npmjs\n\n  '**':\n    # allow all users (including non-authenticated users) to read and\n    # publish all packages\n    #\n    # you can specify usernames/groupnames (depending on your auth plugin)\n    # and three keywords: \"$all\", \"$anonymous\", \"$authenticated\"\n    access: $all\n\n    # allow all known users to publish/unpublish packages\n    # (anyone can register by default, remember?)\n    publish: $authenticated\n    unpublish: $authenticated\n\n    # if package is not available locally, proxy requests to 'npmjs' registry\n    proxy: npmjs\n\n# To improve your security configuration and avoid dependency confusion\n# consider removing the proxy property for private packages\n# https://verdaccio.org/docs/best#remove-proxy-to-increase-security-at-private-packages\n\n# https://verdaccio.org/docs/configuration#server\n# You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections.\n# A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout.\n# WORKAROUND: Through given configuration you can workaround following issue https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough.\nserver:\n  keepAliveTimeout: 60\n  # The pluginPrefix replaces the default plugins prefix which is `verdaccio`. Please don't include `-`. If `something` is provided\n  # the resolved package will be `something-xxxx`.\n  # pluginPrefix: something\n  # A regex for the password validation /.{3}$/ (3 characters min)\n  # An example to limit to 10 characters minimum\n  # passwordValidationRegex: /.{10}$/\n  # Allow `req.ip` to resolve properly when Verdaccio is behind a proxy or load-balancer\n  # https://expressjs.com/en/guide/behind-proxies.html\n  # trustProxy: '127.0.0.1'\n\n# https://verdaccio.org/docs/configuration#offline-publish\n# publish:\n#   allow_offline: false\n#   check_owners: false\n#   keep_readmes: 'latest' | 'tagged' | 'all'\n\n# Define public URL of registry in combination with VERDACCIO_PUBLIC_URL environment variable\n# https://verdaccio.org/docs/configuration#url-prefix\n# url_prefix: /verdaccio/\n#\n# Examples:\n# VERDACCIO_PUBLIC_URL='https://somedomain.org'\n# url_prefix: '/my_prefix'\n# // url -> https://somedomain.org/my_prefix/\n#\n# VERDACCIO_PUBLIC_URL='https://somedomain.org'\n# url_prefix: '/'\n# // url -> https://somedomain.org/\n#\n# VERDACCIO_PUBLIC_URL='https://somedomain.org/first_prefix'\n# url_prefix: '/second_prefix'\n# // url -> https://somedomain.org/second_prefix/\n\n# Security settings\n# https://verdaccio.org/docs/configuration#security\n# security:\n#   api:\n#     legacy: true\n#     jwt:\n#       sign:\n#         expiresIn: 29d\n#       verify:\n#         someProp: [value]\n#   web:\n#     sign:\n#       expiresIn: 1h # 1 hour by default\n#     verify:\n#       someProp: [value]\n\n# https://verdaccio.org/docs/configuration#user-rate-limit\n# userRateLimit:\n#   windowMs: 50000\n#   max: 1000\n\n# https://verdaccio.org/docs/configuration#max-body-size\n# max_body_size: 10mb\n\n# https://verdaccio.org/docs/configuration#listen-port\n# listen:\n#   - localhost:4873            # default value\n#   - http://localhost:4873     # same thing\n#   - 0.0.0.0:4873              # listen on all addresses (INADDR_ANY)\n#   - https://example.org:4873  # if you want to use https\n#   - \"[::1]:4873\"              # ipv6\n#   - unix:/tmp/verdaccio.sock  # unix socket\n\n# The HTTPS configuration is useful if you do not consider use a HTTP Proxy\n# https://verdaccio.org/docs/configuration#https\n# https:\n#   key: ./path/verdaccio-key.pem\n#   cert: ./path/verdaccio-cert.pem\n#   ca: ./path/verdaccio-csr.pem\n\n# https://verdaccio.org/docs/configuration#proxy\n# http_proxy: http://something.local/\n# https_proxy: https://something.local/\n# no_proxy: localhost,127.0.0.1,server.local\n\n# https://verdaccio.org/docs/configuration#notifications\n# notify:\n#   method: 'POST'\n#   headers: '[{ \"Content-Type\": \"application/json\" }]'\n#   endpoint: 'https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken'\n#   content: '{\"color\":\"green\",\"message\":\"New package published: * {{ name }}*\",\"notify\":true,\"message_format\":\"text\"}'\n\n# Settings for middleware plugins\n# https://verdaccio.org/docs/plugins#middleware-configuration\nmiddlewares:\n  audit:\n    enabled: true\n    # timeout: 10000\n\n# Log settings\n# https://verdaccio.org/docs/logger\n# Redaction: https://getpino.io/#/docs/redaction\n# Synchronous logging: https://getpino.io/#/docs/asynchronous\nlog:\n  type: stdout\n  format: pretty\n  level: http\n#  redact:\n#    paths: ['req.header.authorization','req.header.cookie','req.remoteAddress','req.remotePort','ip','remoteIP','user','msg']\n#    censor: '<redacted>'\n#  sync: true\n\n# Feature flags (experimental settings that can be changed or removed in the future)\n# https://verdaccio.org/docs/configuration#experiments\n# experiments:\n#  # Support for npm token command\n#  token: false\n#  # Enable tarball URL redirect for hosting tarball with a different server.\n#  # The tarball_url_redirect can be a template string\n#  tarball_url_redirect: 'https://mycdn.com/verdaccio/${packageName}/${filename}'\n#  # The tarball_url_redirect can be a function, takes packageName and filename and returns the url,\n#  # when working with a js configuration file\n#  tarball_url_redirect(packageName, filename) {\n#    const signedUrl = // generate a signed url\n#    return signedUrl;\n#  }\n# Renamed from \"experiments\" to \"flags\" in next major release\n# flags:\n#  changePassword: true\n#  searchRemote: true\n\n# Translate your registry, API and web UI\n# List of the available translations https://github.com/verdaccio/verdaccio/blob/master/packages/plugins/ui-theme/src/i18n/ABOUT_TRANSLATIONS.md\ni18n:\n    web: en-US\n\"\"\""
}

Tags

node.js, package-repository, npm


Version: 6

On this page