File tree 5 files changed +28
-18
lines changed
5 files changed +28
-18
lines changed Original file line number Diff line number Diff line change @@ -105,8 +105,15 @@ class FetcherBase {
105
105
this [ _readPackageJson ] = readPackageJsonFast
106
106
}
107
107
108
- // config values: npmjs (default), never
109
- this . replaceRegistryHost = opts . replaceRegistryHost === 'never' ? 'never' : 'npmjs'
108
+ // config values: npmjs (default), never, always
109
+ // we don't want to mutate the original value
110
+ if ( opts . replaceRegistryHost !== 'never'
111
+ && opts . replaceRegistryHost !== 'always'
112
+ ) {
113
+ this . replaceRegistryHost = 'npmjs'
114
+ } else {
115
+ this . replaceRegistryHost = opts . replaceRegistryHost
116
+ }
110
117
111
118
this . defaultTag = opts . defaultTag || 'latest'
112
119
this . registry = removeTrailingSlashes ( opts . registry || 'https://registry.npmjs.org' )
Original file line number Diff line number Diff line change @@ -5,18 +5,21 @@ const pacoteVersion = require('../package.json').version
5
5
const fetch = require ( 'npm-registry-fetch' )
6
6
const Minipass = require ( 'minipass' )
7
7
// The default registry URL is a string of great magic.
8
- const magic = / ^ h t t p s ? : \/ \ /r e g i s t r y \ .n p m j s \ .o r g \/ /
8
+ const magicHost = ' https:/ /registry.npmjs.org'
9
9
10
10
const _cacheFetches = Symbol . for ( 'pacote.Fetcher._cacheFetches' )
11
11
const _headers = Symbol ( '_headers' )
12
12
class RemoteFetcher extends Fetcher {
13
13
constructor ( spec , opts ) {
14
14
super ( spec , opts )
15
15
this . resolved = this . spec . fetchSpec
16
- if ( this . replaceRegistryHost === 'npmjs'
17
- && magic . test ( this . resolved )
18
- && ! magic . test ( this . registry + '/' ) ) {
19
- this . resolved = this . resolved . replace ( magic , this . registry + '/' )
16
+ const resolvedURL = new URL ( this . resolved )
17
+ if (
18
+ ( this . replaceRegistryHost === 'npmjs'
19
+ && resolvedURL . origin === magicHost )
20
+ || this . replaceRegistryHost === 'always'
21
+ ) {
22
+ this . resolved = new URL ( resolvedURL . pathname , this . registry ) . href
20
23
}
21
24
22
25
// nam is a fermented pork sausage that is good to eat
Original file line number Diff line number Diff line change 1
1
{
2
2
"name" : " pacote" ,
3
- "version" : " 13.1.1 " ,
3
+ "version" : " 13.2.0 " ,
4
4
"description" : " JavaScript package downloader" ,
5
5
"author" : " GitHub Inc." ,
6
6
"bin" : {
26
26
},
27
27
"devDependencies" : {
28
28
"@npmcli/eslint-config" : " ^3.0.1" ,
29
- "@npmcli/template-oss" : " 3.2 .2" ,
29
+ "@npmcli/template-oss" : " 3.4 .2" ,
30
30
"hosted-git-info" : " ^5.0.0" ,
31
31
"mutate-fs" : " ^2.1.1" ,
32
32
"nock" : " ^13.2.4" ,
74
74
},
75
75
"templateOSS" : {
76
76
"//@npmcli/template-oss" : " This file is partially managed by @npmcli/template-oss. Edits may be overwritten." ,
77
- "version" : " 3.2 .2" ,
77
+ "version" : " 3.4 .2" ,
78
78
"windowsCI" : false
79
79
}
80
80
}
Original file line number Diff line number Diff line change 138
138
"npm-user-validate" : " ^1.0.1" ,
139
139
"npmlog" : " ^6.0.2" ,
140
140
"opener" : " ^1.5.2" ,
141
- "pacote" : " ^13.1.1 " ,
141
+ "pacote" : " ^13.2.0 " ,
142
142
"parse-conflict-json" : " ^2.0.2" ,
143
143
"proc-log" : " ^2.0.1" ,
144
144
"qrcode-terminal" : " ^0.12.0" ,
5563
5563
}
5564
5564
},
5565
5565
"node_modules/pacote" : {
5566
- "version" : " 13.1.1 " ,
5567
- "resolved" : " https://registry.npmjs.org/pacote/-/pacote-13.1.1 .tgz" ,
5568
- "integrity" : " sha512-MTT3k1OhUo+IpvoHGp25OwsRU0L+kJQM236OCywxvY4OIJ/YfloNW2/Yc3HMASH10BkfZaGMVK/pxybB7fWcLw ==" ,
5566
+ "version" : " 13.2.0 " ,
5567
+ "resolved" : " https://registry.npmjs.org/pacote/-/pacote-13.2.0 .tgz" ,
5568
+ "integrity" : " sha512-IT4/xHT8eLi4cJdKSGCuqooWp2YwRP5OgrQypbBlLG8Ubzw+h7s57QbrA2SegQcdGefD81ZvuI+aL0JlfFcPCA ==" ,
5569
5569
"inBundle" : true ,
5570
5570
"dependencies" : {
5571
5571
"@npmcli/git" : " ^3.0.0" ,
13898
13898
}
13899
13899
},
13900
13900
"pacote" : {
13901
- "version" : " 13.1.1 " ,
13902
- "resolved" : " https://registry.npmjs.org/pacote/-/pacote-13.1.1 .tgz" ,
13903
- "integrity" : " sha512-MTT3k1OhUo+IpvoHGp25OwsRU0L+kJQM236OCywxvY4OIJ/YfloNW2/Yc3HMASH10BkfZaGMVK/pxybB7fWcLw ==" ,
13901
+ "version" : " 13.2.0 " ,
13902
+ "resolved" : " https://registry.npmjs.org/pacote/-/pacote-13.2.0 .tgz" ,
13903
+ "integrity" : " sha512-IT4/xHT8eLi4cJdKSGCuqooWp2YwRP5OgrQypbBlLG8Ubzw+h7s57QbrA2SegQcdGefD81ZvuI+aL0JlfFcPCA ==" ,
13904
13904
"requires" : {
13905
13905
"@npmcli/git" : " ^3.0.0" ,
13906
13906
"@npmcli/installed-package-contents" : " ^1.0.7" ,
Original file line number Diff line number Diff line change 107
107
"npm-user-validate" : " ^1.0.1" ,
108
108
"npmlog" : " ^6.0.2" ,
109
109
"opener" : " ^1.5.2" ,
110
- "pacote" : " ^13.1.1 " ,
110
+ "pacote" : " ^13.2.0 " ,
111
111
"parse-conflict-json" : " ^2.0.2" ,
112
112
"proc-log" : " ^2.0.1" ,
113
113
"qrcode-terminal" : " ^0.12.0" ,
You can’t perform that action at this time.
0 commit comments