Allow partial suggestions
This commit is contained in:
parent
3fdf355bb5
commit
c28822c724
24
suggest.js
24
suggest.js
|
@ -37,9 +37,9 @@ var github = function(url, cb) {
|
||||||
githubStars(user, repo),
|
githubStars(user, repo),
|
||||||
githubLicense(user, repo),
|
githubLicense(user, repo),
|
||||||
]).then(function(badges) {
|
]).then(function(badges) {
|
||||||
cb({badges:badges});
|
cb({badges:badges.filter(function(b) { return b != null; })});
|
||||||
}).catch(function(err) {
|
}).catch(function(err) {
|
||||||
cb({badges:badges, err:err});
|
cb({badges:[], err:err});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -85,9 +85,9 @@ var githubLicense = function(user, repo) {
|
||||||
// A special User-Agent is required:
|
// A special User-Agent is required:
|
||||||
// http://developer.github.com/v3/#user-agent-required
|
// http://developer.github.com/v3/#user-agent-required
|
||||||
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
||||||
if (err != null) { reject(err); return; }
|
if (err != null) { resolve(null); return; }
|
||||||
try {
|
try {
|
||||||
if ((+res.headers['x-ratelimit-remaining']) === 0) { reject(Error('rate limited')); return; }
|
if ((+res.headers['x-ratelimit-remaining']) === 0) { resolve(null); return; }
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
var defaultBranch = data.default_branch;
|
var defaultBranch = data.default_branch;
|
||||||
// Step 2: Get the SHA-1 hash of the branch tip.
|
// Step 2: Get the SHA-1 hash of the branch tip.
|
||||||
|
@ -97,9 +97,9 @@ var githubLicense = function(user, repo) {
|
||||||
+ '&client_secret=' + serverSecrets.gh_client_secret;
|
+ '&client_secret=' + serverSecrets.gh_client_secret;
|
||||||
}
|
}
|
||||||
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
||||||
if (err != null) { reject(err); return; }
|
if (err != null) { resolve(null); return; }
|
||||||
try {
|
try {
|
||||||
if ((+res.headers['x-ratelimit-remaining']) === 0) { reject(Error('rate limited')); return; }
|
if ((+res.headers['x-ratelimit-remaining']) === 0) { resolve(null); return; }
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
var branchTip = data.commit.sha;
|
var branchTip = data.commit.sha;
|
||||||
// Step 3: Get the tree at the commit.
|
// Step 3: Get the tree at the commit.
|
||||||
|
@ -109,9 +109,9 @@ var githubLicense = function(user, repo) {
|
||||||
+ '&client_secret=' + serverSecrets.gh_client_secret;
|
+ '&client_secret=' + serverSecrets.gh_client_secret;
|
||||||
}
|
}
|
||||||
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
request(apiUrl, { headers: { 'User-Agent': 'Shields.io' } }, function(err, res, buffer) {
|
||||||
if (err != null) { reject(err); return; }
|
if (err != null) { resolve(null); return; }
|
||||||
try {
|
try {
|
||||||
if ((+res.headers['x-ratelimit-remaining']) === 0) { reject(Error('rate limited')); return; }
|
if ((+res.headers['x-ratelimit-remaining']) === 0) { resolve(null); return; }
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
var treeArray = data.tree;
|
var treeArray = data.tree;
|
||||||
var licenseBlob;
|
var licenseBlob;
|
||||||
|
@ -128,7 +128,7 @@ var githubLicense = function(user, repo) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Could not find license file
|
// Could not find license file
|
||||||
if (!licenseBlob) { reject(Error('no license file')); return; }
|
if (!licenseBlob) { resolve(null); return; }
|
||||||
|
|
||||||
// Step 4: Get the license blob.
|
// Step 4: Get the license blob.
|
||||||
var apiUrl = 'https://api.github.com/repos/' + user + '/' + repo + '/git/blobs/' + licenseBlob;
|
var apiUrl = 'https://api.github.com/repos/' + user + '/' + repo + '/git/blobs/' + licenseBlob;
|
||||||
|
@ -143,9 +143,9 @@ var githubLicense = function(user, repo) {
|
||||||
// https://developer.github.com/v3/media/
|
// https://developer.github.com/v3/media/
|
||||||
request(apiUrl, { headers: { 'User-Agent': 'Shields.io', 'Accept': 'appplication/vnd.github.raw' } },
|
request(apiUrl, { headers: { 'User-Agent': 'Shields.io', 'Accept': 'appplication/vnd.github.raw' } },
|
||||||
function(err, res, buffer) {
|
function(err, res, buffer) {
|
||||||
if (err != null) { reject(err); return; }
|
if (err != null) { resolve(null); return; }
|
||||||
try {
|
try {
|
||||||
if ((+res.headers['x-ratelimit-remaining']) === 0) { reject(Error('rate limited')); return; }
|
if ((+res.headers['x-ratelimit-remaining']) === 0) { resolve(null); return; }
|
||||||
var license = guessLicense(buffer);
|
var license = guessLicense(buffer);
|
||||||
if (license) {
|
if (license) {
|
||||||
badgeData.text[1] = license;
|
badgeData.text[1] = license;
|
||||||
|
@ -157,7 +157,7 @@ var githubLicense = function(user, repo) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
// Not a recognized license
|
// Not a recognized license
|
||||||
reject(Error('unknown license'));
|
resolve(null);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} catch(e) { reject(e); return; }
|
} catch(e) { reject(e); return; }
|
||||||
|
|
Loading…
Reference in New Issue
Block a user