From 021b84d95440ab947bfbf79de33db765ba4f5d04 Mon Sep 17 00:00:00 2001 From: Karolis Narkevicius Date: Mon, 5 Feb 2018 21:19:56 +0000 Subject: [PATCH] feat(auth): Add basic auth support for pathed registries --- __tests__/registries/npm-registry.js | 51 +++++++++++++++++++++++++++- src/registries/npm-registry.js | 2 +- 2 files changed, 51 insertions(+), 2 deletions(-) diff --git a/__tests__/registries/npm-registry.js b/__tests__/registries/npm-registry.js index ce0f97e464..92c6e2226c 100644 --- a/__tests__/registries/npm-registry.js +++ b/__tests__/registries/npm-registry.js @@ -6,6 +6,11 @@ import NpmRegistry from '../../src/registries/npm-registry.js'; import {BufferReporter} from '../../src/reporters/index.js'; import homeDir, {home} from '../../src/util/user-home-dir.js'; +function basicAuth (username, password) { + const pw = new Buffer(String(password), 'base64').toString(); + return new Buffer(String(username) + ':' + pw).toString('base64'); +} + describe('normalizeConfig', () => { beforeAll(() => { process.env.REPLACE = 'REPLACED'; @@ -554,6 +559,46 @@ describe('request', () => { }, ], }, + { + title: 'using username/password config for registries where pathnames play a role', + config: { + '@private:registry': 'https://registry.myorg.com/api/npm/registry/', + '//registry.myorg.com/api/npm/registry/:username': 'scopedPrivateUsername', + '//registry.myorg.com/api/npm/registry/:_password': 'scopedPrivatePassword', + '//registry.myorg.com/api/packages/:username': 'scopedPrivateUsername', + '//registry.myorg.com/api/packages/:_password': 'scopedPrivatePassword', + }, + requests: [ + { + url: '@private/pkg', + pkg: '@private/pkg', + expect: { + root: 'https://registry.myorg.com/api/npm/registry/', + auth: basicAuth('scopedPrivateUsername', 'scopedPrivatePassword'), + basicAuth: true + }, + }, + { + url: 'https://some.cdn.com/some-hash/@private-pkg-1.0.0.tar.gz', + pkg: '@private/pkg', + expect: {root: 'https://some.cdn.com', auth: false}, + }, + { + url: 'https://some.cdn.com/@private/pkg', + pkg: null, + expect: {root: 'https://some.cdn.com', auth: false}, + }, + { + url: 'https://registry.myorg.com/api/packages/private---pkg.tar.gz', + pkg: '@private/pkg', + expect: { + root: 'https://registry.myorg.com/api/packages/', + auth: basicAuth('scopedPrivateUsername', 'scopedPrivatePassword'), + basicAuth: true + }, + }, + ], + }, ]; testCases.forEach(testCase => { @@ -566,7 +611,11 @@ describe('request', () => { (req.skip ? it.skip : req.only ? it.only : it)(desc, () => { const requestParams = registry.request(req.url, {}, req.pkg); expect(requestParams.url.substr(0, req.expect.root.length)).toBe(req.expect.root); - expect(requestParams.headers.authorization).toBe(req.expect.auth ? `Bearer ${req.expect.auth}` : undefined); + if (req.expect.basicAuth) { + expect(requestParams.headers.authorization).toBe(req.expect.auth ? `Basic ${req.expect.auth}` : undefined); + } else { + expect(requestParams.headers.authorization).toBe(req.expect.auth ? `Bearer ${req.expect.auth}` : undefined); + } }); }); }); diff --git a/src/registries/npm-registry.js b/src/registries/npm-registry.js index 3a553d1131..a2f3bdc410 100644 --- a/src/registries/npm-registry.js +++ b/src/registries/npm-registry.js @@ -171,7 +171,7 @@ export default class NpmRegistry extends Registry { const requestParts = urlParts(requestUrl); return !!Object.keys(config).find(option => { const parts = option.split(':'); - if (parts.length === 2 && parts[1] === '_authToken') { + if (parts.length === 2 && parts[1] === '_authToken' || parts[1] === '_password') { const registryParts = urlParts(parts[0]); if (requestParts.host === registryParts.host && requestParts.path.startsWith(registryParts.path)) { return true;