Skip to content

Commit

Permalink
Better match npm's SCP vs SSH URL heuristic (#3147)
Browse files Browse the repository at this point in the history
Fixes #3146
  • Loading branch information
kornelski authored and arcanis committed Apr 18, 2017
1 parent 2ee0d8a commit 4e5b5f0
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
6 changes: 6 additions & 0 deletions __tests__/util/git.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,12 @@ test('npmUrlToGitUrl', () => {
hostname: 'github.com',
repository: 'git://github.com/npm-opam/ocamlfind.git',
});
expect(Git.npmUrlToGitUrl('git+ssh://git@gitlab.mydomain.tld:10202/project-name/my-package.git'))
.toEqual({
protocol: 'ssh:',
hostname: 'gitlab.mydomain.tld',
repository: 'ssh://git@gitlab.mydomain.tld:10202/project-name/my-package.git',
});
expect(Git.npmUrlToGitUrl('git+ssh://git@github.com/npm-opam/ocamlfind.git'))
.toEqual({
protocol: 'ssh:',
Expand Down
8 changes: 5 additions & 3 deletions src/util/git.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,11 @@ export default class Git {
*/
static npmUrlToGitUrl(npmUrl: string): GitUrl {
// Special case in npm, where ssh:// prefix is stripped to pass scp-like syntax
// which works as remote path only if there are no slashes before ':'
const match = npmUrl.match(/^git\+ssh:\/\/((?:[^@:\/]+@)?([^@:\/]+):.*)/);
if (match) {
// which in git works as remote path only if there are no slashes before ':'.
const match = npmUrl.match(/^git\+ssh:\/\/((?:[^@:\/]+@)?([^@:\/]+):([^/]*).*)/);
// Additionally, if the host part is digits-only, npm falls back to
// interpreting it as an SSH URL with a port number.
if (match && /[^0-9]/.test(match[3])) {
return {
protocol: 'ssh:',
hostname: match[2],
Expand Down

0 comments on commit 4e5b5f0

Please sign in to comment.