verdaccio 6.2.9 → 7.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +47 -69
- package/build/api/endpoint/api/dist-tags.d.ts +3 -3
- package/build/api/endpoint/api/dist-tags.js +1 -1
- package/build/api/endpoint/api/package.d.ts +4 -4
- package/build/api/endpoint/api/package.js +1 -1
- package/build/api/endpoint/api/ping.d.ts +1 -1
- package/build/api/endpoint/api/ping.js +1 -1
- package/build/api/endpoint/api/publish.d.ts +5 -5
- package/build/api/endpoint/api/publish.js +1 -1
- package/build/api/endpoint/api/star.d.ts +3 -3
- package/build/api/endpoint/api/star.js +1 -1
- package/build/api/endpoint/api/stars.d.ts +2 -2
- package/build/api/endpoint/api/stars.js +1 -1
- package/build/api/endpoint/api/user.d.ts +3 -3
- package/build/api/endpoint/api/user.js +1 -1
- package/build/api/endpoint/api/v1/profile.d.ts +3 -3
- package/build/api/endpoint/api/v1/profile.js +1 -1
- package/build/api/endpoint/api/v1/search.js +1 -1
- package/build/api/endpoint/api/v1/token.d.ts +4 -4
- package/build/api/endpoint/api/v1/token.js +1 -1
- package/build/api/endpoint/api/whoami.d.ts +1 -1
- package/build/api/endpoint/api/whoami.js +1 -1
- package/build/api/endpoint/index.d.ts +3 -3
- package/build/api/endpoint/index.js +1 -1
- package/build/api/index.d.ts +1 -1
- package/build/api/index.js +2 -2
- package/build/api/middleware.d.ts +2 -2
- package/build/api/middleware.js +1 -1
- package/build/api/web/api/package.d.ts +3 -3
- package/build/api/web/api/package.js +1 -1
- package/build/api/web/api/search.d.ts +2 -2
- package/build/api/web/api/search.js +1 -1
- package/build/api/web/api/user.d.ts +2 -2
- package/build/api/web/api/user.js +1 -1
- package/build/api/web/index.d.ts +1 -1
- package/build/api/web/index.js +1 -5
- package/build/lib/cli/cli.js +2 -2
- package/build/lib/cli/commands/init.js +2 -2
- package/build/lib/cli/commands/version.js +2 -2
- package/build/lib/cli/utils.d.ts +1 -1
- package/build/lib/cli/utils.js +2 -2
- package/package.json +28 -23
package/README.md
CHANGED
|
@@ -2,15 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|

