node.js libary for the Baelor (Taylor Swift) API.
$ npm install baelorjs
baelorjs is a simple node.js libary for the Baelor API.
- To obtain an API key, npm install baelorjs and run the Create a new API user example*
Below is a simple example which shows it fetching a list of albums.
var Baelor = require('baelorjs'); // Include the node libary
var client = new Baelor({ // Create a new client
api_key: "xxx" // Set the api_key, can be done later with .setKey()
});
client.albums({ // Lets try get a list of albums
// We dont need to pass in anything for this API
},function(error,albums) { // Error and Albums returned as parameters
if(error){console.log(error);} // Check if there were any errors
else {
console.log(albums); // Do something with the albums
}
});
Here are some of the examples of the libary in use
var Baelor = require('baelorjs'); // Include the node libary
var client = new Baelor({ // Create a new client
// We dont have an api key yet, so leave this blank
});
client.userCreate({},function(error,user) {
if(error){console.log(error);} // Check if there were any errors
else {
console.log("Your API key is: " + user.api_key)
}
});
var Baelor = require('baelorjs'); // Include the node libary
var client = new Baelor({ // Create a new client
api_key: "xxx" // Set the api_key
});
client.albums({},function(error,albums) {
if(error){console.log(error);} // Check if there were any errors
else {
var names = albums.map(function(album){
return album.name;
});
console.log(names);
}
});
var Baelor = require('baelorjs'); // Include the node libary
var client = new Baelor({ // Create a new client
api_key: "xxx" // Set the api_key
});
client.songLyrics({
slug: "style" // We want to get the lyrics from the song Style (its slug is "style")
},function(error,lyrics) {
if(error){console.log(error);} // Check if there were any errors
else {
var lines = lyrics.split('\n'); // The lyrics are sent as one string with \n markers, so lets split it up
var longest_length = 0;
var longest_i = 0;
for (var i in lines) {
var current = lines[i].length
if(current>longest_length){
longest_length = current;
longest_i = i;
}
};
console.log("The longest line is line %s, and it says: %s",longest_i+1,lines[longest_i]);
}
});
There are multiple different object types that get returned by the APIs. To keep this doc clean, they will all be described up here instead of at each occurance.
An object that describes an album
{
slug: "xxx", // Slug of the album
name: "xxx", // Name of the album
released_at: "xxxx-xx-xxTxx:xx:xx", // Release date
length: "xx:xx:xx",
label: "xxx",
genres: [], // Array of genre keywords
producers: [], // Array of producer names
songs: [], // Array of Song Objects
album_cover:{
image_id: "xxx" // image_id of Image Object
}
}
An object that describes a song
{
slug: "xxx", // Slug of song
title: "xxx", // Name of song
length: "xx:xx:xx", // Length of song (time)
writers: [], // Array of writer names
producers: [], // Array of producer names
album: {} // Album Objects
}
An object that describes an image
{
data: "xxx", // String of image data (warning: raw data string)
type: "xxx", // Mime type of image (eg image/png)
}
An object that describes an api user
{
username: "xxx", // Username
email_address: "xxx", // Email address
api_key: "xxx" // API key,
is_admin: false // Has API admin rights
}
An object that describes an error
{
status_code: 0, // Integer error description
description: "xxx", // String representation of error
details: [] // This holds additional error details. This can be null.
}
Sets the api key of the Baelor client to use in API requests. Not needed if you pass in the api_key at init.
apikey
is your Baelor API key. You would acquire this calling .userCreate()- Required
client.setKey("xxx");
Gets a list of albums. Requires a client with an api key.
values
is an object containing values that are required by the API- Has no arguments
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
albums
- returns an array of
Album Object
s
- returns an array of
client.albums({},function(error,albums) {
if(error){console.log(error);}
else {
console.log(albums);
}
});
Gets an album. Requires a client with an api key.
values
is an object containing values that are required by the APIslug
is the slug of the album- Required
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
album
- returns an
Album Object
- returns an
client.album({
slug: "xxx"
},function(error,album) {
if(error){console.log(error);}
else {
console.log(album);
}
});
Gets a list of songs. Requires a client with an api key.
values
is an object containing values that are required by the API- Has no arguments
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
songs
- returns an array of
Song Object
s
- returns an array of
client.songs({},function(error,songs) {
if(error){console.log(error);}
else {
console.log(songs);
}
});
Gets an song. Requires a client with an api key.
values
is an object containing values that are required by the APIslug
is the slug of the song- Required
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
song
- returns a
Song Object
- returns a
client.song({
slug: "xxx"
},function(error,song) {
if(error){console.log(error);}
else {
console.log(song);
}
});
Gets an songs lyrics. Requires a client with an api key.
values
is an object containing values that are required by the APIslug
is the slug of the song- Required
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
lyrics
- returns a string of lyrics
client.songLyrics({
slug: "xxx"
},function(error,lyrics) {
if(error){console.log(error);}
else {
console.log(lyrics);
}
});
Gets an image (To-Improve). Requires a client with an api key.
values
is an object containing values that are required by the APIimage_id
is the id of an image. For example album artwork- Required
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
song
- returns an
Image Object
- returns an
client.image({
image_id: "xxx"
},function(error,image) {
if(error){console.log(error);}
else {
// Do something with image
}
});
Gets an API user.
values
is an object containing values that are required by the API- Has no arguments
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
user
- returns a
User Object
- returns a
client.user({},function(error,user) {
if(error){console.log(error);}
else {
console.log(user);
}
});
Creates a new API user.
values
is an object containing values that are required by the APIusername
is your desired username.- Required
- Must be between 1 and 25 characters long
- Must match
(?![\s])(?!.*[_-]{2})[a-zA-Z0-9-_]+(?
email
is your email address.- Required
- Must be a valid email address.
password
is your desired password.- Required
- Must be longer than 8 characters
- Must contain at least two of the following; number, lowercase letter, uppercase letter
callback
is called when the request completeserror
- if error occurs, returns an
Error Object
- else returns null
- if error occurs, returns an
user
- returns a
User Object
- returns a
client.createUser({
username: "xxx",
email: "xxx",
password: "xxx"
},function(error,user) {
if(error){console.log(error);}
else {
console.log(user);
}
});
Baelor API created by Alex Forbes-Reed @0xdeafcafe
baelorjs libary created by Jamie Davies @viralpickaxe