A promise based json api wrapper for the MAL (myanimelist) api. http://myanimelist.net/modules.php?go=api
This api has not been tested in production environments.
All api requests return promises, if you are using in the browser instead of nodejs, use a Promise polyfill where neccesarry. For browsers that don't support ES6 see the ES5 file in the es5/ directory.
Install with npm install MALjs or bower install MALjs
To use in the browser you might want to use the es5/mal.min.js file and load a promise polyfill if neccesarry.
For node require the file first: const MALjs = require('MALjs');
To make manga calls, replace anime with manga.
// create an new api instance with your myanimelist user name and password
const mal = new MALjs('MAL username', 'MAL password');
// search my animelist
mal.anime.search('search string')
  .then(result => result) // contains the json result on success
  .catch(err => err); // contains an error message if the request fails
// Get the authenticated users animelist
mal.anime.list()
  .then(result => result)
  .catch(err => err);
// adds an anime to the list
mal.anime.add('71', { // '71' is the animes ID (retrieved from search())
  episode: "1",
  status: "6", // 1/watching, 2/completed, 3/onhold, 4/dropped, 6/plantowatch
  score: "7"
})
  .then(result => result)
  .catch(err => err);
// Updates an anime on the list
mal.anime.update('71', {
  status: "1"
})
  .then(result => result)
  .catch(err => err);
// Deletes an anime from the list
mal.anime.delete('71')
  .then(result => result)
  .catch(err => err);
// Verify the users credentials
api.verifyCredentials()
  .then(result => result)
  .catch(err => err);Anime values
- episode. int
- status. int OR string. 1/watching, 2/completed, 3/onhold, 4/dropped, 6/plantowatch
- score. int
- storage_type. int
- storage_value. float
- times_rewatched. int
- rewatch_value. int
- date_start. date. mmddyyyy
- date_finish. date. mmddyyyy
- priority. int
- enable_discussion. int. 1=enable, 0=disable
- enable_rewatching. int. 1=enable, 0=disable
- comments. string
- fansub_group. string
- tags. string. tags separated by commas
Manga Values
- chapter. int
- volume. int
- status. *int OR string. 1/reading, 2/completed, 3/onhold, 4/dropped, 6/*plantoread
- score. int
- times_reread. int
- reread_value. int
- date_start. date. mmddyyyy
- date_finish. date. mmddyyyy
- priority. int
- enable_discussion. int. 1=enable, 0=disable
- enable_rereading. int. 1=enable, 0=disable
- comments. string
- scan_group. string
- tags. string. tags separated by commas
- retail_volumes. int
Since the api uses promises you can use things like chaining and parallel requests.
Chaining requests
var api = new MALjs('MAL username', 'MAL password');
// Make the first request
api.anime.search('Full Metal')
  .then(result => {
    // result.anime.entry contains an array of animes matching the search query
    var animeId =  result.anime[0].id;
    // Make a new request, adding the anime to the users list
    return api.anime.add(animeId);
  })
  .then(result => {
    console.log('Anime added!', result);
  })
  .catch(err => {
    console.log('Something went wrong!', err);
  });Parallel request
var api = new MALjs('MAL username', 'MAL password');
// Add multiple anime to the users myanimelist.
Promise.all([
  api.anime.add('71'),
  api.anime.add('231'),
  api.anime.add('71')
])
  // When all promises resolve.
  .then(results => {
    console.log('All anime were added!', results);
  })
   // When one promise fails, all fail.
  .catch(err => {
    console.log('Something went wrong!', err);
  });Install dependencies with npm install.
Run npm run build to build files.
NOTE: Tests are run against the live MAL Api, Don't use your actual MAL account if you don't want to alter your list
If you want to test locally run chrome with the  --args --disable-web-security --user-data-dir (MACos) commands, becuase MAL has a No-Access-Control-Allow-Origin header set. However keep in mind this will causes browser stability and security issues.
In order to test add the file env.js to the project root with MAL credentials.
// env.js contents
(function() {
  var root = this;
  var env = {
    user: 'username',
    password: 'password',
  };
  if (typeof exports !== 'undefined') {
    if (typeof module !== 'undefined' && module.exports) {
      exports = module.exports = env;
    }
    exports._ENV = env;
  } else {
    root._ENV = env;
  }
}).call(this);Open test.html in the browser or run node.js in node to execute tests.