|
|
4
4
|
|
|
5
|
-
# Version
|
|
5
|
+
# Version 7
|
|
6
6
|
|
|
7
|
-
[Verdaccio](https://verdaccio.org/) is a simple, **zero-
|
|
8
|
-
|
|
9
|
-
**
|
|
10
|
-
caching the downloaded modules along the way.
|
|
11
|
-
For those looking to extend their storage capabilities, Verdaccio
|
|
12
|
-
**supports various community-made plugins to hook into services such as Amazon's s3,
|
|
13
|
-
Google Cloud Storage** or create your own plugin.
|
|
7
|
+
[Verdaccio](https://verdaccio.org/) is a simple, **zero-configuration-required local private npm registry**.
|
|
8
|
+
Verdaccio doesn't require a full-fledged database to get started. It comes out of the box with **its own tiny database** and the ability to proxy other registries (e.g., npmjs.org), caching downloaded modules along the way.
|
|
9
|
+
For those looking to extend storage capabilities, Verdaccio **supports various community-made plugins that integrate with services such as Amazon S3, Google Cloud Storage, or custom solutions.**
|
|
14
10
|
|
|
15
11
|
[](https://www.npmjs.com/package/verdaccio)
|
|
16
12
|
[](https://www.npmjs.com/package/verdaccio)
|
|
@@ -32,9 +28,9 @@ Install with npm:
|
|
|
32
28
|
npm install --global verdaccio
|
|
33
29
|
```
|
|
34
30
|
|
|
35
|
-
**Node.js v18 or higher is required
|
|
31
|
+
**Node.js v18 or higher is required.**
|
|
36
32
|
|
|
37
|
-
>
|
|
33
|
+
> Node.js 20 (or the latest LTS version) is recommended.
|
|
38
34
|
|
|
39
35
|
or pull [Docker official image](https://verdaccio.org/docs/docker)
|
|
40
36
|
|
|
@@ -58,7 +54,7 @@ helm install verdaccio/verdaccio
|
|
|
58
54
|
|
|
59
55
|
## Programmatic API
|
|
60
56
|
|
|
61
|
-
Verdaccio can be used as a module
|
|
57
|
+
Verdaccio can be used as a module to launch a server programmatically. You can find more information on the website.
|
|
62
58
|
|
|
63
59
|
```
|
|
64
60
|
import {runServer} from 'verdaccio';
|
|
@@ -73,41 +69,41 @@ Verdaccio can be used as a module for launch a server programmatically, [you can
|
|
|
73
69
|
|
|
74
70
|
## Plugins
|
|
75
71
|
|
|
76
|
-
You can develop your own [plugins](https://verdaccio.org/docs/plugins)
|
|
72
|
+
You can develop your own [plugins](https://verdaccio.org/docs/plugins) using the [verdaccio generator](https://github.com/verdaccio/generator-verdaccio-plugin). [Yeoman](https://yeoman.io/) installation is required.
|
|
77
73
|
|
|
78
|
-
Learn more [
|
|
74
|
+
Learn more about [how to develop plugins](https://verdaccio.org/docs/dev-plugins) and share them with the community.
|
|
79
75
|
|
|
80
76
|
## Donations
|
|
81
77
|
|
|
82
|
-
Verdaccio is run by **volunteers
|
|
78
|
+
Verdaccio is run by **volunteers**, with no one working on it full-time. If you find this project useful and would like to support its development and maintenance, consider donating.
|
|
83
79
|
|
|
84
|
-
You can donate at **[Open Collective](https://opencollective.com/verdaccio)** 💵👍🏻 starting from _$1/month_ or
|
|
80
|
+
You can donate at **[Open Collective](https://opencollective.com/verdaccio)** 💵👍🏻 starting from _$1/month_ or with a single contribution.
|
|
81
|
+
|
|
82
|
+
> **Note:** There is currently **no funding available for contributions or security research**.
|
|
85
83
|
|
|
86
84
|
## What does Verdaccio do for me?
|
|
87
85
|
|
|
88
86
|
### Use private packages
|
|
89
87
|
|
|
90
|
-
If you want to
|
|
88
|
+
If you want to leverage all the benefits of the npm package system within your company without exposing all your code to the public, Verdaccio allows you to use your private packages as easily as public ones.
|
|
91
89
|
|
|
92
90
|
### Cache npmjs.org registry
|
|
93
91
|
|
|
94
|
-
If you have
|
|
95
|
-
(presumably "slow" npmjs.org will be connected to only once per package/version) and provide limited failover (if npmjs.org is down, we might still find something useful in the cache) or avoid issues like _[How one developer just broke Node, Babel and thousands of projects in 11 lines of JavaScript](https://www.theregister.co.uk/2016/03/23/npm_left_pad_chaos/)_, _[Many packages suddenly disappeared](https://github.com/npm/registry-issue-archive/issues/255)_ or _[Registry returns 404 for a package I have installed before](https://github.com/npm/registry-issue-archive/issues/329)_.
|
|
92
|
+
If you have multiple servers requiring package installations, caching the npmjs.org registry can significantly decrease latency (as npmjs.org is connected only once per package/version). It also provides limited failover capabilities (if npmjs.org is down, useful packages might still be found in the cache) and helps avoid issues such as _[How one developer just broke Node, Babel and thousands of projects in 11 lines of JavaScript](https://www.theregister.co.uk/2016/03/23/npm_left_pad_chaos/)_, _[Many packages suddenly disappeared](https://github.com/npm/registry-issue-archive/issues/255)_ or _[Registry returns 404 for a package I have installed before](https://github.com/npm/registry-issue-archive/issues/329)_.
|
|
96
93
|
|
|
97
94
|
### Link multiple registries
|
|
98
95
|
|
|
99
|
-
If
|
|
96
|
+
If your organization uses multiple registries and you need to fetch packages from various sources within a single project, you can leverage Verdaccio's uplinks feature to chain multiple registries and fetch packages from a single endpoint.
|
|
100
97
|
|
|
101
98
|
### Override public packages
|
|
102
99
|
|
|
103
|
-
If you
|
|
100
|
+
If you need to use a modified version of a third-party package (e.g., you found a bug, but the maintainer hasn't yet accepted a pull request), you can publish your version locally under the same name. Learn more [here](https://verdaccio.org/docs/en/best#override-public-packages).
|
|
104
101
|
|
|
105
102
|
### E2E Testing
|
|
106
103
|
|
|
107
|
-
Verdaccio has
|
|
108
|
-
booted in a couple of seconds, fast enough for any CI. Many open source projects use verdaccio for end to end testing, to mention some examples, **create-react-app**, **mozilla neutrino**, **pnpm**, **storybook**, **babel.js**, **angular-cli** or **docusaurus**. You can read more in [here](https://verdaccio.org/docs/e2e).
|
|
104
|
+
Verdaccio has proven to be a lightweight registry that can be booted in a couple of seconds, making it fast enough for any CI environment. Many open-source projects utilize Verdaccio for end-to-end testing, including **create-react-app**, **mozilla neutrino**, **pnpm**, **storybook**, **babel.js**, **angular-cli**, and **docusaurus**. You can read more [here](https://verdaccio.org/docs/e2e).
|
|
109
105
|
|
|
110
|
-
|
|
106
|
+
Here are a few examples to get started:
|
|
111
107
|
|
|
112
108
|
- [e2e-ci-example-gh-actions](https://github.com/juanpicado/e2e-ci-example-gh-actions)
|
|
113
109
|
- [verdaccio-end-to-end-tests](https://github.com/juanpicado/verdaccio-end-to-end-tests)
|
|
@@ -115,76 +111,75 @@ Furthermore, here few examples how to start:
|
|
|
115
111
|
|
|
116
112
|
## Talks
|
|
117
113
|
|
|
118
|
-
- [**NodeTLV
|
|
119
|
-
- [Five Ways of Taking Advantage of Verdaccio, Your Private and Proxy Node.js Registry **Node Congress 2022** -
|
|
120
|
-
- [Using Docker and Verdaccio to
|
|
114
|
+
- [**NodeTLV 2022** - Deep Dive into Verdaccio, a Lightweight Node.js Registry - Juan Picado](https://portal.gitnation.org/contents/five-ways-of-taking-advantage-of-verdaccio-your-private-and-proxy-nodejs-registry)
|
|
115
|
+
- [Five Ways of Taking Advantage of Verdaccio, Your Private and Proxy Node.js Registry - **Node Congress 2022** - Juan Picado](https://portal.gitnation.org/contents/five-ways-of-taking-advantage-of-verdaccio-your-private-and-proxy-nodejs-registry)
|
|
116
|
+
- [Using Docker and Verdaccio to Make Integration Testing Easy - **Docker All Hands #4 December 2021** - Juan Picado](https://www.youtube.com/watch?v=zRI0skF1f8I)
|
|
121
117
|
|
|
122
|
-
[View more
|
|
118
|
+
[View more on the YouTube channel](https://www.youtube.com/channel/UC5i20v6o7lSjXzAHOvatt0w).
|
|
123
119
|
|
|
124
120
|
## Get Started
|
|
125
121
|
|
|
126
|
-
|
|
122
|
+
To get started, run Verdaccio in your terminal:
|
|
127
123
|
|
|
128
124
|
```bash
|
|
129
125
|
verdaccio
|
|
130
126
|
```
|
|
131
127
|
|
|
132
|
-
|
|
128
|
+
Optionally, you can set some npm configuration:
|
|
133
129
|
|
|
134
130
|
```bash
|
|
135
131
|
$ npm set registry http://localhost:4873/
|
|
136
132
|
```
|
|
137
133
|
|
|
138
|
-
For one-off commands or to avoid setting the registry globally:
|
|
134
|
+
For one-off commands or to avoid setting the registry globally, use:
|
|
139
135
|
|
|
140
136
|
```bash
|
|
141
137
|
NPM_CONFIG_REGISTRY=http://localhost:4873 npm i
|
|
142
138
|
```
|
|
143
139
|
|
|
144
|
-
|
|
140
|
+
You can now navigate to [http://localhost:4873/](http://localhost:4873/) where your local packages will be listed and searchable.
|
|
145
141
|
|
|
146
|
-
> Warning: Verdaccio [does not currently support PM2's cluster mode](https://github.com/verdaccio/verdaccio/issues/1301#issuecomment-489302298)
|
|
142
|
+
> Warning: Verdaccio [does not currently support PM2's cluster mode](https://github.com/verdaccio/verdaccio/issues/1301#issuecomment-489302298). Running it with cluster mode may lead to unknown behavior.
|
|
147
143
|
|
|
148
144
|
## Publishing
|
|
149
145
|
|
|
150
|
-
#### 1.
|
|
146
|
+
#### 1. Create a User and Log In
|
|
151
147
|
|
|
152
148
|
```bash
|
|
153
149
|
npm adduser --registry http://localhost:4873
|
|
154
150
|
```
|
|
155
151
|
|
|
156
|
-
>
|
|
152
|
+
> If you use HTTPS, add appropriate CA information. ("null" indicates getting the CA list from the OS.)
|
|
157
153
|
|
|
158
154
|
```bash
|
|
159
155
|
$ npm set ca null
|
|
160
156
|
```
|
|
161
157
|
|
|
162
|
-
#### 2.
|
|
158
|
+
#### 2. Publish Your Package
|
|
163
159
|
|
|
164
160
|
```bash
|
|
165
161
|
npm publish --registry http://localhost:4873
|
|
166
162
|
```
|
|
167
163
|
|
|
168
|
-
This will prompt you for user credentials which will be saved on the `verdaccio` server.
|
|
164
|
+
This command will prompt you for user credentials, which will then be saved on the `verdaccio` server.
|
|
169
165
|
|
|
170
166
|
## Docker
|
|
171
167
|
|
|
172
|
-
|
|
173
|
-
every aspect of Docker and verdaccio is [documented separately](https://www.verdaccio.org/docs/en/docker.html)
|
|
168
|
+
The most commonly needed information is provided below. Every aspect of Docker and Verdaccio is [documented separately](https://www.verdaccio.org/docs/en/docker.html).
|
|
174
169
|
|
|
175
|
-
```
|
|
170
|
+
```bash
|
|
176
171
|
docker pull verdaccio/verdaccio
|
|
177
172
|
```
|
|
178
173
|
|
|
179
174
|
Available as [tags](https://hub.docker.com/r/verdaccio/verdaccio/tags/).
|
|
180
175
|
|
|
181
|
-
```
|
|
182
|
-
docker pull verdaccio/verdaccio:
|
|
176
|
+
```bash
|
|
177
|
+
docker pull verdaccio/verdaccio:7.x-next
|
|
183
178
|
```
|
|
184
179
|
|
|
185
|
-
### Running
|
|
180
|
+
### Running Verdaccio using Docker
|
|
186
181
|
|
|
187
|
-
To run the
|
|
182
|
+
To run the Docker container:
|
|
188
183
|
|
|
189
184
|
```bash
|
|
190
185
|
docker run -it --rm --name verdaccio -p 4873:4873 verdaccio/verdaccio
|
|
@@ -194,7 +189,7 @@ Docker examples are available [in this repository](https://github.com/verdaccio/
|
|
|
194
189
|
|
|
195
190
|
## Compatibility
|
|
196
191
|
|
|
197
|
-
Verdaccio aims to support all features of a standard npm client
|
|
192
|
+
Verdaccio aims to support all relevant features of a standard npm client for private repositories. However, full compatibility isn't always possible.
|
|
198
193
|
|
|
199
194
|
### Basic features
|
|
200
195
|
|
|
@@ -211,7 +206,7 @@ Verdaccio aims to support all features of a standard npm client that make sense
|
|
|
211
206
|
|
|
212
207
|
- Registering new users (`npm adduser {newuser}`) - **supported**
|
|
213
208
|
- Change password (`npm profile set password`) - **supported**
|
|
214
|
-
- Transferring ownership (`npm owner add {user} {pkg}`) - not supported,
|
|
209
|
+
- Transferring ownership (`npm owner add {user} {pkg}`) - not supported, _PRs welcome_
|
|
215
210
|
- Token (`npm token`) - **supported** (under flag)
|
|
216
211
|
|
|
217
212
|
### Miscellany
|
|
@@ -226,19 +221,9 @@ Verdaccio aims to support all features of a standard npm client that make sense
|
|
|
226
221
|
|
|
227
222
|
## Report a vulnerability
|
|
228
223
|
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
## Contributors
|
|
224
|
+
To report a security vulnerability, please follow the steps outlined in our [security policy](https://github.com/verdaccio/verdaccio/policy).
|
|
232
225
|
|
|
233
|
-
| [Juan Picado](https://github.com/juanpicado) | [Ayush Sharma](https://github.com/ayusharma) | [Sergio Hg](https://github.com/sergiohgz) |
|
|
234
|
-
| ----------------------------------------------------------------------------- | ----------------------------------------------------------------------- | ------------------------------------------------------------------------ |
|
|
235
|
-
|  |  |  |
|
|
236
|
-
| [@jotadeveloper](https://fosstodon.org/@jotadeveloper) | [@ayusharma\_](https://twitter.com/ayusharma_) | [@sergiohgz](https://twitter.com/sergiohgz) |
|
|
237
|
-
| [Priscila Oliveria](https://github.com/priscilawebdev) | [Daniel Ruf](https://github.com/DanielRuf) |
|
|
238
|
-
|  |  |
|
|
239
|
-
| [@priscilawebdev](https://twitter.com/priscilawebdev) | [@DanielRufde](https://twitter.com/DanielRufde) |
|
|
240
226
|
|
|
241
|
-
[See the full list of contributors is at the website.](https://verdaccio.org/contributors)
|
|
242
227
|
|
|
243
228
|
## Open Collective Backers
|
|
244
229
|
|
|
@@ -248,31 +233,25 @@ Thank you to all our backers! 🙏 [[Become a backer](https://opencollective.com
|
|
|
248
233
|
|
|
249
234
|
## Special Thanks
|
|
250
235
|
|
|
251
|
-
|
|
236
|
+
Special thanks to the following companies for helping us achieve our goals by providing free open-source licenses. Each company contributes significant resources to move this project forward.
|
|
252
237
|
|
|
253
238
|
| Company | Logo | License |
|
|
254
239
|
| ------------ | ------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------- |
|
|
255
240
|
| JetBrains | [](https://www.jetbrains.com/) | JetBrains provides licenses for products for active maintainers, renewable yearly |
|
|
256
241
|
| Crowdin | [](https://crowdin.com/) | Crowdin provides platform for translations |
|
|
257
242
|
| BrowserStack | [](https://www.browserstack.com/) | BrowserStack provides plan to run End to End testing for the UI |
|
|
258
|
-
| Netlify | [](https://www.netlify.com/) | Netlify provides pro plan for website deployment |
|
|
259
|
-
| Algolia | [](https://algolia.com/) | Algolia provides search services for the website |
|
|
260
243
|
| Docker | [](https://www.docker.com/community/open-source/application) | Docker offers unlimited pulls and unlimited egress to any and all users |
|
|
261
244
|
|
|
262
|
-
## Contributors
|
|
263
|
-
|
|
264
|
-
This project exists thanks to all the people who contribute. [[Contribute](CONTRIBUTING.md)].
|
|
265
245
|
|
|
266
|
-
[](../../graphs/contributors)
|
|
267
246
|
|
|
268
247
|
### FAQ / Contact / Troubleshoot
|
|
269
248
|
|
|
270
|
-
If you
|
|
249
|
+
If you encounter any issues, consider the following options. Don't hesitate to ask or check our issues database; perhaps someone has already addressed what you're looking for.
|
|
271
250
|
|
|
272
251
|
- [Blog](https://verdaccio.org/blog/)
|
|
273
252
|
- [Donations](https://opencollective.com/verdaccio)
|
|
274
|
-
- [
|
|
275
|
-
- [
|
|
253
|
+
- [Report an Issue](https://github.com/verdaccio/verdaccio/issues/new/choose)
|
|
254
|
+
- [Discussions](https://github.com/verdaccio/verdaccio/issues?q=is%3Aissue+is%3Aopen+label%3Adiscuss)
|
|
276
255
|
- [Chat](https://discord.gg/7qWJxBf)
|
|
277
256
|
- [Logos](https://verdaccio.org/docs/en/logo)
|
|
278
257
|
- [Docker Examples](https://github.com/verdaccio/verdaccio/tree/master/docker-examples)
|
|
@@ -280,7 +259,6 @@ If you have any issue you can try the following options, do no desist to ask or
|
|
|
280
259
|
|
|
281
260
|
### License
|
|
282
261
|
|
|
283
|
-
Verdaccio is [MIT licensed](https://github.com/verdaccio/verdaccio/blob/master/LICENSE)
|
|
262
|
+
Verdaccio is [MIT licensed](https://github.com/verdaccio/verdaccio/blob/master/LICENSE).
|
|
284
263
|
|
|
285
|
-
The Verdaccio documentation and logos (excluding /thanks
|
|
286
|
-
[Creative Commons licensed](https://creativecommons.org/licenses/by/4.0/).
|
|
264
|
+
The Verdaccio documentation and logos (excluding `/assets/thanks` files such as `.md`, `.png`, and `.sketch`) are [Creative Commons licensed](https://creativecommons.org/licenses/by/4.0/).
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import Auth from '../../../lib/auth';
|
|
3
|
-
import Storage from '../../../lib/storage';
|
|
1
|
+
import type { Router } from 'express';
|
|
2
|
+
import type Auth from '../../../lib/auth';
|
|
3
|
+
import type Storage from '../../../lib/storage';
|
|
4
4
|
export default function (route: Router, auth: Auth, storage: Storage): void;
|
|
@@ -74,4 +74,4 @@ function _default(route, auth, storage) {
|
|
|
74
74
|
});
|
|
75
75
|
});
|
|
76
76
|
}
|
|
77
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_mime","_middleware","_constants","_logger","e","__esModule","default","_default","route","auth","storage","can","allow","beforeAll","params","message","logger","trace","afterAll","tag_package_version","req","res","next","_","isString","body","tags","tag","mergeTags","package","err","status","HTTP_STATUS","CREATED","ok","API_MESSAGE","TAG_ADDED","put","DIST_TAGS_API_ENDPOINTS","tagging","media","mime","getType","post","tagging_package","delete","TAG_REMOVED","get","get_dist_tags","getPackage","name","uplinksLook","callback","info","DIST_TAGS","TAG_UPDATED"],"sources":["../../../../src/api/endpoint/api/dist-tags.ts"],"sourcesContent":["import type { Router } from 'express';\nimport _ from 'lodash';\nimport mime from 'mime';\n\nimport { DIST_TAGS_API_ENDPOINTS, allow, media } from '@verdaccio/middleware';\nimport type { Package } from '@verdaccio/types';\n\nimport type Auth from '../../../lib/auth';\nimport { API_MESSAGE, DIST_TAGS, HTTP_STATUS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport type Storage from '../../../lib/storage';\nimport type { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\n\nexport default function (route: Router, auth: Auth, storage: Storage): void {\n  const can = allow(auth, {\n    beforeAll: (params, message) => logger.trace(params, message),\n    afterAll: (params, message) => logger.trace(params, message),\n  });\n  const tag_package_version = function (\n    req: $RequestExtend,\n    res: $ResponseExtend,\n    next: $NextFunctionVer\n  ): $NextFunctionVer {\n    if (_.isString(req.body) === false) {\n      return next('route');\n    }\n\n    const tags = {};\n    tags[req.params.tag] = req.body;\n    storage.mergeTags(req.params.package, tags, function (err: Error): $NextFunctionVer {\n      if (err) {\n        return next(err);\n      }\n      res.status(HTTP_STATUS.CREATED);\n      return next({ ok: API_MESSAGE.TAG_ADDED });\n    });\n  };\n\n  // tagging a package\n  route.put(\n    DIST_TAGS_API_ENDPOINTS.tagging,\n    can('publish'),\n    media(mime.getType('json')),\n    tag_package_version\n  );\n\n  route.post(\n    DIST_TAGS_API_ENDPOINTS.tagging_package,\n    can('publish'),\n    media(mime.getType('json')),\n    tag_package_version\n  );\n\n  route.put(\n    DIST_TAGS_API_ENDPOINTS.tagging_package,\n    can('publish'),\n    media(mime.getType('json')),\n    tag_package_version\n  );\n\n  route.delete(\n    DIST_TAGS_API_ENDPOINTS.tagging_package,\n    can('publish'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const tags = {};\n      tags[req.params.tag] = null;\n      storage.mergeTags(req.params.package, tags, function (err: any): $NextFunctionVer {\n        if (err) {\n          return next(err);\n        }\n        res.status(HTTP_STATUS.CREATED);\n        return next({\n          ok: API_MESSAGE.TAG_REMOVED,\n        });\n      });\n    }\n  );\n\n  route.get(\n    DIST_TAGS_API_ENDPOINTS.get_dist_tags,\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      storage.getPackage({\n        name: req.params.package,\n        uplinksLook: true,\n        req,\n        callback: function (err: any, info: Package): $NextFunctionVer {\n          if (err) {\n            return next(err);\n          }\n\n          next(info[DIST_TAGS]);\n        },\n      });\n    }\n  );\n\n  route.post(\n    DIST_TAGS_API_ENDPOINTS.get_dist_tags,\n    can('publish'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      storage.mergeTags(req.params.package, req.body, function (err: any): $NextFunctionVer {\n        if (err) {\n          return next(err);\n        }\n        res.status(HTTP_STATUS.CREATED);\n        return next({\n          ok: API_MESSAGE.TAG_UPDATED,\n        });\n      });\n    }\n  );\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import { Config } from '@verdaccio/types';
|
|
3
|
-
import Auth from '../../../lib/auth';
|
|
4
|
-
import Storage from '../../../lib/storage';
|
|
1
|
+
import type { Router } from 'express';
|
|
2
|
+
import type { Config } from '@verdaccio/types';
|
|
3
|
+
import type Auth from '../../../lib/auth';
|
|
4
|
+
import type Storage from '../../../lib/storage';
|
|
5
5
|
export default function (route: Router, auth: Auth, storage: Storage, config: Config): void;
|
|
@@ -100,4 +100,4 @@ function _default(route, auth, storage, config) {
|
|
|
100
100
|
}
|
|
101
101
|
});
|
|
102
102
|
}
|
|
103
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_core","_middleware","_tarball","_constants","_logger","_utils","e","__esModule","default","downloadStream","packageName","filename","storage","req","res","stream","getTarball","on","content","header","err","locals","report_error","HEADERS","CONTENT_TYPE","OCTET_STREAM","pipe","redirectOrDownloadStream","config","tarballUrlRedirect","_","get","hasLocalTarball","then","context","tarballUrl","template","redirect","catch","_default","route","auth","can","allow","beforeAll","params","message","logger","trace","afterAll","PACKAGE_API_ENDPOINTS","get_package_by_version","next","abbreviated","stringUtils","getByQualityPriorityValue","getPackageMetaCallback","metadata","convertDistRemoteToLocalTarballUrls","protocol","headers","host","hostname","remoteAddress","socket","url_prefix","queryVersion","version","isNil","setHeader","JSON","getVersion","DIST_TAGS","ErrorCode","getNotFound","API_ERROR","VERSION_NOT_EXIST","getPackage","name","package","uplinksLook","callback","get_package_tarball","undefined"],"sources":["../../../../src/api/endpoint/api/package.ts"],"sourcesContent":["import { Router } from 'express';\nimport _ from 'lodash';\n\nimport { stringUtils } from '@verdaccio/core';\nimport { PACKAGE_API_ENDPOINTS, allow } from '@verdaccio/middleware';\nimport { convertDistRemoteToLocalTarballUrls } from '@verdaccio/tarball';\nimport { Config, Manifest } from '@verdaccio/types';\n\nimport Auth from '../../../lib/auth';\nimport { API_ERROR, DIST_TAGS, HEADERS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport Storage from '../../../lib/storage';\nimport { ErrorCode, getVersion } from '../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\n\nconst downloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend\n): void => {\n  const stream = storage.getTarball(packageName, filename);\n\n  stream.on('content-length', function (content): void {\n    res.header('Content-Length', content);\n  });\n\n  stream.on('error', function (err): void {\n    return res.locals.report_error(err);\n  });\n\n  res.header(HEADERS.CONTENT_TYPE, HEADERS.OCTET_STREAM);\n  stream.pipe(res);\n};\n\nconst redirectOrDownloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend,\n  config: Config\n): void => {\n  const tarballUrlRedirect = _.get(config, 'experiments.tarball_url_redirect');\n  storage\n    .hasLocalTarball(packageName, filename)\n    .then((hasLocalTarball) => {\n      if (hasLocalTarball) {\n        const context = { packageName, filename };\n        const tarballUrl =\n          typeof tarballUrlRedirect === 'function'\n            ? tarballUrlRedirect(context)\n            : _.template(tarballUrlRedirect)(context);\n        res.redirect(tarballUrl);\n      } else {\n        downloadStream(packageName, filename, storage, req, res);\n      }\n    })\n    .catch((err) => {\n      res.locals.report_error(err);\n    });\n};\n\nexport default function (route: Router, auth: Auth, storage: Storage, config: Config): void {\n  const can = allow(auth, {\n    beforeAll: (params, message) => logger.trace(params, message),\n    afterAll: (params, message) => logger.trace(params, message),\n  });\n  // TODO: anonymous user?\n  route.get(\n    PACKAGE_API_ENDPOINTS.get_package_by_version,\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const abbreviated =\n        stringUtils.getByQualityPriorityValue(req.get('Accept')) ===\n        'application/vnd.npm.install-v1+json';\n      const getPackageMetaCallback = function (err, metadata: Manifest): void {\n        if (err) {\n          return next(err);\n        }\n        metadata = convertDistRemoteToLocalTarballUrls(\n          metadata,\n          {\n            protocol: req.protocol,\n            headers: req.headers as any,\n            host: req.hostname,\n            remoteAddress: req.socket.remoteAddress,\n          },\n          config.url_prefix\n        );\n\n        let queryVersion = req.params.version;\n        if (_.isNil(queryVersion)) {\n          if (abbreviated) {\n            res.setHeader(HEADERS.CONTENT_TYPE, 'application/vnd.npm.install-v1+json');\n          } else {\n            res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          }\n\n          return next(metadata);\n        }\n\n        let version = getVersion(metadata, queryVersion);\n        if (_.isNil(version) === false) {\n          res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          return next(version);\n        }\n\n        if (_.isNil(metadata[DIST_TAGS]) === false) {\n          if (_.isNil(metadata[DIST_TAGS][queryVersion]) === false) {\n            queryVersion = metadata[DIST_TAGS][queryVersion];\n            version = getVersion(metadata, queryVersion);\n            if (_.isNil(version) === false) {\n              res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n              return next(version);\n            }\n          }\n        }\n        return next(ErrorCode.getNotFound(`${API_ERROR.VERSION_NOT_EXIST}: ${req.params.version}`));\n      };\n\n      storage.getPackage({\n        name: req.params.package,\n        uplinksLook: true,\n        req,\n        abbreviated,\n        callback: getPackageMetaCallback,\n      });\n    }\n  );\n\n  route.get(\n    PACKAGE_API_ENDPOINTS.get_package_tarball,\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(req.params.package, req.params.filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(\n          req.params.package,\n          req.params.filename,\n          storage,\n          req,\n          res,\n          config\n        );\n      }\n    }\n  );\n}\n"],"mappings":";;;;;;AACA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,KAAA,GAAAD,OAAA;AACA,IAAAE,WAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAIA,IAAAI,UAAA,GAAAJ,OAAA;AACA,IAAAK,OAAA,GAAAL,OAAA;AAEA,IAAAM,MAAA,GAAAN,OAAA;AAA2D,SAAAD,uBAAAQ,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAG3D,MAAMG,cAAc,GAAGA,CACrBC,WAAmB,EACnBC,QAAgB,EAChBC,OAAY,EACZC,GAAmB,EACnBC,GAAoB,KACX;EACT,MAAMC,MAAM,GAAGH,OAAO,CAACI,UAAU,CAACN,WAAW,EAAEC,QAAQ,CAAC;EAExDI,MAAM,CAACE,EAAE,CAAC,gBAAgB,EAAE,UAAUC,OAAO,EAAQ;IACnDJ,GAAG,CAACK,MAAM,CAAC,gBAAgB,EAAED,OAAO,CAAC;EACvC,CAAC,CAAC;EAEFH,MAAM,CAACE,EAAE,CAAC,OAAO,EAAE,UAAUG,GAAG,EAAQ;IACtC,OAAON,GAAG,CAACO,MAAM,CAACC,YAAY,CAACF,GAAG,CAAC;EACrC,CAAC,CAAC;EAEFN,GAAG,CAACK,MAAM,CAACI,kBAAO,CAACC,YAAY,EAAED,kBAAO,CAACE,YAAY,CAAC;EACtDV,MAAM,CAACW,IAAI,CAACZ,GAAG,CAAC;AAClB,CAAC;AAED,MAAMa,wBAAwB,GAAGA,CAC/BjB,WAAmB,EACnBC,QAAgB,EAChBC,OAAY,EACZC,GAAmB,EACnBC,GAAoB,EACpBc,MAAc,KACL;EACT,MAAMC,kBAAkB,GAAGC,eAAC,CAACC,GAAG,CAACH,MAAM,EAAE,kCAAkC,CAAC;EAC5EhB,OAAO,CACJoB,eAAe,CAACtB,WAAW,EAAEC,QAAQ,CAAC,CACtCsB,IAAI,CAAED,eAAe,IAAK;IACzB,IAAIA,eAAe,EAAE;MACnB,MAAME,OAAO,GAAG;QAAExB,WAAW;QAAEC;MAAS,CAAC;MACzC,MAAMwB,UAAU,GACd,OAAON,kBAAkB,KAAK,UAAU,GACpCA,kBAAkB,CAACK,OAAO,CAAC,GAC3BJ,eAAC,CAACM,QAAQ,CAACP,kBAAkB,CAAC,CAACK,OAAO,CAAC;MAC7CpB,GAAG,CAACuB,QAAQ,CAACF,UAAU,CAAC;IAC1B,CAAC,MAAM;MACL1B,cAAc,CAACC,WAAW,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,GAAG,EAAEC,GAAG,CAAC;IAC1D;EACF,CAAC,CAAC,CACDwB,KAAK,CAAElB,GAAG,IAAK;IACdN,GAAG,CAACO,MAAM,CAACC,YAAY,CAACF,GAAG,CAAC;EAC9B,CAAC,CAAC;AACN,CAAC;AAEc,SAAAmB,SAAUC,KAAa,EAAEC,IAAU,EAAE7B,OAAgB,EAAEgB,MAAc,EAAQ;EAC1F,MAAMc,GAAG,GAAG,IAAAC,iBAAK,EAACF,IAAI,EAAE;IACtBG,SAAS,EAAEA,CAACC,MAAM,EAAEC,OAAO,KAAKC,cAAM,CAACC,KAAK,CAACH,MAAM,EAAEC,OAAO,CAAC;IAC7DG,QAAQ,EAAEA,CAACJ,MAAM,EAAEC,OAAO,KAAKC,cAAM,CAACC,KAAK,CAACH,MAAM,EAAEC,OAAO;EAC7D,CAAC,CAAC;EACF;EACAN,KAAK,CAACT,GAAG,CACPmB,iCAAqB,CAACC,sBAAsB,EAC5CT,GAAG,CAAC,QAAQ,CAAC,EACb,UAAU7B,GAAmB,EAAEC,GAAoB,EAAEsC,IAAsB,EAAQ;IACjF,MAAMC,WAAW,GACfC,iBAAW,CAACC,yBAAyB,CAAC1C,GAAG,CAACkB,GAAG,CAAC,QAAQ,CAAC,CAAC,KACxD,qCAAqC;IACvC,MAAMyB,sBAAsB,GAAG,SAAAA,CAAUpC,GAAG,EAAEqC,QAAkB,EAAQ;MACtE,IAAIrC,GAAG,EAAE;QACP,OAAOgC,IAAI,CAAChC,GAAG,CAAC;MAClB;MACAqC,QAAQ,GAAG,IAAAC,4CAAmC,EAC5CD,QAAQ,EACR;QACEE,QAAQ,EAAE9C,GAAG,CAAC8C,QAAQ;QACtBC,OAAO,EAAE/C,GAAG,CAAC+C,OAAc;QAC3BC,IAAI,EAAEhD,GAAG,CAACiD,QAAQ;QAClBC,aAAa,EAAElD,GAAG,CAACmD,MAAM,CAACD;MAC5B,CAAC,EACDnC,MAAM,CAACqC,UACT,CAAC;MAED,IAAIC,YAAY,GAAGrD,GAAG,CAACgC,MAAM,CAACsB,OAAO;MACrC,IAAIrC,eAAC,CAACsC,KAAK,CAACF,YAAY,CAAC,EAAE;QACzB,IAAIb,WAAW,EAAE;UACfvC,GAAG,CAACuD,SAAS,CAAC9C,kBAAO,CAACC,YAAY,EAAE,qCAAqC,CAAC;QAC5E,CAAC,MAAM;UACLV,GAAG,CAACuD,SAAS,CAAC9C,kBAAO,CAACC,YAAY,EAAED,kBAAO,CAAC+C,IAAI,CAAC;QACnD;QAEA,OAAOlB,IAAI,CAACK,QAAQ,CAAC;MACvB;MAEA,IAAIU,OAAO,GAAG,IAAAI,iBAAU,EAACd,QAAQ,EAAES,YAAY,CAAC;MAChD,IAAIpC,eAAC,CAACsC,KAAK,CAACD,OAAO,CAAC,KAAK,KAAK,EAAE;QAC9BrD,GAAG,CAACuD,SAAS,CAAC9C,kBAAO,CAACC,YAAY,EAAED,kBAAO,CAAC+C,IAAI,CAAC;QACjD,OAAOlB,IAAI,CAACe,OAAO,CAAC;MACtB;MAEA,IAAIrC,eAAC,CAACsC,KAAK,CAACX,QAAQ,CAACe,oBAAS,CAAC,CAAC,KAAK,KAAK,EAAE;QAC1C,IAAI1C,eAAC,CAACsC,KAAK,CAACX,QAAQ,CAACe,oBAAS,CAAC,CAACN,YAAY,CAAC,CAAC,KAAK,KAAK,EAAE;UACxDA,YAAY,GAAGT,QAAQ,CAACe,oBAAS,CAAC,CAACN,YAAY,CAAC;UAChDC,OAAO,GAAG,IAAAI,iBAAU,EAACd,QAAQ,EAAES,YAAY,CAAC;UAC5C,IAAIpC,eAAC,CAACsC,KAAK,CAACD,OAAO,CAAC,KAAK,KAAK,EAAE;YAC9BrD,GAAG,CAACuD,SAAS,CAAC9C,kBAAO,CAACC,YAAY,EAAED,kBAAO,CAAC+C,IAAI,CAAC;YACjD,OAAOlB,IAAI,CAACe,OAAO,CAAC;UACtB;QACF;MACF;MACA,OAAOf,IAAI,CAACqB,gBAAS,CAACC,WAAW,CAAC,GAAGC,oBAAS,CAACC,iBAAiB,KAAK/D,GAAG,CAACgC,MAAM,CAACsB,OAAO,EAAE,CAAC,CAAC;IAC7F,CAAC;IAEDvD,OAAO,CAACiE,UAAU,CAAC;MACjBC,IAAI,EAAEjE,GAAG,CAACgC,MAAM,CAACkC,OAAO;MACxBC,WAAW,EAAE,IAAI;MACjBnE,GAAG;MACHwC,WAAW;MACX4B,QAAQ,EAAEzB;IACZ,CAAC,CAAC;EACJ,CACF,CAAC;EAEDhB,KAAK,CAACT,GAAG,CACPmB,iCAAqB,CAACgC,mBAAmB,EACzCxC,GAAG,CAAC,QAAQ,CAAC,EACb,UAAU7B,GAAmB,EAAEC,GAAoB,EAAQ;IACzD,IAAIgB,eAAC,CAACC,GAAG,CAACH,MAAM,EAAE,kCAAkC,CAAC,KAAKuD,SAAS,EAAE;MACnE1E,cAAc,CAACI,GAAG,CAACgC,MAAM,CAACkC,OAAO,EAAElE,GAAG,CAACgC,MAAM,CAAClC,QAAQ,EAAEC,OAAO,EAAEC,GAAG,EAAEC,GAAG,CAAC;IAC5E,CAAC,MAAM;MACLa,wBAAwB,CACtBd,GAAG,CAACgC,MAAM,CAACkC,OAAO,EAClBlE,GAAG,CAACgC,MAAM,CAAClC,QAAQ,EACnBC,OAAO,EACPC,GAAG,EACHC,GAAG,EACHc,MACF,CAAC;IACH;EACF,CACF,CAAC;AACH","ignoreList":[]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_core","_middleware","_tarball","_constants","_logger","_utils","e","__esModule","default","downloadStream","packageName","filename","storage","req","res","stream","getTarball","on","content","header","err","locals","report_error","HEADERS","CONTENT_TYPE","OCTET_STREAM","pipe","redirectOrDownloadStream","config","tarballUrlRedirect","_","get","hasLocalTarball","then","context","tarballUrl","template","redirect","catch","_default","route","auth","can","allow","beforeAll","params","message","logger","trace","afterAll","PACKAGE_API_ENDPOINTS","get_package_by_version","next","abbreviated","stringUtils","getByQualityPriorityValue","getPackageMetaCallback","metadata","convertDistRemoteToLocalTarballUrls","protocol","headers","host","hostname","remoteAddress","socket","url_prefix","queryVersion","version","isNil","setHeader","JSON","getVersion","DIST_TAGS","ErrorCode","getNotFound","API_ERROR","VERSION_NOT_EXIST","getPackage","name","package","uplinksLook","callback","get_package_tarball","undefined"],"sources":["../../../../src/api/endpoint/api/package.ts"],"sourcesContent":["import type { Router } from 'express';\nimport _ from 'lodash';\n\nimport { stringUtils } from '@verdaccio/core';\nimport { PACKAGE_API_ENDPOINTS, allow } from '@verdaccio/middleware';\nimport { convertDistRemoteToLocalTarballUrls } from '@verdaccio/tarball';\nimport type { Config, Manifest } from '@verdaccio/types';\n\nimport type Auth from '../../../lib/auth';\nimport { API_ERROR, DIST_TAGS, HEADERS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport type Storage from '../../../lib/storage';\nimport { ErrorCode, getVersion } from '../../../lib/utils';\nimport type { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\n\nconst downloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend\n): void => {\n  const stream = storage.getTarball(packageName, filename);\n\n  stream.on('content-length', function (content): void {\n    res.header('Content-Length', content);\n  });\n\n  stream.on('error', function (err): void {\n    return res.locals.report_error(err);\n  });\n\n  res.header(HEADERS.CONTENT_TYPE, HEADERS.OCTET_STREAM);\n  stream.pipe(res);\n};\n\nconst redirectOrDownloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend,\n  config: Config\n): void => {\n  const tarballUrlRedirect = _.get(config, 'experiments.tarball_url_redirect');\n  storage\n    .hasLocalTarball(packageName, filename)\n    .then((hasLocalTarball) => {\n      if (hasLocalTarball) {\n        const context = { packageName, filename };\n        const tarballUrl =\n          typeof tarballUrlRedirect === 'function'\n            ? tarballUrlRedirect(context)\n            : _.template(tarballUrlRedirect)(context);\n        res.redirect(tarballUrl);\n      } else {\n        downloadStream(packageName, filename, storage, req, res);\n      }\n    })\n    .catch((err) => {\n      res.locals.report_error(err);\n    });\n};\n\nexport default function (route: Router, auth: Auth, storage: Storage, config: Config): void {\n  const can = allow(auth, {\n    beforeAll: (params, message) => logger.trace(params, message),\n    afterAll: (params, message) => logger.trace(params, message),\n  });\n  // TODO: anonymous user?\n  route.get(\n    PACKAGE_API_ENDPOINTS.get_package_by_version,\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const abbreviated =\n        stringUtils.getByQualityPriorityValue(req.get('Accept')) ===\n        'application/vnd.npm.install-v1+json';\n      const getPackageMetaCallback = function (err, metadata: Manifest): void {\n        if (err) {\n          return next(err);\n        }\n        metadata = convertDistRemoteToLocalTarballUrls(\n          metadata,\n          {\n            protocol: req.protocol,\n            headers: req.headers as any,\n            host: req.hostname,\n            remoteAddress: req.socket.remoteAddress,\n          },\n          config.url_prefix\n        );\n\n        let queryVersion = req.params.version;\n        if (_.isNil(queryVersion)) {\n          if (abbreviated) {\n            res.setHeader(HEADERS.CONTENT_TYPE, 'application/vnd.npm.install-v1+json');\n          } else {\n            res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          }\n\n          return next(metadata);\n        }\n\n        let version = getVersion(metadata, queryVersion);\n        if (_.isNil(version) === false) {\n          res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          return next(version);\n        }\n\n        if (_.isNil(metadata[DIST_TAGS]) === false) {\n          if (_.isNil(metadata[DIST_TAGS][queryVersion]) === false) {\n            queryVersion = metadata[DIST_TAGS][queryVersion];\n            version = getVersion(metadata, queryVersion);\n            if (_.isNil(version) === false) {\n              res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n              return next(version);\n            }\n          }\n        }\n        return next(ErrorCode.getNotFound(`${API_ERROR.VERSION_NOT_EXIST}: ${req.params.version}`));\n      };\n\n      storage.getPackage({\n        name: req.params.package,\n        uplinksLook: true,\n        req,\n        abbreviated,\n        callback: getPackageMetaCallback,\n      });\n    }\n  );\n\n  route.get(\n    PACKAGE_API_ENDPOINTS.get_package_tarball,\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(req.params.package, req.params.filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(\n          req.params.package,\n          req.params.filename,\n          storage,\n          req,\n          res,\n          config\n        );\n      }\n    }\n  );\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
1
|
+
import type { Router } from 'express';
|
|
2
2
|
export default function (route: Router): void;
|
|
@@ -10,4 +10,4 @@ function _default(route) {
|
|
|
10
10
|
next({});
|
|
11
11
|
});
|
|
12
12
|
}
|
|
13
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbWlkZGxld2FyZSIsInJlcXVpcmUiLCJfZGVmYXVsdCIsInJvdXRlIiwiZ2V0IiwiUElOR19BUElfRU5EUE9JTlRTIiwicGluZyIsInJlcSIsInJlcyIsIm5leHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBpL2VuZHBvaW50L2FwaS9waW5nLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUm91dGVyIH0gZnJvbSAnZXhwcmVzcyc7XG5cbmltcG9ydCB7IFBJTkdfQVBJX0VORFBPSU5UUyB9IGZyb20gJ0B2ZXJkYWNjaW8vbWlkZGxld2FyZSc7XG5cbmltcG9ydCB0eXBlIHsgJE5leHRGdW5jdGlvblZlciwgJFJlcXVlc3RFeHRlbmQsICRSZXNwb25zZUV4dGVuZCB9IGZyb20gJy4uLy4uLy4uL3R5cGVzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKHJvdXRlOiBSb3V0ZXIpOiB2b2lkIHtcbiAgcm91dGUuZ2V0KFxuICAgIFBJTkdfQVBJX0VORFBPSU5UUy5waW5nLFxuICAgIGZ1bmN0aW9uIChyZXE6ICRSZXF1ZXN0RXh0ZW5kLCByZXM6ICRSZXNwb25zZUV4dGVuZCwgbmV4dDogJE5leHRGdW5jdGlvblZlcikge1xuICAgICAgbmV4dCh7fSk7XG4gICAgfVxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFQSxJQUFBQSxXQUFBLEdBQUFDLE9BQUE7QUFJZSxTQUFBQyxTQUFVQyxLQUFhLEVBQVE7RUFDNUNBLEtBQUssQ0FBQ0MsR0FBRyxDQUNQQyw4QkFBa0IsQ0FBQ0MsSUFBSSxFQUN2QixVQUFVQyxHQUFtQixFQUFFQyxHQUFvQixFQUFFQyxJQUFzQixFQUFFO0lBQzNFQSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7RUFDVixDQUNGLENBQUM7QUFDSCIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import { Config } from '@verdaccio/types';
|
|
3
|
-
import Auth from '../../../lib/auth';
|
|
4
|
-
import Storage from '../../../lib/storage';
|
|
5
|
-
import { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';
|
|
1
|
+
import type { Router } from 'express';
|
|
2
|
+
import type { Config } from '@verdaccio/types';
|
|
3
|
+
import type Auth from '../../../lib/auth';
|
|
4
|
+
import type Storage from '../../../lib/storage';
|
|
5
|
+
import type { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';
|
|
6
6
|
export default function publish(router: Router, auth: Auth, storage: Storage, config: Config): void;
|
|
7
7
|
/**
|
|
8
8
|
* Publish a package
|