Skip to content

Node.js v1.x.x migration guide

Vincent Voyer edited this page Apr 20, 2015 · 10 revisions

You can now use the algoliasearch-client-js in all JavaScript environments, using the same unified API.

The new API is not backward compatible with the previous Node.js client, we made a few changes.

If you have any issue, please contact our team at [email protected].

Table of contents

  1. Migrate your code
  2. Installation
  3. Initialization
  4. Callback convention
  5. New function signatures
  6. New features
  1. Can I still use V1?

Migrate your code

Installation

The JavaScript client can be installed with:

npm install algoliasearch --save

The previous Node.js-only package algolia-search was deprecated.

Initialization

Before

new AlgoliaSearch(applicationID, apiKey/*, httpsAgent, hostsArray*/);

After

algoliasearch(applicationID, apiKey/*, opts*/);

Calling algoliasearch(..) without an applicationID or apiKey will now throw an Error.

Most of the time, you do not need to pass any opts to get a client.

Hosts are computed automatically and every client is already using keepalive connections.

httpsAgent and hostsArray were removed.

See the list of available client opts.

Callback convention

Before

index.search(query, function(error, content) {
  // error `true` or `false`
  // content is either the results or an error message
}, params);

After

index.search(query, params, function(err, content) {
  // err `null` or `Error` object (with a `message` property)
  // content contains the results if no error
});

All asynchronous methods are now using these two conventions:

You can also use promises.

Changed function signatures

Due to the change in the callback convention, we modified these functions:

  • index.search
    • Before: index.search(query, callback[, params, ClassToDerive])
    • After, any of the following:
      • index.search(query[, cb])
      • index.search(query[, params, cb])
      • index.search(params[, cb]) where params.query is filled
      • We removed the ClassToDerive, if you need to instantiate a class on every hit, please do it on your side.
      • index.search is an important function, we made it so it can be used in multiple ways
  • client.getLogs
    • Before: client.getLogs(cb[, offset, length])
    • After: client.getLogs([offset, length, cb])
  • client.listIndexes
    • Before: client.listIndexes(cb[, page])
    • After: client.listIndexes([page, cb])
  • Managing keys:
    • We removed client|index.addUserKeyWithValidityAndIndexes(), client|index.updateUserKeyWithValidity(), client|index.updateUserKeyWithValidityAndIndexes()
    • You can now use client|index.addUserKey(acls[, params, callback]) and client|index.updateUserKey(key, acls[, params, callback]). Where params: {validity: val, maxQueriesPerIPPerHour: val, maxHitsPerQuery:val, indexes: val}
  • client.multipleQueries was renamed and reworked to client.search, usage:
      client.search([{
        indexName: 'some-index',
        query: 'hello world',
        params: {
          // query parameters
          hitsPerPage: 200
        }
      }, {
        indexName: 'some-other-index',
        query: 'HI!',
        params: {
          // query parameters
          hitsPerPage: 10
        }
      }], callback)
    • query can also be given as params.query
  • index.addObject
    • Before: index.addObject(content[, callback, objectID])
    • After: index.addObject(content[, objectID, callback])
  • index.getObject
    • Before: index.getObject(objectID[, callback, attributes, ClassToDerive])
    • After: index.getObject(objectID[, attributes, callback])
    • We removed the ClassToDerive option. Same reason as for search.
  • index.browse
    • Before: index.browse(page, cb[, hitsPerPage])
    • After: index.browse(page[, hitsPerPage, cb])
  • index.searchDisjunctiveFaceting() was removed, you can now use the algoliasearch-helper-js

New features

Isomorphic module

This new JavaScript module is now usable on the browser and on the server with the same API.

Promises

The JavaScript client now supports both promises and callbacks for asynchronous calls.

var algoliasearch = require('algoliasearch');
var client = algoliasearch('applicationID', 'apiKey');
var index = client.initIndex('indexName');

index.search('something')
  .then(function success(content) {
    console.log('Success', content);
  })
  .catch(function failure(err) {
    console.log('Failure', err);
  });

The promise implementation is the native Promise from the environment or jakearchibald/es6-promise for other unsupported environments the Promise object.

When using the parse.com build, you get Parse promises.

callback AND promise?

No.

If you pass a callback, you won't get a promise. If no callback passed, you get a promise.

Automatic keepalive

The Node.js client now automatically use keepalived connections to our servers.

Can I still use V1?

Yes. If you are using the V1 of our Node.js client and do not want to upgrade then you can stick to V1.

We have a V1 branch where we will publish critical updates.

Clone this wiki locally