Skip to content

A Cisco Meraki Dashboard API service library. Handles API keys, redirects, and exposes methods for the most popular endpoints, and can act as a proxy.

Notifications You must be signed in to change notification settings

dexterlabora/meraki-service

Repository files navigation

meraki-service

A Meraki Dashboard API service

A collection of methods to interact with the Meraki Dashboard API.

Documentation

About

This is a convenient API wrapper built with Axios. The service saves time by handling common tasks when working with the API. It works for both backend and frontend code. Tested primarily with NodeJS w/ Express and VueJS.

-- In Active Development -- This service could have several breaking changes as it is being developed. You can clone this into your application if you want stability for now.

Features:

  • Collection of the most common Dashboard API calls
  • Handles URL redirects
  • Handles Meraki error messages
  • Custom scripts to traverse multiple API enpoints or enrich the response data

Notes:

  • The API rate limit is 5 calls per second (as of May, 2018)
  • The Meraki API implements CORS, thus all API calls to Meraki must not come directly from the client browser. Instead, interact with the API from the server or create proxy server. You can then use this library on the client side, using your proxy address as the new endpoint. See the examples folder.

Install

Requires Node >= v8

npm install https://github.com/dexterlabora/meraki-service.git

or (once published)

npm install meraki-service

Test

An included test script will run an inventory of your organizations, networks, devices and group policies. Run this to confirm everything is working properly.

API_KEY=1234YourAPIKey node ./test/test

There are additional script samples in the file ./test/test-scripts. Open the file to uncomment out sample scripts, then run from the command.

API_KEY=1234YourAPIKey ORG_ID=123 node ./test/test-scripts

Usage

API endpoint methods

The meraki-service.js file contains a JavaScript class with all of the service methods. Explore this file to understand what each of the method names are and their required parameters. Use the Meraki Dashboard API docs to understand the required body parameters, etc.

// index.js
const Meraki = require('meraki-service');
const meraki = new Meraki('YourAPIKey','https://api.meraki.com/api/v0');

meraki.getOrganizations().then(res => {
    console.log('Organizations: ', res);
});

$ node index.js
$ Organizations:  [ { id: 549236, name: 'Meraki DevNet Sandbox' } ]

As an Express API proxy

... <node express> ...
app.use('/api', jsonParser, function (req, res){
    console.log('API request ', req.method, req.url, req.method != 'GET' ? req.body:'');

    var options = {
      url: req.url,
      method: req.method,
      body: JSON.stringify(req.body)
    };

    const apiKey = req.headers['x-cisco-meraki-api-key'] || configs.apiKey;
    const meraki = new Meraki(apiKey,configs.apiUrl);
    meraki.proxy(options).then((response) => {
      res.send(response);
      res.end();
    });

});
$ node index.js
Server Running on:      http://localhost:5000
Meraki API Proxy:       http://localhost:5000/api
Meraki API Endpoint:    https://api.meraki.com/api/v0

Use the proxy address with desired API endpoint (uses server-side API key)

$ curl -X GET http://localhost:5000/api/organizations

[{"id":549236,"name":"Meraki DevNet Sandbox"}]

The proxy accepts an API key override. Just specify the new header in the reqest

$ curl -X GET \
>   http://localhost:5000/api/organizations \
>   -H 'X-Cisco-Meraki-API-Key: 2f301bccd61b6c6BoGuS3f76e5eb66ebd170f'

[{"id":549236,"name":"Meraki DevNet Sandbox"}]

Further Development

  • The /endpoints folder contains files for each of the endpoint groups.
  • It is easy to duplicate any of the methods and modify them for new API endpoints.
  • Send me a pull request if you want to contribute.

ToDo

  • improve redirect handling
  • improve error handling
  • complete JSDocs
    • Descriptions
    • Sample Code
  • implement proper tests

License

Apache-v2.0

About

A Cisco Meraki Dashboard API service library. Handles API keys, redirects, and exposes methods for the most popular endpoints, and can act as a proxy.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published