mirror of
https://github.com/all-contributors/cli.git
synced 2025-01-25 05:56:28 +00:00
feat(repo): github profile url should be valid (#268)
* feat(repo): github profile url should be valid * docs: add k3nsei as a contributor
This commit is contained in:
parent
649f6ceebc
commit
b77f86bf7f
6 changed files with 100 additions and 3 deletions
|
@ -429,6 +429,17 @@
|
||||||
"contributions": [
|
"contributions": [
|
||||||
"platform"
|
"platform"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"login": "k3nsei",
|
||||||
|
"name": "Piotr Stępniewski",
|
||||||
|
"avatar_url": "https://avatars2.githubusercontent.com/u/190422?v=4",
|
||||||
|
"profile": "https://github.com/k3nsei",
|
||||||
|
"contributions": [
|
||||||
|
"bug",
|
||||||
|
"code",
|
||||||
|
"test"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"skipCi": true
|
"skipCi": true
|
||||||
|
|
|
@ -134,14 +134,16 @@ Thanks goes to these wonderful people
|
||||||
<td align="center"><a href="https://anandchowdhary.com/?utm_source=github&utm_campaign=about-link"><img src="https://avatars3.githubusercontent.com/u/2841780?v=4" width="100px;" alt=""/><br /><sub><b>Anand Chowdhary</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=AnandChowdhary" title="Tests">⚠️</a> <a href="https://github.com/all-contributors/all-contributors-cli/issues?q=author%3AAnandChowdhary" title="Bug reports">🐛</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=AnandChowdhary" title="Code">💻</a></td>
|
<td align="center"><a href="https://anandchowdhary.com/?utm_source=github&utm_campaign=about-link"><img src="https://avatars3.githubusercontent.com/u/2841780?v=4" width="100px;" alt=""/><br /><sub><b>Anand Chowdhary</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=AnandChowdhary" title="Tests">⚠️</a> <a href="https://github.com/all-contributors/all-contributors-cli/issues?q=author%3AAnandChowdhary" title="Bug reports">🐛</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=AnandChowdhary" title="Code">💻</a></td>
|
||||||
<td align="center"><a href="https://phacks.dev/"><img src="https://avatars1.githubusercontent.com/u/2587348?v=4" width="100px;" alt=""/><br /><sub><b>Nicolas Goutay</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=phacks" title="Code">💻</a></td>
|
<td align="center"><a href="https://phacks.dev/"><img src="https://avatars1.githubusercontent.com/u/2587348?v=4" width="100px;" alt=""/><br /><sub><b>Nicolas Goutay</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=phacks" title="Code">💻</a></td>
|
||||||
<td align="center"><a href="https://github.com/tylerkrupicka"><img src="https://avatars1.githubusercontent.com/u/5761061?s=460&v=4" width="100px;" alt=""/><br /><sub><b>Tyler Krupicka</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=tylerkrupicka" title="Code">💻</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=tylerkrupicka" title="Tests">⚠️</a></td>
|
<td align="center"><a href="https://github.com/tylerkrupicka"><img src="https://avatars1.githubusercontent.com/u/5761061?s=460&v=4" width="100px;" alt=""/><br /><sub><b>Tyler Krupicka</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=tylerkrupicka" title="Code">💻</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=tylerkrupicka" title="Tests">⚠️</a></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
<td align="center"><a href="https://github.com/smoia"><img src="https://avatars3.githubusercontent.com/u/35300580?v=4" width="100px;" alt=""/><br /><sub><b>Stefano Moia</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=smoia" title="Code">💻</a></td>
|
<td align="center"><a href="https://github.com/smoia"><img src="https://avatars3.githubusercontent.com/u/35300580?v=4" width="100px;" alt=""/><br /><sub><b>Stefano Moia</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/commits?author=smoia" title="Code">💻</a></td>
|
||||||
<td align="center"><a href="https://github.com/ilai-deutel"><img src="https://avatars0.githubusercontent.com/u/10098207?v=4" width="100px;" alt=""/><br /><sub><b>Ilaï Deutel</b></sub></a><br /><a href="#platform-ilai-deutel" title="Packaging/porting to new platform">📦</a></td>
|
<td align="center"><a href="https://github.com/ilai-deutel"><img src="https://avatars0.githubusercontent.com/u/10098207?v=4" width="100px;" alt=""/><br /><sub><b>Ilaï Deutel</b></sub></a><br /><a href="#platform-ilai-deutel" title="Packaging/porting to new platform">📦</a></td>
|
||||||
|
<td align="center"><a href="https://github.com/k3nsei"><img src="https://avatars2.githubusercontent.com/u/190422?v=4" width="100px;" alt=""/><br /><sub><b>Piotr Stępniewski</b></sub></a><br /><a href="https://github.com/all-contributors/all-contributors-cli/issues?q=author%3Ak3nsei" title="Bug reports">🐛</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=k3nsei" title="Code">💻</a> <a href="https://github.com/all-contributors/all-contributors-cli/commits?author=k3nsei" title="Tests">⚠️</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<!-- markdownlint-enable -->
|
<!-- markdownlint-enable -->
|
||||||
<!-- prettier-ignore-end -->
|
<!-- prettier-ignore-end -->
|
||||||
|
|
||||||
<!-- ALL-CONTRIBUTORS-LIST:END -->
|
<!-- ALL-CONTRIBUTORS-LIST:END -->
|
||||||
|
|
||||||
This project follows the
|
This project follows the
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
const url = require('url')
|
const url = require('url')
|
||||||
const pify = require('pify')
|
const pify = require('pify')
|
||||||
const request = pify(require('request'))
|
const request = pify(require('request'))
|
||||||
|
const { parseHttpUrl, isValidHttpUrl } = require('../util/url')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the host based on public or enterprise GitHub.
|
* Get the host based on public or enterprise GitHub.
|
||||||
|
@ -93,7 +94,7 @@ const getUserInfo = function(username, hostname, optionalPrivateToken) {
|
||||||
.then(res => {
|
.then(res => {
|
||||||
const body = JSON.parse(res.body)
|
const body = JSON.parse(res.body)
|
||||||
|
|
||||||
let profile = body.blog || body.html_url
|
let profile = isValidHttpUrl(body.blog) ? body.blog : body.html_url
|
||||||
|
|
||||||
// Check for authentication required
|
// Check for authentication required
|
||||||
if (
|
if (
|
||||||
|
@ -112,7 +113,7 @@ const getUserInfo = function(username, hostname, optionalPrivateToken) {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
profile = profile.startsWith('http') ? profile : `http://${profile}`
|
profile = parseHttpUrl(profile)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
login: body.login,
|
login: body.login,
|
||||||
|
|
49
src/util/__tests__/url.js
Normal file
49
src/util/__tests__/url.js
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
import url from '../url';
|
||||||
|
|
||||||
|
test(`Result of protocol validation should be true`, () => {
|
||||||
|
expect(url.isHttpProtocol('http:')).toBe(true)
|
||||||
|
expect(url.isHttpProtocol('https:')).toBe(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of protocol validation should be false`, () => {
|
||||||
|
expect(url.isHttpProtocol('ftp:')).toBe(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of url validation should be true`, () => {
|
||||||
|
expect(url.isValidHttpUrl('https://api.github.com/users/octocat')).toBe(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of url validation should be false when url uses wrong protocol`, () => {
|
||||||
|
expect(url.isValidHttpUrl('git://git@github.com:all-contributors/all-contributors-cli.git')).toBe(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of url validation should be false when input isn't url`, () => {
|
||||||
|
expect(url.isValidHttpUrl('github-octocat')).toBe(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of parsed url should be equal`, () => {
|
||||||
|
const input = 'https://api.github.com/users/octocat'
|
||||||
|
const expected = 'https://api.github.com/users/octocat'
|
||||||
|
expect(url.parseHttpUrl(input)).toBe(expected)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Result of parsed url without protocol should be equal`, () => {
|
||||||
|
const input = 'example.com'
|
||||||
|
const expected = 'http://example.com/'
|
||||||
|
expect(url.parseHttpUrl(input)).toBe(expected)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Throw an error when parsed input isn't a string`, () => {
|
||||||
|
const input = 123
|
||||||
|
expect(url.parseHttpUrl.bind(null, input)).toThrowError('input must be a string')
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Throw an error when parsed url has wrong protocol`, () => {
|
||||||
|
const input = 'ftp://domain.xyz'
|
||||||
|
expect(url.parseHttpUrl.bind(null, input)).toThrowError('Provided URL has an invalid protocol')
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`Throw an error when parsed input isn't a URL`, () => {
|
||||||
|
const input = 'some string'
|
||||||
|
expect(url.parseHttpUrl.bind(null, input)).toThrowError('Invalid URL: http://some string')
|
||||||
|
})
|
|
@ -3,4 +3,5 @@ module.exports = {
|
||||||
contributionTypes: require('./contribution-types'),
|
contributionTypes: require('./contribution-types'),
|
||||||
git: require('./git'),
|
git: require('./git'),
|
||||||
markdown: require('./markdown'),
|
markdown: require('./markdown'),
|
||||||
|
url: require('./url'),
|
||||||
}
|
}
|
||||||
|
|
33
src/util/url.js
Normal file
33
src/util/url.js
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
function isHttpProtocol(input) {
|
||||||
|
return new RegExp('^https?\\:?$').test(input)
|
||||||
|
}
|
||||||
|
|
||||||
|
function isValidHttpUrl(input) {
|
||||||
|
try {
|
||||||
|
const url = new URL(input)
|
||||||
|
|
||||||
|
return isHttpProtocol(url.protocol)
|
||||||
|
} catch (e) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function parseHttpUrl(input) {
|
||||||
|
if (typeof input !== 'string') {
|
||||||
|
throw new TypeError('input must be a string')
|
||||||
|
}
|
||||||
|
|
||||||
|
const url = new URL(new RegExp('^\\w+\\:\\/\\/').test(input) ? input : `http://${input}`)
|
||||||
|
|
||||||
|
if (!isHttpProtocol(url.protocol)) {
|
||||||
|
throw new TypeError('Provided URL has an invalid protocol')
|
||||||
|
}
|
||||||
|
|
||||||
|
return url.toString()
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
isHttpProtocol,
|
||||||
|
isValidHttpUrl,
|
||||||
|
parseHttpUrl
|
||||||
|
}
|
Loading…
Reference in a new issue