Use promises, split tests, make music services modular, add deezer.
This commit is contained in:
parent
7cc68d1968
commit
2b65c0632a
15 changed files with 407 additions and 307 deletions
117
lib/rdio.js
117
lib/rdio.js
|
@ -1,117 +0,0 @@
|
|||
"use strict";
|
||||
var parse = require('url').parse;
|
||||
|
||||
if (!process.env.RDIO_API_KEY || !process.env.RDIO_API_SHARED) {
|
||||
throw new Error("You need to set RDIO_API_KEY and RDIO_API_SHARED environment variables");
|
||||
}
|
||||
|
||||
|
||||
var rdio = require('rdio')({
|
||||
rdio_api_key: process.env.RDIO_API_KEY,
|
||||
rdio_api_shared: process.env.RDIO_API_SHARED,
|
||||
});
|
||||
|
||||
module.exports.lookupId = function(id, next) {
|
||||
rdio.api("", "", {
|
||||
method: 'getObjectFromShortCode',
|
||||
short_code: id,
|
||||
}, function(err, results) {
|
||||
var result = JSON.parse(results).result;
|
||||
var parsed = parse(result.shortUrl)
|
||||
var id = parsed.path.replace("/x/", "").replace("/", "");
|
||||
var type = result.album ? "track" : "album";
|
||||
next({
|
||||
service: "rdio",
|
||||
type: type,
|
||||
id: id,
|
||||
name: result.name,
|
||||
url: result.shortUrl,
|
||||
artwork: result.icon.replace("http:", "").replace("square-200", "square-250"),
|
||||
artist: {
|
||||
name: result.artist
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.exports.lookupUrl = function(url, next) {
|
||||
var parsed = parse(url);
|
||||
|
||||
var data;
|
||||
|
||||
if (parsed.host == "rd.io") {
|
||||
data = {
|
||||
method: 'getObjectFromShortCode',
|
||||
short_code: parsed.path.replace("/x/", "").replace("/", ""),
|
||||
};
|
||||
} else if (parsed.host.match(/rdio\.com$/)) {
|
||||
data = {
|
||||
method: 'getObjectFromUrl',
|
||||
url: parsed.path,
|
||||
};
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
|
||||
rdio.api("", "", data, function(err, results) {
|
||||
var result = JSON.parse(results).result;
|
||||
var parsed = parse(result.shortUrl)
|
||||
var id = parsed.path.replace("/x/", "").replace("/", "");
|
||||
var type = result.album ? "track" : "album";
|
||||
next({
|
||||
service: "rdio",
|
||||
type: type,
|
||||
id: id,
|
||||
name: result.name,
|
||||
url: result.shortUrl,
|
||||
artwork: result.icon.replace("http:", "").replace("square-200", "square-250"),
|
||||
artist: {
|
||||
name: result.artist
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.exports.search = function(data, next) {
|
||||
var query;
|
||||
var type = data.type;
|
||||
|
||||
if (type == "album") {
|
||||
query = data.artist.name + " " + data.name;
|
||||
} else if (type == "track") {
|
||||
query = data.artist.name + " " + data.album.name + " " + data.name;
|
||||
}
|
||||
|
||||
rdio.api("", "", {
|
||||
query: query,
|
||||
method: 'search',
|
||||
types: type,
|
||||
}, function(err, results) {
|
||||
var results = JSON.parse(results).result.results;
|
||||
|
||||
var result = results.filter(function(result) {
|
||||
if (type == "album" && result.name == data.name) {
|
||||
return result;
|
||||
} else if (type == "track" && result.album == data.album.name) {
|
||||
return result;
|
||||
}
|
||||
}).shift();
|
||||
|
||||
if (!result) {
|
||||
return next({service: "rdio"});
|
||||
}
|
||||
var parsed = parse(result.shortUrl)
|
||||
var id = parsed.path.replace("/x/", "").replace("/", "");
|
||||
next({
|
||||
service: "rdio",
|
||||
type: type,
|
||||
id: id,
|
||||
name: result.name,
|
||||
url: result.shortUrl,
|
||||
artwork: result.icon.replace("http:", "").replace("square-200", "square-250"),
|
||||
artist: {
|
||||
name: result.artist
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue