com.jimuwd.xian.registry-proxy 1.0.20 → 1.0.22
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/dist/index.js +16 -16
- package/package.json +1 -1
- package/src/index.ts +16 -16
package/dist/index.js
CHANGED
|
@@ -60,9 +60,9 @@ function removeRegistryPrefix(tarballUrl, registries) {
|
|
|
60
60
|
const normalizedRegistries = registries
|
|
61
61
|
.map(r => normalizeUrl(r.url))
|
|
62
62
|
.sort((a, b) => b.length - a.length);
|
|
63
|
-
for (const
|
|
64
|
-
if (normalizedTarball.startsWith(
|
|
65
|
-
return normalizedTarball.slice(
|
|
63
|
+
for (const normalizedRegistry of normalizedRegistries) {
|
|
64
|
+
if (normalizedTarball.startsWith(normalizedRegistry)) {
|
|
65
|
+
return normalizedTarball.slice(normalizedRegistry.length) || '/';
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
68
|
}
|
|
@@ -124,9 +124,9 @@ async function loadRegistries(proxyConfigPath = './.registry-proxy.yml', localYa
|
|
|
124
124
|
export async function startProxyServer(proxyConfigPath, localYarnConfigPath, globalYarnConfigPath, port = 0) {
|
|
125
125
|
const proxyConfig = await loadProxyConfig(proxyConfigPath);
|
|
126
126
|
const registries = await loadRegistries(proxyConfigPath, localYarnConfigPath, globalYarnConfigPath);
|
|
127
|
-
const
|
|
127
|
+
const basePathPrefixedWithSlash = proxyConfig.basePath ? `/${proxyConfig.basePath.replace(/^\/|\/$/g, '')}` : '/';
|
|
128
128
|
console.log('Active registries:', registries.map(r => r.url));
|
|
129
|
-
console.log('Proxy base path:',
|
|
129
|
+
console.log('Proxy base path:', basePathPrefixedWithSlash);
|
|
130
130
|
console.log('HTTPS:', !!proxyConfig.https);
|
|
131
131
|
let proxyPort;
|
|
132
132
|
const requestHandler = async (req, res) => {
|
|
@@ -136,20 +136,20 @@ export async function startProxyServer(proxyConfigPath, localYarnConfigPath, glo
|
|
|
136
136
|
return;
|
|
137
137
|
}
|
|
138
138
|
const fullUrl = new URL(req.url, `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host}`);
|
|
139
|
-
if (
|
|
140
|
-
console.error(`Path ${fullUrl.pathname} does not match basePath ${
|
|
139
|
+
if (basePathPrefixedWithSlash && !fullUrl.pathname.startsWith(basePathPrefixedWithSlash)) {
|
|
140
|
+
console.error(`Path ${fullUrl.pathname} does not match basePath ${basePathPrefixedWithSlash}`);
|
|
141
141
|
res.writeHead(404).end('Not Found');
|
|
142
142
|
return;
|
|
143
143
|
}
|
|
144
|
-
const
|
|
145
|
-
? fullUrl.pathname.slice(
|
|
144
|
+
const relativePathPrefixedWithSlash = basePathPrefixedWithSlash
|
|
145
|
+
? fullUrl.pathname.slice(basePathPrefixedWithSlash.length)
|
|
146
146
|
: fullUrl.pathname;
|
|
147
|
-
console.log(`Proxying: ${
|
|
147
|
+
console.log(`Proxying: ${relativePathPrefixedWithSlash}`);
|
|
148
148
|
const fetchPromises = registries.map(async ({ url, token }) => {
|
|
149
149
|
await limiter.acquire();
|
|
150
150
|
try {
|
|
151
|
-
const cleanRelativePath =
|
|
152
|
-
const targetUrl = `${url}/${cleanRelativePath}${fullUrl.search || ''}
|
|
151
|
+
const cleanRelativePath = relativePathPrefixedWithSlash.replace(/^\/+|\/+$/g, '');
|
|
152
|
+
const targetUrl = `${url}/${cleanRelativePath}${fullUrl.search || ''}`;
|
|
153
153
|
console.log(`Fetching from: ${targetUrl}`);
|
|
154
154
|
const headers = token ? { Authorization: `Bearer ${token}` } : undefined;
|
|
155
155
|
const response = await fetch(targetUrl, { headers, });
|
|
@@ -167,7 +167,7 @@ export async function startProxyServer(proxyConfigPath, localYarnConfigPath, glo
|
|
|
167
167
|
const responses = await Promise.all(fetchPromises);
|
|
168
168
|
const successResponse = responses.find((r) => r !== null);
|
|
169
169
|
if (!successResponse) {
|
|
170
|
-
console.error(`All registries failed for ${
|
|
170
|
+
console.error(`All registries failed for ${relativePathPrefixedWithSlash}`);
|
|
171
171
|
res.writeHead(404).end('Not Found - All upstream registries failed');
|
|
172
172
|
return;
|
|
173
173
|
}
|
|
@@ -176,7 +176,7 @@ export async function startProxyServer(proxyConfigPath, localYarnConfigPath, glo
|
|
|
176
176
|
try {
|
|
177
177
|
const data = await successResponse.json();
|
|
178
178
|
if (data.versions) {
|
|
179
|
-
const proxyBase = `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host || 'localhost:' + proxyPort}${
|
|
179
|
+
const proxyBase = `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host || 'localhost:' + proxyPort}${basePathPrefixedWithSlash}`;
|
|
180
180
|
for (const version in data.versions) {
|
|
181
181
|
const dist = data.versions[version]?.dist;
|
|
182
182
|
if (dist?.tarball) {
|
|
@@ -207,7 +207,7 @@ export async function startProxyServer(proxyConfigPath, localYarnConfigPath, glo
|
|
|
207
207
|
};
|
|
208
208
|
res.writeHead(successResponse.status, safeHeaders);
|
|
209
209
|
successResponse.body.pipe(res).on('error', (err) => {
|
|
210
|
-
console.error(`Stream error for ${
|
|
210
|
+
console.error(`Stream error for ${relativePathPrefixedWithSlash}:`, err);
|
|
211
211
|
res.writeHead(502).end('Stream Error');
|
|
212
212
|
});
|
|
213
213
|
}
|
|
@@ -248,7 +248,7 @@ export async function startProxyServer(proxyConfigPath, localYarnConfigPath, glo
|
|
|
248
248
|
proxyPort = address.port;
|
|
249
249
|
const portFile = join(process.env.PROJECT_ROOT || process.cwd(), '.registry-proxy-port');
|
|
250
250
|
writeFile(portFile, proxyPort.toString()).catch(e => console.error('Failed to write port file:', e));
|
|
251
|
-
console.log(`Proxy server running on ${proxyConfig.https ? 'https' : 'http'}://localhost:${proxyPort}${
|
|
251
|
+
console.log(`Proxy server running on ${proxyConfig.https ? 'https' : 'http'}://localhost:${proxyPort}${basePathPrefixedWithSlash}`);
|
|
252
252
|
resolve(server);
|
|
253
253
|
});
|
|
254
254
|
});
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -81,9 +81,9 @@ function removeRegistryPrefix(tarballUrl: string, registries: RegistryInfo[]): s
|
|
|
81
81
|
.map(r => normalizeUrl(r.url))
|
|
82
82
|
.sort((a, b) => b.length - a.length);
|
|
83
83
|
|
|
84
|
-
for (const
|
|
85
|
-
if (normalizedTarball.startsWith(
|
|
86
|
-
return normalizedTarball.slice(
|
|
84
|
+
for (const normalizedRegistry of normalizedRegistries) {
|
|
85
|
+
if (normalizedTarball.startsWith(normalizedRegistry)) {
|
|
86
|
+
return normalizedTarball.slice(normalizedRegistry.length) || '/';
|
|
87
87
|
}
|
|
88
88
|
}
|
|
89
89
|
} catch (e) {
|
|
@@ -157,10 +157,10 @@ export async function startProxyServer(
|
|
|
157
157
|
): Promise<HttpServer | HttpsServer> {
|
|
158
158
|
const proxyConfig = await loadProxyConfig(proxyConfigPath);
|
|
159
159
|
const registries = await loadRegistries(proxyConfigPath, localYarnConfigPath, globalYarnConfigPath);
|
|
160
|
-
const
|
|
160
|
+
const basePathPrefixedWithSlash = proxyConfig.basePath ? `/${proxyConfig.basePath.replace(/^\/|\/$/g, '')}` : '/';
|
|
161
161
|
|
|
162
162
|
console.log('Active registries:', registries.map(r => r.url));
|
|
163
|
-
console.log('Proxy base path:',
|
|
163
|
+
console.log('Proxy base path:', basePathPrefixedWithSlash);
|
|
164
164
|
console.log('HTTPS:', !!proxyConfig.https);
|
|
165
165
|
|
|
166
166
|
let proxyPort: number;
|
|
@@ -173,22 +173,22 @@ export async function startProxyServer(
|
|
|
173
173
|
}
|
|
174
174
|
|
|
175
175
|
const fullUrl = new URL(req.url, `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host}`);
|
|
176
|
-
if (
|
|
177
|
-
console.error(`Path ${fullUrl.pathname} does not match basePath ${
|
|
176
|
+
if (basePathPrefixedWithSlash && !fullUrl.pathname.startsWith(basePathPrefixedWithSlash)) {
|
|
177
|
+
console.error(`Path ${fullUrl.pathname} does not match basePath ${basePathPrefixedWithSlash}`);
|
|
178
178
|
res.writeHead(404).end('Not Found');
|
|
179
179
|
return;
|
|
180
180
|
}
|
|
181
181
|
|
|
182
|
-
const
|
|
183
|
-
? fullUrl.pathname.slice(
|
|
182
|
+
const relativePathPrefixedWithSlash = basePathPrefixedWithSlash
|
|
183
|
+
? fullUrl.pathname.slice(basePathPrefixedWithSlash.length)
|
|
184
184
|
: fullUrl.pathname;
|
|
185
|
-
console.log(`Proxying: ${
|
|
185
|
+
console.log(`Proxying: ${relativePathPrefixedWithSlash}`);
|
|
186
186
|
|
|
187
187
|
const fetchPromises = registries.map(async ({ url, token }) => {
|
|
188
188
|
await limiter.acquire();
|
|
189
189
|
try {
|
|
190
|
-
const cleanRelativePath =
|
|
191
|
-
const targetUrl = `${url}/${cleanRelativePath}${fullUrl.search || ''}
|
|
190
|
+
const cleanRelativePath = relativePathPrefixedWithSlash.replace(/^\/+|\/+$/g, '');
|
|
191
|
+
const targetUrl = `${url}/${cleanRelativePath}${fullUrl.search || ''}`;
|
|
192
192
|
console.log(`Fetching from: ${targetUrl}`);
|
|
193
193
|
const headers = token ? { Authorization: `Bearer ${token}` } : undefined;
|
|
194
194
|
const response = await fetch(targetUrl, { headers, });
|
|
@@ -205,7 +205,7 @@ export async function startProxyServer(
|
|
|
205
205
|
const responses = await Promise.all(fetchPromises);
|
|
206
206
|
const successResponse = responses.find((r): r is Response => r !== null);
|
|
207
207
|
if (!successResponse) {
|
|
208
|
-
console.error(`All registries failed for ${
|
|
208
|
+
console.error(`All registries failed for ${relativePathPrefixedWithSlash}`);
|
|
209
209
|
res.writeHead(404).end('Not Found - All upstream registries failed');
|
|
210
210
|
return;
|
|
211
211
|
}
|
|
@@ -215,7 +215,7 @@ export async function startProxyServer(
|
|
|
215
215
|
try {
|
|
216
216
|
const data = await successResponse.json() as PackageData;
|
|
217
217
|
if (data.versions) {
|
|
218
|
-
const proxyBase = `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host || 'localhost:' + proxyPort}${
|
|
218
|
+
const proxyBase = `${proxyConfig.https ? 'https' : 'http'}://${req.headers.host || 'localhost:' + proxyPort}${basePathPrefixedWithSlash}`;
|
|
219
219
|
for (const version in data.versions) {
|
|
220
220
|
const dist = data.versions[version]?.dist;
|
|
221
221
|
if (dist?.tarball) {
|
|
@@ -244,7 +244,7 @@ export async function startProxyServer(
|
|
|
244
244
|
};
|
|
245
245
|
res.writeHead(successResponse.status, safeHeaders);
|
|
246
246
|
successResponse.body.pipe(res).on('error', (err:any) => {
|
|
247
|
-
console.error(`Stream error for ${
|
|
247
|
+
console.error(`Stream error for ${relativePathPrefixedWithSlash}:`, err);
|
|
248
248
|
res.writeHead(502).end('Stream Error');
|
|
249
249
|
});
|
|
250
250
|
}
|
|
@@ -285,7 +285,7 @@ export async function startProxyServer(
|
|
|
285
285
|
proxyPort = address.port;
|
|
286
286
|
const portFile = join(process.env.PROJECT_ROOT || process.cwd(), '.registry-proxy-port');
|
|
287
287
|
writeFile(portFile, proxyPort.toString()).catch(e => console.error('Failed to write port file:', e));
|
|
288
|
-
console.log(`Proxy server running on ${proxyConfig.https ? 'https' : 'http'}://localhost:${proxyPort}${
|
|
288
|
+
console.log(`Proxy server running on ${proxyConfig.https ? 'https' : 'http'}://localhost:${proxyPort}${basePathPrefixedWithSlash}`);
|
|
289
289
|
resolve(server);
|
|
290
290
|
});
|
|
291
291
|
});
|