37 KiB
@verdaccio/config
8.0.0-next-8.3
Patch Changes
- @verdaccio/core@8.0.0-next-8.3
- @verdaccio/utils@8.1.0-next-8.3
8.0.0-next-8.2
Minor Changes
6a8154c
: feat: update logger pino to latest
Patch Changes
- Updated dependencies [
6a8154c
]- @verdaccio/core@8.0.0-next-8.2
- @verdaccio/utils@7.1.0-next-8.2
8.0.0-next-8.1
Patch Changes
- @verdaccio/core@8.0.0-next-8.1
- @verdaccio/utils@7.0.1-next-8.1
8.0.0-next-8.0
Major Changes
- chore: move v7 next to v8 next
Patch Changes
- Updated dependencies
- @verdaccio/core@8.0.0-next-8.0
- @verdaccio/utils@7.0.1-next-8.0
7.0.0
Major Changes
Minor Changes
daceb6d
: restore legacy supportc9962fe
: feat: forbidden user interfacef047cc8
: refactor: auth with legacy sign supportbd8703e
: feat: add migrateToSecureLegacySignature and remove enhancedLegacySignature property
Patch Changes
10dd81f
: feat: complete overhaul of web user interface6e764e3
: feat: add support for npm owner8c10a3e
: chore: improve debug code and refactor codea99a4bb
: fix config builder erroring when passed partial configa05a7d8
: fix(config): test runs on Windowsc31aec8
: fix: typo in config docs regarding check_owners4d96324
: chore(config): increase test coverage- Updated dependencies [
47f61c6
] - Updated dependencies [
6e764e3
] - Updated dependencies [
daceb6d
] - Updated dependencies [
e7ebccb
] - Updated dependencies [
f047cc8
] - Updated dependencies [
7c9f3cf
] - Updated dependencies [
bd8703e
]- @verdaccio/core@7.0.0
- @verdaccio/utils@7.0.0
7.0.0-next-8.21
Patch Changes
8c10a3e
: chore: improve debug code and refactor codea05a7d8
: fix(config): test runs on Windows- Updated dependencies [
7c9f3cf
]- @verdaccio/core@7.0.0-next-8.21
- @verdaccio/utils@7.0.0-next-8.21
7.0.0-next-7.20
Patch Changes
- @verdaccio/core@7.0.0-next-7.20
- @verdaccio/utils@7.0.0-next-7.20
7.0.0-next-7.19
Patch Changes
c31aec8
: fix: typo in config docs regarding check_owners- @verdaccio/core@7.0.0-next-7.19
- @verdaccio/utils@7.0.0-next-7.19
7.0.0-next-7.18
Patch Changes
10dd81f
: feat: complete overhaul of web user interface- @verdaccio/core@7.0.0-next-7.18
- @verdaccio/utils@7.0.0-next-7.18
7.0.0-next-7.17
Patch Changes
6e764e3
: feat: add support for npm owner- Updated dependencies [
6e764e3
]- @verdaccio/core@7.0.0-next-7.17
- @verdaccio/utils@7.0.0-next-7.17
7.0.0-next-7.16
Patch Changes
- @verdaccio/core@7.0.0-next-7.16
- @verdaccio/utils@7.0.0-next-7.16
7.0.0-next-7.15
Minor Changes
bd8703e
: feat: add migrateToSecureLegacySignature and remove enhancedLegacySignature property
Patch Changes
- Updated dependencies [
bd8703e
]- @verdaccio/core@7.0.0-next-7.15
- @verdaccio/utils@7.0.0-next-7.15
7.0.0-next-7.14
Patch Changes
- @verdaccio/core@7.0.0-next-7.14
- @verdaccio/utils@7.0.0-next-7.14
7.0.0-next-7.13
Patch Changes
a99a4bb
: fix config builder erroring when passed partial config- @verdaccio/core@7.0.0-next-7.13
- @verdaccio/utils@7.0.0-next-7.13
7.0.0-next-7.12
Patch Changes
- @verdaccio/core@7.0.0-next-7.12
- @verdaccio/utils@7.0.0-next-7.12
7.0.0-next-7.11
Minor Changes
c9962fe
: feat: forbidden user interface
Patch Changes
- @verdaccio/core@7.0.0-next-7.11
- @verdaccio/utils@7.0.0-next-7.11
7.0.0-next-7.10
Patch Changes
- @verdaccio/core@7.0.0-next-7.10
- @verdaccio/utils@7.0.0-next-7.10
7.0.0-next-7.9
Patch Changes
- @verdaccio/core@7.0.0-next-7.9
- @verdaccio/utils@7.0.0-next-7.9
7.0.0-next-7.8
Patch Changes
- @verdaccio/core@7.0.0-next-7.8
- @verdaccio/utils@7.0.0-next-7.8
7.0.0-next-7.7
Patch Changes
- @verdaccio/core@7.0.0-next-7.7
- @verdaccio/utils@7.0.0-next-7.7
7.0.0-next.6
Patch Changes
4d96324
: chore(config): increase test coverage- @verdaccio/core@7.0.0-next.6
- @verdaccio/utils@7.0.0-next.6
7.0.0-next.5
Minor Changes
f047cc8
: refactor: auth with legacy sign support
Patch Changes
- Updated dependencies [
f047cc8
]- @verdaccio/core@7.0.0-next.5
- @verdaccio/utils@7.0.0-next.5
7.0.0-next.4
Patch Changes
- @verdaccio/core@7.0.0-next.4
- @verdaccio/utils@7.0.0-next.4
7.0.0-next.3
Major Changes
e7ebccb61
: update major dependencies, remove old nodejs support
Minor Changes
daceb6d87
: restore legacy support
Patch Changes
- Updated dependencies [
daceb6d87
] - Updated dependencies [
e7ebccb61
]- @verdaccio/core@7.0.0-next.3
- @verdaccio/utils@7.0.0-next.3
7.0.0-next.2
Patch Changes
- @verdaccio/core@7.0.0-next.2
- @verdaccio/utils@7.0.0-next.2
7.0.0-next.1
Patch Changes
- @verdaccio/core@7.0.0-next.1
- @verdaccio/utils@7.0.0-next.1
7.0.0-next.0
Major Changes
- feat!: bump to v7
Patch Changes
- Updated dependencies
- @verdaccio/core@7.0.0-next.0
- @verdaccio/utils@7.0.0-next.0
6.0.0
Major Changes
-
292c0a37f
: feat!: replace deprecated request dependency by gotThis is a big refactoring of the core, fetching dependencies, improve code, more tests and better stability. This is essential for the next release, will take some time but would allow modularize more the core.
Notes
- Remove deprecated
request
by othergot
, retry improved, custom Agent ( got does not include it built-in) - Remove
async
dependency from storage (used by core) it was linked with proxy somehow safe to remove now - Refactor with promises instead callback wherever is possible
Document the API- Improve testing, integration tests
- Bugfix
- Clean up old validations
- Improve performance
💥 Breaking changes
- Plugin API methods were callbacks based are returning promises, this will break current storage plugins, check documentation for upgrade.
- Write Tarball, Read Tarball methods parameters change, a new set of options like
AbortController
signals are being provided to theaddAbortSignal
can be internally used with Streams when a request is aborted. eg:addAbortSignal(signal, fs.createReadStream(pathName));
@verdaccio/streams
stream abort support is legacy is being deprecated removed- Remove AWS and Google Cloud packages for future refactoring #2574.
- Remove deprecated
-
459b6fa72
: refactor: search v1 endpoint and local-database- refactor search
api v1
endpoint, improve performance - remove usage of
async
dependency https://github.com/verdaccio/verdaccio/issues/1225 - refactor method storage class
- create new module
core
to reduce the ammount of modules with utilities - use
undici
insteadnode-fetch
- use
fastify
insteadexpress
for functional test
Breaking changes
- plugin storage API changes
- remove old search endpoint (return 404)
- filter local private packages at plugin level
The storage api changes for methods
get
,add
,remove
as promise base. Thesearch
methods also changes and recieves aquery
object that contains all query params from the client.export interface IPluginStorage<T> extends IPlugin { add(name: string): Promise<void>; remove(name: string): Promise<void>; get(): Promise<any>; init(): Promise<void>; getSecret(): Promise<string>; setSecret(secret: string): Promise<any>; getPackageStorage(packageInfo: string): IPackageStorage; search(query: searchUtils.SearchQuery): Promise<searchUtils.SearchItem[]>; saveToken(token: Token): Promise<any>; deleteToken(user: string, tokenKey: string): Promise<any>; readTokens(filter: TokenFilter): Promise<Token[]>; }
- refactor search
-
9fc2e7961
: feat(plugins): improve plugin loaderChanges
- Add scope plugin support to 6.x https://github.com/verdaccio/verdaccio/pull/3227
- Avoid config collisions https://github.com/verdaccio/verdaccio/issues/928
- https://github.com/verdaccio/verdaccio/issues/1394
config.plugins
plugin path validations- Updated algorithm for plugin loader.
- improved documentation (included dev)
Features
- Add scope plugin support to 6.x https://github.com/verdaccio/verdaccio/pull/3227
- Custom prefix:
// config.yaml server: pluginPrefix: mycompany middleware: audit: foo: 1
This configuration will look up for
mycompany-audit
insteadVerdaccio-audit
.Breaking Changes
sinopia plugins
sinopia
fallback support is removed, but can be restored usingpluginPrefix
plugin filter
- method rename
filter_metadata
->filterMetadata
Plugin constructor does not merge configs anymore https://github.com/verdaccio/verdaccio/issues/928
The plugin receives as first argument
config
, which represents the config of the plugin. Example:// config.yaml auth: plugin: foo: 1 bar: 2 export class Plugin<T> { public constructor(config: T, options: PluginOptions) { console.log(config); // {foo:1, bar: 2} } }
-
794af76c5
: Remove Node 12 support- We need move to the new
undici
and does not support Node.js 12
- We need move to the new
-
10aeb4f13
: feat!: experiments config renamed to flags- The
experiments
configuration is renamed toflags
. The functionality is exactly the same.
flags: token: false; search: false;
- The
self_path
property from the config file is being removed in favor ofconfig_file
full path. - Refactor
config
module, better types and utilities
- The
-
e367c3f1e
: - Replace signature handler for legacy tokens by removing deprecated crypto.createDecipher by createCipheriv- Introduce environment variables for legacy tokens
Code Improvements
- Add debug library for improve developer experience
Breaking change
- The new signature invalidates all previous tokens generated by Verdaccio 4 or previous versions.
- The secret key must have 32 characters long.
New environment variables
VERDACCIO_LEGACY_ALGORITHM
: Allows to define the specific algorithm for the token signature which by default isaes-256-ctr
VERDACCIO_LEGACY_ENCRYPTION_KEY
: By default, the token stores in the database, but using this variable allows to get it from memory
-
82cb0f2bf
: feat!: config.logs throw an error, logging config not longer accept array or logs property💥 Breaking change
This is valid
log: { type: stdout, format: pretty, level: http }
This is invalid
logs: { type: stdout, format: pretty, level: http }
or
logs: - [{ type: stdout, format: pretty, level: http }]
-
8f43bf17d
: feat: node api new structure based on promiseimport { runServer } from "@verdaccio/node-api"; // or import { runServer } from "verdaccio"; const app = await runServer(); // default configuration const app = await runServer("./config/config.yaml"); const app = await runServer({ configuration }); app.listen(4000, (event) => { // do something });
Breaking Change
If you are using the node-api, the new structure is Promise based and less arguments.
Minor Changes
-
ef88da3b4
: feat: improve support for fs promises older nodejs -
1b217fd34
: Some verdaccio modules depend on 'mkdirp' library which provides recursive directory creation functionality. NodeJS can do this out of the box since v.10.12. The last commit in 'mkdirp' was made in early 2016, and it's mid 2021 now. Time to stick with a built-in library solution!- All 'mkdirp' calls are replaced with appropriate 'fs' calls.
-
d167f92e1
: chore: rollback yaml dep support old nodejs versions -
ddb6a2239
: feat: signature package -
b61f762d6
: feat: add server rate limit protection to all requestTo modify custom values, use the server settings property.
server: ## https://www.npmjs.com/package/express-rate-limit#configuration-options rateLimit: windowMs: 1000 max: 10000
The values are intended to be high, if you want to improve security of your server consider using different values.
-
d43894e8f
: feat: rework web header for mobile, add new settings and raw manifest buttonNew set of variables to hide features
Add set of new variables that allow hide different parts of the UI, buttons, footer or download tarballs. All are enabled by default.
# login: true <-- already exist but worth the reminder # showInfo: true # showSettings: true # In combination with darkMode you can force specific theme # showThemeSwitch: true # showFooter: true # showSearch: true # showDownloadTarball: true
If you disable
showThemeSwitch
and forcedarkMode: true
the local storage settings would be ignored and force all themes to the one in the configuration file.Future could be extended to
Raw button to display manifest package
A new experimental feature (enabled by default), button named RAW to be able navigate on the package manifest directly on the ui, kudos to react-json-view that allows an easy integration, not configurable yet until get more feedback.
showRaw: true
Rework header buttons
- The header has been rework, the mobile was not looking broken.
- Removed info button in the header and moved to a dialog
- Info dialog now contains more information about the project, license and the aid content for Ukrania now is inside of the info modal.
- Separate settings and info to avoid collapse too much info (for mobile still need some work)
-
154b2ecd3
: refactor: remove @verdaccio/commons-api in favor @verdaccio/core and remove duplications -
aa763baec
: feat: add typescript project references settingsReading https://ebaytech.berlin/optimizing-multi-package-apps-with-typescript-project-references-d5c57a3b4440 I realized I can use project references to solve the issue to pre-compile modules on develop mode.
It allows to navigate (IDE) trough the packages without need compile the packages.
Add two
tsconfig
, one using the previous existing configuration that is able to produce declaration files (tsconfig.build
) and a new onetsconfig
which is enables projects references. -
16e38df8a
: feat: trustProxy property -
dc571aabd
: feat: add forceEnhancedLegacySignature -
62c24b632
: feat: add passwordValidationRegex property -
d08fe29d9
: feat(web): add a config item to web,let the developer can select whet……her enable the html cache -
5167bb528
: feat: ui search support for remote, local and private packagesThe command
npm search
search globally and return all matches, with this improvement the user interface is powered with the same capabilities.The UI also tag where is the origin the package with a tag, also provide the latest version and description of the package.
-
4b29d715b
: chore: move improvements from v5 to v6Migrate improvements form v5 to v6:
-
45c03819e
: refactor: render html middleware
Patch Changes
-
679c19c1b
: Respect thechangePassword
configuration flag to enable changing the password through the web API.Note
This feature is still experimental and not fully supported in the default web application.
-
9718e0330
: fix: build targets for 5x modules -
1810ed0d8
: Feature- add option to set storage from environment variable VERDACCIO_STORAGE_PATH
Related tickets
-
a610ef26b
: chore: add release step to private regisry on merge changeset pr -
34f0f1101
: Enable prerelease mode with changesets -
68ea21214
: ESLint Warnings FixedRelated to issue #1461
- max-len: most of the sensible max-len errors are fixed
- no-unused-vars: most of these types of errors are fixed by deleting not needed declarations
- @typescript-eslint/no-unused-vars: same as above
-
Updated dependencies [
292c0a37f
] -
Updated dependencies [
a1986e098
] -
Updated dependencies [
974cd8c19
] -
Updated dependencies [
a828271d6
] -
Updated dependencies [
ef88da3b4
] -
Updated dependencies [
43f32687c
] -
Updated dependencies [
a3a209b5e
] -
Updated dependencies [
459b6fa72
] -
Updated dependencies [
24b9be020
] -
Updated dependencies [
794af76c5
] -
Updated dependencies [
351aeeaa8
] -
Updated dependencies [
10aeb4f13
] -
Updated dependencies [
9718e0330
] -
Updated dependencies [
e367c3f1e
] -
Updated dependencies [
a1da11308
] -
Updated dependencies [
d2c65da9c
] -
Updated dependencies [
00d1d2a17
] -
Updated dependencies [
a610ef26b
] -
Updated dependencies [
648575aa4
] -
Updated dependencies [
b61f762d6
] -
Updated dependencies [
154b2ecd3
] -
Updated dependencies [
aa763baec
] -
Updated dependencies [
378e907d5
] -
Updated dependencies [
16e38df8a
] -
Updated dependencies [
34f0f1101
] -
Updated dependencies [
82cb0f2bf
] -
Updated dependencies [
dc571aabd
] -
Updated dependencies [
f859d2b1a
] -
Updated dependencies [
6c1eb021b
] -
Updated dependencies [
62c24b632
] -
Updated dependencies [
0a6412ca9
] -
Updated dependencies [
5167bb528
] -
Updated dependencies [
f86c31ed0
] -
Updated dependencies [
c9d1af0e5
] -
Updated dependencies [
4b29d715b
] -
Updated dependencies [
b13a3fefd
] -
Updated dependencies [
68ea21214
] -
Updated dependencies [
b849128de
]- @verdaccio/core@6.0.0
- @verdaccio/utils@6.0.0
6.0.0-6-next.76
Patch Changes
- @verdaccio/core@6.0.0-6-next.76
- @verdaccio/utils@6.0.0-6-next.44
6.0.0-6-next.75
Patch Changes
- Updated dependencies [
0a6412ca9
]- @verdaccio/core@6.0.0-6-next.75
- @verdaccio/utils@6.0.0-6-next.43
6.0.0-6-next.74
Patch Changes
- @verdaccio/core@6.0.0-6-next.74
- @verdaccio/utils@6.0.0-6-next.42
6.0.0-6-next.73
Patch Changes
- Updated dependencies [
f859d2b1a
]- @verdaccio/core@6.0.0-6-next.73
- @verdaccio/utils@6.0.0-6-next.41
6.0.0-6-next.72
Patch Changes
- @verdaccio/core@6.0.0-6-next.72
- @verdaccio/utils@6.0.0-6-next.40
6.0.0-6-next.71
Patch Changes
-
679c19c1b
: Respect thechangePassword
configuration flag to enable changing the password through the web API.Note
This feature is still experimental and not fully supported in the default web application.
- @verdaccio/core@6.0.0-6-next.71
- @verdaccio/utils@6.0.0-6-next.39
6.0.0-6-next.70
Patch Changes
- @verdaccio/core@6.0.0-6-next.70
- @verdaccio/utils@6.0.0-6-next.38
6.0.0-6-next.69
Patch Changes
- Updated dependencies [
c9d1af0e
]- @verdaccio/core@6.0.0-6-next.69
- @verdaccio/utils@6.0.0-6-next.37
6.0.0-6-next.68
Patch Changes
- @verdaccio/core@6.0.0-6-next.68
- @verdaccio/utils@6.0.0-6-next.36
6.0.0-6-next.67
Minor Changes
16e38df8
: feat: trustProxy property
Patch Changes
- Updated dependencies [
16e38df8
]- @verdaccio/core@6.0.0-6-next.67
- @verdaccio/utils@6.0.0-6-next.35
6.0.0-6-next.66
Patch Changes
- @verdaccio/core@6.0.0-6-next.66
- @verdaccio/utils@6.0.0-6-next.34
6.0.0-6-next.65
Patch Changes
- Updated dependencies [
a1da1130
]- @verdaccio/core@6.0.0-6-next.65
- @verdaccio/utils@6.0.0-6-next.33
6.0.0-6-next.64
Patch Changes
- Updated dependencies [
974cd8c1
]- @verdaccio/core@6.0.0-6-next.64
- @verdaccio/utils@6.0.0-6-next.32
6.0.0-6-next.63
Minor Changes
Patch Changes
- Updated dependencies [
dc571aab
]- @verdaccio/core@6.0.0-6-next.63
- @verdaccio/utils@6.0.0-6-next.31
6.0.0-6-next.62
Patch Changes
- Updated dependencies [
378e907d
]- @verdaccio/core@6.0.0-6-next.62
- @verdaccio/utils@6.0.0-6-next.30
6.0.0-6-next.61
Minor Changes
d167f92e
: chore: rollback yaml dep support old nodejs versions
Patch Changes
- @verdaccio/core@6.0.0-6-next.61
- @verdaccio/utils@6.0.0-6-next.29
6.0.0-6-next.60
Minor Changes
45c03819
: refactor: render html middleware
Patch Changes
- @verdaccio/core@6.0.0-6-next.60
- @verdaccio/utils@6.0.0-6-next.28
6.0.0-6-next.59
Patch Changes
- @verdaccio/core@6.0.0-6-next.59
- @verdaccio/utils@6.0.0-6-next.27
6.0.0-6-next.58
Patch Changes
- @verdaccio/core@6.0.0-6-next.58
- @verdaccio/utils@6.0.0-6-next.26
6.0.0-6-next.57
Patch Changes
- @verdaccio/core@6.0.0-6-next.57
- @verdaccio/utils@6.0.0-6-next.25
6.0.0-6-next.56
Patch Changes
- Updated dependencies [
a1986e09
]- @verdaccio/utils@6.0.0-6-next.24
- @verdaccio/core@6.0.0-6-next.56
6.0.0-6-next.55
Patch Changes
9718e033
: fix: build targets for 5x modules- Updated dependencies [
9718e033
]- @verdaccio/core@6.0.0-6-next.55
- @verdaccio/utils@6.0.0-6-next.23
6.0.0-6-next.54
Minor Changes
ef88da3b
: feat: improve support for fs promises older nodejs
Patch Changes
- Updated dependencies [
ef88da3b
]- @verdaccio/core@6.0.0-6-next.54
- @verdaccio/utils@6.0.0-6-next.22
6.0.0-6-next.53
Patch Changes
- @verdaccio/core@6.0.0-6-next.53
- @verdaccio/utils@6.0.0-6-next.21
6.0.0-6-next.52
Patch Changes
- @verdaccio/core@6.0.0-6-next.52
- @verdaccio/utils@6.0.0-6-next.20
6.0.0-6-next.51
Minor Changes
-
4b29d715
: chore: move improvements from v5 to v6Migrate improvements form v5 to v6:
Patch Changes
- Updated dependencies [
4b29d715
]- @verdaccio/core@6.0.0-6-next.51
- @verdaccio/utils@6.0.0-6-next.19
6.0.0-6-next.50
Patch Changes
- @verdaccio/core@6.0.0-6-next.50
- @verdaccio/utils@6.0.0-6-next.18
6.0.0-6-next.49
Patch Changes
- @verdaccio/core@6.0.0-6-next.49
- @verdaccio/utils@6.0.0-6-next.17
6.0.0-6-next.48
Major Changes
-
9fc2e796
: feat(plugins): improve plugin loaderChanges
- Add scope plugin support to 6.x https://github.com/verdaccio/verdaccio/pull/3227
- Avoid config collisions https://github.com/verdaccio/verdaccio/issues/928
- https://github.com/verdaccio/verdaccio/issues/1394
config.plugins
plugin path validations- Updated algorithm for plugin loader.
- improved documentation (included dev)
Features
- Add scope plugin support to 6.x https://github.com/verdaccio/verdaccio/pull/3227
- Custom prefix:
// config.yaml server: pluginPrefix: mycompany middleware: audit: foo: 1
This configuration will look up for
mycompany-audit
insteadVerdaccio-audit
.Breaking Changes
sinopia plugins
sinopia
fallback support is removed, but can be restored usingpluginPrefix
plugin filter
- method rename
filter_metadata
->filterMetadata
Plugin constructor does not merge configs anymore https://github.com/verdaccio/verdaccio/issues/928
The plugin receives as first argument
config
, which represents the config of the plugin. Example:// config.yaml auth: plugin: foo: 1 bar: 2 export class Plugin<T> { public constructor(config: T, options: PluginOptions) { console.log(config); // {foo:1, bar: 2} } }
Minor Changes
62c24b63
: feat: add passwordValidationRegex property
Patch Changes
- Updated dependencies [
43f32687
] - Updated dependencies [
62c24b63
]- @verdaccio/core@6.0.0-6-next.48
- @verdaccio/utils@6.0.0-6-next.16
6.0.0-6-next.47
Patch Changes
- @verdaccio/core@6.0.0-6-next.47
- @verdaccio/utils@6.0.0-6-next.15
6.0.0-6-next.17
Patch Changes
- Updated dependencies [
b849128d
]- @verdaccio/core@6.0.0-6-next.8
- @verdaccio/utils@6.0.0-6-next.14
6.0.0-6-next.16
Patch Changes
- Updated dependencies [
351aeeaa
]- @verdaccio/core@6.0.0-6-next.7
- @verdaccio/utils@6.0.0-6-next.13
6.0.0-6-next.15
Major Changes
-
292c0a37
: feat!: replace deprecated request dependency by gotThis is a big refactoring of the core, fetching dependencies, improve code, more tests and better stability. This is essential for the next release, will take some time but would allow modularize more the core.
Notes
- Remove deprecated
request
by othergot
, retry improved, custom Agent ( got does not include it built-in) - Remove
async
dependency from storage (used by core) it was linked with proxy somehow safe to remove now - Refactor with promises instead callback wherever is possible
Document the API- Improve testing, integration tests
- Bugfix
- Clean up old validations
- Improve performance
💥 Breaking changes
- Plugin API methods were callbacks based are returning promises, this will break current storage plugins, check documentation for upgrade.
- Write Tarball, Read Tarball methods parameters change, a new set of options like
AbortController
signals are being provided to theaddAbortSignal
can be internally used with Streams when a request is aborted. eg:addAbortSignal(signal, fs.createReadStream(pathName));
@verdaccio/streams
stream abort support is legacy is being deprecated removed- Remove AWS and Google Cloud packages for future refactoring #2574.
- Remove deprecated
Patch Changes
- Updated dependencies [
292c0a37
] - Updated dependencies [
a3a209b5
] - Updated dependencies [
00d1d2a1
]- @verdaccio/core@6.0.0-6-next.6
- @verdaccio/utils@6.0.0-6-next.12
6.0.0-6-next.14
Minor Changes
-
d43894e8
: feat: rework web header for mobile, add new settings and raw manifest buttonNew set of variables to hide features
Add set of new variables that allow hide different parts of the UI, buttons, footer or download tarballs. All are enabled by default.
# login: true <-- already exist but worth the reminder # showInfo: true # showSettings: true # In combination with darkMode you can force specific theme # showThemeSwitch: true # showFooter: true # showSearch: true # showDownloadTarball: true
If you disable
showThemeSwitch
and forcedarkMode: true
the local storage settings would be ignored and force all themes to the one in the configuration file.Future could be extended to
Raw button to display manifest package
A new experimental feature (enabled by default), button named RAW to be able navigate on the package manifest directly on the ui, kudos to react-json-view that allows an easy integration, not configurable yet until get more feedback.
showRaw: true
Rework header buttons
- The header has been rework, the mobile was not looking broken.
- Removed info button in the header and moved to a dialog
- Info dialog now contains more information about the project, license and the aid content for Ukrania now is inside of the info modal.
- Separate settings and info to avoid collapse too much info (for mobile still need some work)
-
d08fe29d
: feat(web): add a config item to web,let the developer can select whet……her enable the html cache
Patch Changes
- @verdaccio/core@6.0.0-6-next.5
6.0.0-6-next.13
Major Changes
-
82cb0f2b
: feat!: config.logs throw an error, logging config not longer accept array or logs property💥 Breaking change
This is valid
log: { type: stdout, format: pretty, level: http }
This is invalid
logs: { type: stdout, format: pretty, level: http }
or
logs: - [{ type: stdout, format: pretty, level: http }]
Minor Changes
-
5167bb52
: feat: ui search support for remote, local and private packagesThe command
npm search
search globally and return all matches, with this improvement the user interface is powered with the same capabilities.The UI also tag where is the origin the package with a tag, also provide the latest version and description of the package.
Patch Changes
- Updated dependencies [
82cb0f2b
] - Updated dependencies [
5167bb52
]- @verdaccio/core@6.0.0-6-next.5
- @verdaccio/utils@6.0.0-6-next.11
6.0.0-6-next.12
Patch Changes
- Updated dependencies [
a828271d
] - Updated dependencies [
24b9be02
] - Updated dependencies [
b13a3fef
]- @verdaccio/utils@6.0.0-6-next.10
- @verdaccio/core@6.0.0-6-next.4
6.0.0-6-next.11
Patch Changes
- Updated dependencies [
f86c31ed
]- @verdaccio/utils@6.0.0-6-next.9
6.0.0-6-next.10
Patch Changes
- Updated dependencies [
6c1eb021
]- @verdaccio/core@6.0.0-6-next.3
- @verdaccio/utils@6.0.0-6-next.8
6.0.0-6-next.9
Major Changes
-
794af76c
: Remove Node 12 support- We need move to the new
undici
and does not support Node.js 12
- We need move to the new
Minor Changes
154b2ecd
: refactor: remove @verdaccio/commons-api in favor @verdaccio/core and remove duplications
Patch Changes
- Updated dependencies [
794af76c
] - Updated dependencies [
154b2ecd
]- @verdaccio/core@6.0.0-6-next.2
- @verdaccio/utils@6.0.0-6-next.7
6.0.0-6-next.8
Major Changes
-
459b6fa7
: refactor: search v1 endpoint and local-database- refactor search
api v1
endpoint, improve performance - remove usage of
async
dependency https://github.com/verdaccio/verdaccio/issues/1225 - refactor method storage class
- create new module
core
to reduce the ammount of modules with utilities - use
undici
insteadnode-fetch
- use
fastify
insteadexpress
for functional test
Breaking changes
- plugin storage API changes
- remove old search endpoint (return 404)
- filter local private packages at plugin level
The storage api changes for methods
get
,add
,remove
as promise base. Thesearch
methods also changes and recieves aquery
object that contains all query params from the client.export interface IPluginStorage<T> extends IPlugin { add(name: string): Promise<void>; remove(name: string): Promise<void>; get(): Promise<any>; init(): Promise<void>; getSecret(): Promise<string>; setSecret(secret: string): Promise<any>; getPackageStorage(packageInfo: string): IPackageStorage; search(query: searchUtils.SearchQuery): Promise<searchUtils.SearchItem[]>; saveToken(token: Token): Promise<any>; deleteToken(user: string, tokenKey: string): Promise<any>; readTokens(filter: TokenFilter): Promise<Token[]>; }
- refactor search
Patch Changes
- Updated dependencies [
459b6fa7
]- @verdaccio/commons-api@11.0.0-6-next.4
- @verdaccio/utils@6.0.0-6-next.6
6.0.0-6-next.7
Patch Changes
- Updated dependencies [
d2c65da9
]- @verdaccio/utils@6.0.0-6-next.5
6.0.0-6-next.6
Minor Changes
-
1b217fd3
: Some verdaccio modules depend on 'mkdirp' library which provides recursive directory creation functionality. NodeJS can do this out of the box since v.10.12. The last commit in 'mkdirp' was made in early 2016, and it's mid 2021 now. Time to stick with a built-in library solution!- All 'mkdirp' calls are replaced with appropriate 'fs' calls.
6.0.0-6-next.5
Patch Changes
-
1810ed0d
: Feature- add option to set storage from environment variable VERDACCIO_STORAGE_PATH
Related tickets
-
Updated dependencies [
648575aa
]- @verdaccio/utils@6.0.0-6-next.4
6.0.0-6-next.4
Major Changes
-
5c5057fc
: feat: node api new structure based on promiseimport { runServer } from "@verdaccio/node-api"; // or import { runServer } from "verdaccio"; const app = await runServer(); // default configuration const app = await runServer("./config/config.yaml"); const app = await runServer({ configuration }); app.listen(4000, (event) => { // do something });
Breaking Change
If you are using the node-api, the new structure is Promise based and less arguments.
5.0.0-alpha.3
Patch Changes
fecbb9be
: chore: add release step to private regisry on merge changeset pr- Updated dependencies [
fecbb9be
]- @verdaccio/commons-api@10.0.0-alpha.3
- @verdaccio/utils@5.0.0-alpha.3
5.0.0-alpha.2
Minor Changes
-
54c58d1e
: feat: add server rate limit protection to all requestTo modify custom values, use the server settings property.
server: ## https://www.npmjs.com/package/express-rate-limit#configuration-options rateLimit: windowMs: 1000 max: 10000
The values are intended to be high, if you want to improve security of your server consider using different values.
Patch Changes
- Updated dependencies [
54c58d1e
]- @verdaccio/commons-api@10.0.0-alpha.2
- @verdaccio/utils@5.0.0-alpha.2
5.0.0-alpha.1
Major Changes
-
d87fa026
: feat!: experiments config renamed to flags- The
experiments
configuration is renamed toflags
. The functionality is exactly the same.
flags: token: false; search: false;
- The
self_path
property from the config file is being removed in favor ofconfig_file
full path. - Refactor
config
module, better types and utilities
- The
-
da1ee9c8
: - Replace signature handler for legacy tokens by removing deprecated crypto.createDecipher by createCipheriv- Introduce environment variables for legacy tokens
Code Improvements
- Add debug library for improve developer experience
Breaking change
- The new signature invalidates all previous tokens generated by Verdaccio 4 or previous versions.
- The secret key must have 32 characters long.
New environment variables
VERDACCIO_LEGACY_ALGORITHM
: Allows to define the specific algorithm for the token signature which by default isaes-256-ctr
VERDACCIO_LEGACY_ENCRYPTION_KEY
: By default, the token stores in the database, but using this variable allows to get it from memory
Minor Changes
-
26b494cb
: feat: add typescript project references settingsReading https://ebaytech.berlin/optimizing-multi-package-apps-with-typescript-project-references-d5c57a3b4440 I realized I can use project references to solve the issue to pre-compile modules on develop mode.
It allows to navigate (IDE) trough the packages without need compile the packages.
Add two
tsconfig
, one using the previous existing configuration that is able to produce declaration files (tsconfig.build
) and a new onetsconfig
which is enables projects references.
Patch Changes
-
b57b4338
: Enable prerelease mode with changesets -
31af0164
: ESLint Warnings FixedRelated to issue #1461
- max-len: most of the sensible max-len errors are fixed
- no-unused-vars: most of these types of errors are fixed by deleting not needed declarations
- @typescript-eslint/no-unused-vars: same as above
-
Updated dependencies [
d87fa026
] -
Updated dependencies [
da1ee9c8
] -
Updated dependencies [
26b494cb
] -
Updated dependencies [
b57b4338
] -
Updated dependencies [
31af0164
]- @verdaccio/commons-api@10.0.0-alpha.1
- @verdaccio/utils@5.0.0-alpha.1
5.0.0-alpha.1
Major Changes
-
d87fa0268
: feat!: experiments config renamed to flags- The
experiments
configuration is renamed toflags
. The functionality is exactly the same.
flags: token: false; search: false;
- The
self_path
property from the config file is being removed in favor ofconfig_file
full path. - Refactor
config
module, better types and utilities
- The
-
da1ee9c82
: - Replace signature handler for legacy tokens by removing deprecated crypto.createDecipher by createCipheriv- Introduce environment variables for legacy tokens
Code Improvements
- Add debug library for improve developer experience
Breaking change
- The new signature invalidates all previous tokens generated by Verdaccio 4 or previous versions.
- The secret key must have 32 characters long.
New environment variables
VERDACCIO_LEGACY_ALGORITHM
: Allows to define the specific algorithm for the token signature which by default isaes-256-ctr
VERDACCIO_LEGACY_ENCRYPTION_KEY
: By default, the token stores in the database, but using this variable allows to get it from memory
Minor Changes
-
26b494cbd
: feat: add typescript project references settingsReading https://ebaytech.berlin/optimizing-multi-package-apps-with-typescript-project-references-d5c57a3b4440 I realized I can use project references to solve the issue to pre-compile modules on develop mode.
It allows to navigate (IDE) trough the packages without need compile the packages.
Add two
tsconfig
, one using the previous existing configuration that is able to produce declaration files (tsconfig.build
) and a new onetsconfig
which is enables projects references.
Patch Changes
-
b57b43388
: Enable prerelease mode with changesets -
31af01641
: ESLint Warnings FixedRelated to issue #1461
- max-len: most of the sensible max-len errors are fixed
- no-unused-vars: most of these types of errors are fixed by deleting not needed declarations
- @typescript-eslint/no-unused-vars: same as above
-
Updated dependencies [
d87fa0268
] -
Updated dependencies [
da1ee9c82
] -
Updated dependencies [
26b494cbd
] -
Updated dependencies [
b57b43388
] -
Updated dependencies [
31af01641
]- @verdaccio/commons-api@10.0.0-alpha.0
- @verdaccio/utils@5.0.0-alpha.1