Skip to content
This repository has been archived by the owner on Dec 28, 2024. It is now read-only.

Latest commit

 

History

History
93 lines (66 loc) · 3.52 KB

README.md

File metadata and controls

93 lines (66 loc) · 3.52 KB

node-meraki-dashboard

A modern now outdated node.js client library for using the Meraki Dashboard API (v0). See the deprecation notice below.

⚠️ Deprecation Notice ⚠️

This library has aged poorly, having been created in 2019 when I was working with Cisco Meraki products for a hackathon at the time. The Dashboard API has evolved significantly since, with v1 being released since 2020 and superseding v0 since February 5th, 2022. Additionally, as of December 2024 (v1.53.0 of their API), they have 520 unique endpoint paths and 773 operations within said endpoints, and the only officially supported API client for v1 is written in Python.

With that all said, this library is officially deprecated for future Cisco Meraki API development. This repository will remain for anyone who's used this library before and is looking for an alternative solution below. The following documentation links have been updated but it's recommended to always check the official documentation website.

Documentation (Updated since December 2024)

Additional Resources

  • Meraki Read-only Sandbox - This read-only sandbox provides a "developer environment to experiment with the Cisco Meraki Dashboard, Dashboard API, Captive Portal integration, MV Sense, Webhook Alerts, and Location Scanning"

Alternative Solutions

You now have a few options that you can consider in place of this library, for which I've listed the instructions for the first 2. The 3rd one is NOT a solution I officially endorse, but it is an option if you desire a strongly-typed API interface.

  1. Switch to their official Python Client Library.
  2. Use Axios (via the Client pattern) for API calls
  3. Use an OpenAPI client generator like @hey-api/openapi-ts.

Official Python Client Library

Installation

pip install --upgrade meraki

export MERAKI_DASHBOARD_API_KEY=YOUR_KEY_HERE

Sync version

import meraki

dashboard = meraki.DashboardAPI()
my_orgs = dashboard.organizations.getOrganizations()

for org in my_orgs:
    print(org)

Async version

import asyncio
import meraki.aio

def main():
    async with meraki.aio.AsyncDashboardAPI() as aiomeraki:
        my_orgs = await aiomeraki.organizations.getOrganizations()

    for org in my_orgs:
        print(org)

if __name__ == "__main__":
    asyncio.run(main())

Axios for API Calls

Installation

npm install --save axios
import axios from 'axios';

// TODO: Change this line
const API_KEY = 'INSERT_API_KEY_HERE';

const meraki = axios.create({
    baseURL: 'https://api.meraki.com/api/v1/',
    headers: {
        'X-Cisco-Meraki-API-Key': API_KEY,
        'Content-Type': 'application/json; charset=utf-8',
        'Accept': 'application/json'
    },
})

const my_orgs = await meraki.get('/organizations');
for (const org of my_orgs) {
    console.log(org);
}