meraki


Namemeraki JSON
Version 1.46.0 PyPI version JSON
download
home_pagehttps://github.com/meraki/dashboard-api-python
SummaryCisco Meraki Dashboard API library
upload_time2024-05-02 20:41:36
maintainerNone
docs_urlNone
authorCisco Meraki
requires_python>=3.8
licenseMIT
keywords meraki dashboard cisco
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Meraki Dashboard API Python Library

The Meraki Dashboard API Python library provides all current
Meraki [dashboard API](https://developer.cisco.com/meraki/api-v1/) calls to interface with the Cisco Meraki
cloud-managed platform. Meraki generates the library based on dashboard API's OpenAPI spec to keep it up to date with
the latest API releases, and provides the full source code for the library including the tools used to generate the
library, if you are participating in the Early Access program or would like to contribute to the development of the
library. Meraki welcomes constructive pull requests that maintain backwards compatibility with prior versions. The
library requires Python 3.10+, receives support from the community, and you can install it
via [PyPI](https://pypi.org/project/meraki/):

    pip install --upgrade meraki

If you participate
in [our Early Access program](https://community.meraki.com/t5/Developers-APIs/UPDATED-Beta-testing-with-the-Meraki-Developer-Early-Access/m-p/145344#M5808)
and would like to use early access features via the library,
you'll [find instructions in the generator readme](https://github.com/meraki/dashboard-api-python/tree/main/generator#readme).

## Features

While you can make direct HTTP requests to dashboard API in any programming language or REST API client, using a client
library can make it easier for you to focus on your specific use case, without the overhead of having to write functions
to handle the dashboard API calls. The Python library can also take care of error handling, logging, retries, and other
convenient processes and options for you automatically.

* Support for all API endpoints, as it uses the [OpenAPI specification](https://api.meraki.com/api/v1/openapiSpec) to
  generate source code
* Log all API requests made to a local file as well as on-screen console
* Automatic retries upon 429 rate limit errors, using
  the [`Retry-After` field](https://developer.cisco.com/meraki/api-v1/#!rate-limit) within response headers
* Get all (or a specified number of) pages of data with built-in pagination control
* Tweak settings such as maximum retries, certificate path, suppress logging, and other options
* Simulate POST/PUT/DELETE calls to preview first, so that network configuration does not get changed

## Setup

1. Enable API access in your Meraki dashboard organization and obtain an API
   key ([instructions](https://documentation.meraki.com/zGeneral_Administration/Other_Topics/The_Cisco_Meraki_Dashboard_API))

2. Keep your API key safe and secure, as it is similar to a password for your dashboard. If publishing your Python code
   to a wider audience, please research secure handling of API keys.

3. Install the latest version of [Python 3](ttps://wiki.python.org/moin/BeginnersGuide/NonProgrammers)

4. Use _pip_ (or an alternative such as _easy_install_) to install the library from the
   Python [Package Index](https://pypi.org/project/meraki/):
    * `pip install meraki`
    * If you have both Python3 and Python2 installed, you may need to use `pip3` (so `pip3 install meraki`) along
      with `python3` on your system
    * If _meraki_ was previously installed, you can upgrade to the latest non-beta release
      with `pip install --upgrade meraki`

5. The library supports Meraki dashboard API v1. You can also specify the version of the library when installing with
   _pip_:
    * See the full [release history](https://pypi.org/project/meraki/#history) to pick the version you want, or
      use `pip install meraki==` without including a version number to display the list of available versions
    * Versions begin with _1_ (1.0.0b**z** for beta)
    * Specify the version you want with the install command; for example: `pip install meraki==1.34.0`
    * You can also see the version currently installed with `pip show meraki`
    * End-of-life v0 versions of the Python library begin with _0_ (0.**x**.**y**) and are not supported nor
      recommended.

## Usage

1. Export your API key as
   an [environment variable](https://www.twilio.com/blog/2017/01/how-to-set-environment-variables.html), for example:

    ```shell
    export MERAKI_DASHBOARD_API_KEY=YOUR_KEY_HERE
    ```

2. Alternatively, define your API key as a variable in your source code; this method is not recommended due to its
   inherent insecurity.

3. Single line of code to import and use the library goes at the top of your script:

    ```python
    import meraki
    ```

4. Instantiate the client (API consumer class), optionally specifying any of the parameters available to set:

    ```python
    dashboard = meraki.DashboardAPI()
    ```

5. Make dashboard API calls in your source code, using the format _client.scope.operation_, where _client_ is the name
   you defined in the previous step (**dashboard** above), _scope_ is the corresponding scope that represents the first
   tag from the OpenAPI spec, and _operation_ is the operation of the API endpoint. For example, to make a call to get
   the list of organizations accessible by the API key defined in step 1, use this function call:

    ```python
    my_orgs = dashboard.organizations.getOrganizations()
    ```

### Examples

You can find fully working example scripts in the **examples** folder.

| Script                  | Purpose                                                                                                                                                                                               |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| **org_wide_clients.py** | That code collects the clients of all networks, in all orgs to which the key has access. No changes are made, since only GET endpoints are called, and the data is written to local CSV output files. |

## AsyncIO

**asyncio** is a library to write concurrent code using the **async/await** syntax. Special thanks to Heimo
Stieg ([@coreGreenberet](https://github.com/coreGreenberet)) who has ported the API to asyncio.

### Installation on macOS

If you use a Mac, then you may need to take
[additional Python installation steps](https://bugs.python.org/issue43404) that aren't required on other platforms. This
is [a limitation of macOS and not the library](https://github.com/meraki/dashboard-api-python/issues/226). This step is
not required on Windows.

### Usage

The usage is similiar to the sequential version above. However it has has some differences.

1. Export your API key as
   an [environment variable](https://www.twilio.com/blog/2017/01/how-to-set-environment-variables.html), for example:

    ```shell
    export MERAKI_DASHBOARD_API_KEY=YOUR_KEY_HERE
    ```

2. Alternatively, define your API key as a variable in your source code; this method is not recommended due to its
   inherent insecurity.

3. Single line of code to import and use the library goes at the top of your script:

    ```python
    import meraki.aio
    ```

4. Instantiate the client (API consumer class), optionally specifying any of the parameters available to set:

    ```python
    async with meraki.aio.AsyncDashboardAPI() as aiomeraki:
    ```
   The **async with** statement is important here to make sure, that the client sessions will be closed after using the
   api.

5. Make dashboard API calls in your source code, using the format await _client.section.operation_, where _client_ is
   the name you defined in the previous step (**aiomeraki** above), _section_ is the corresponding group (or tag from
   the OpenAPI spec) from the [API docs](https://developer.cisco.com/meraki/api/#/rest), and _operation_ is the name (or
   operation ID from OpenAPI) of the API endpoint. For example, to make a call to get the list of organizations
   accessible by the API key defined in step 1, use this function call:

    ```python
    my_orgs = await aiomeraki.organizations.getOrganizations()
    ```
6. Run everything inside an event loop.

```python
import asyncio

if __name__ == "__main__":
    # replace my_async_entry_point with the name of your entry point method
    asyncio.run(my_async_entry_point())
```

### Examples

You can find fully working example scripts in the **examples** folder.
| Script | Purpose |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| **aio_org_wide_clients.py** | That code is a asyncio port from org_wide_clients.py and collects the clients of all
networks, in all orgs to which the key has access. No changes are made, since only GET endpoints are called, and the
data is written to local CSV output files. |
| **aio_ips2firewall.py**     | That code will collect the source IP of security events and creates L7 firewall rules to
block them. `usage: aio_ips2firewall.py [-h] -o ORGANIZATIONS [ORGANIZATIONS ...] [-f FILTER] [-s] [-d DAYS]` |

## Note for application developers and ecosystem partners

We're so glad that you're leveraging our Python library. It's best practice to identify your application with every API
request that you make. You can easily do this automatically just by following the format defined
in [config.py](https://github.com/meraki/dashboard-api-python/blob/master/meraki/config.py) and passing the session
kwarg:

``` Python
MERAKI_PYTHON_SDK_CALLER
```

Unless you are an ecosystem partner, this identifier is optional.

1. If you are an ecosystem partner and you have questions about this requirement, please reach out to your ecosystem
   rep.
2. If you have any questions about the formatting, please ask your question by opening an issue in this repo.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/meraki/dashboard-api-python",
    "name": "meraki",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "meraki, dashboard, cisco",
    "author": "Cisco Meraki",
    "author_email": "api-feedback@meraki.net",
    "download_url": "https://files.pythonhosted.org/packages/e8/fa/227101501f0379973f6d2383c5c9c048130e0399d32aa19082e5e5187a98/meraki-1.46.0.tar.gz",
    "platform": null,
    "description": "# Meraki Dashboard API Python Library\n\nThe Meraki Dashboard API Python library provides all current\nMeraki [dashboard API](https://developer.cisco.com/meraki/api-v1/) calls to interface with the Cisco Meraki\ncloud-managed platform. Meraki generates the library based on dashboard API's OpenAPI spec to keep it up to date with\nthe latest API releases, and provides the full source code for the library including the tools used to generate the\nlibrary, if you are participating in the Early Access program or would like to contribute to the development of the\nlibrary. Meraki welcomes constructive pull requests that maintain backwards compatibility with prior versions. The\nlibrary requires Python 3.10+, receives support from the community, and you can install it\nvia [PyPI](https://pypi.org/project/meraki/):\n\n    pip install --upgrade meraki\n\nIf you participate\nin [our Early Access program](https://community.meraki.com/t5/Developers-APIs/UPDATED-Beta-testing-with-the-Meraki-Developer-Early-Access/m-p/145344#M5808)\nand would like to use early access features via the library,\nyou'll [find instructions in the generator readme](https://github.com/meraki/dashboard-api-python/tree/main/generator#readme).\n\n## Features\n\nWhile you can make direct HTTP requests to dashboard API in any programming language or REST API client, using a client\nlibrary can make it easier for you to focus on your specific use case, without the overhead of having to write functions\nto handle the dashboard API calls. The Python library can also take care of error handling, logging, retries, and other\nconvenient processes and options for you automatically.\n\n* Support for all API endpoints, as it uses the [OpenAPI specification](https://api.meraki.com/api/v1/openapiSpec) to\n  generate source code\n* Log all API requests made to a local file as well as on-screen console\n* Automatic retries upon 429 rate limit errors, using\n  the [`Retry-After` field](https://developer.cisco.com/meraki/api-v1/#!rate-limit) within response headers\n* Get all (or a specified number of) pages of data with built-in pagination control\n* Tweak settings such as maximum retries, certificate path, suppress logging, and other options\n* Simulate POST/PUT/DELETE calls to preview first, so that network configuration does not get changed\n\n## Setup\n\n1. Enable API access in your Meraki dashboard organization and obtain an API\n   key ([instructions](https://documentation.meraki.com/zGeneral_Administration/Other_Topics/The_Cisco_Meraki_Dashboard_API))\n\n2. Keep your API key safe and secure, as it is similar to a password for your dashboard. If publishing your Python code\n   to a wider audience, please research secure handling of API keys.\n\n3. Install the latest version of [Python 3](ttps://wiki.python.org/moin/BeginnersGuide/NonProgrammers)\n\n4. Use _pip_ (or an alternative such as _easy_install_) to install the library from the\n   Python [Package Index](https://pypi.org/project/meraki/):\n    * `pip install meraki`\n    * If you have both Python3 and Python2 installed, you may need to use `pip3` (so `pip3 install meraki`) along\n      with `python3` on your system\n    * If _meraki_ was previously installed, you can upgrade to the latest non-beta release\n      with `pip install --upgrade meraki`\n\n5. The library supports Meraki dashboard API v1. You can also specify the version of the library when installing with\n   _pip_:\n    * See the full [release history](https://pypi.org/project/meraki/#history) to pick the version you want, or\n      use `pip install meraki==` without including a version number to display the list of available versions\n    * Versions begin with _1_ (1.0.0b**z** for beta)\n    * Specify the version you want with the install command; for example: `pip install meraki==1.34.0`\n    * You can also see the version currently installed with `pip show meraki`\n    * End-of-life v0 versions of the Python library begin with _0_ (0.**x**.**y**) and are not supported nor\n      recommended.\n\n## Usage\n\n1. Export your API key as\n   an [environment variable](https://www.twilio.com/blog/2017/01/how-to-set-environment-variables.html), for example:\n\n    ```shell\n    export MERAKI_DASHBOARD_API_KEY=YOUR_KEY_HERE\n    ```\n\n2. Alternatively, define your API key as a variable in your source code; this method is not recommended due to its\n   inherent insecurity.\n\n3. Single line of code to import and use the library goes at the top of your script:\n\n    ```python\n    import meraki\n    ```\n\n4. Instantiate the client (API consumer class), optionally specifying any of the parameters available to set:\n\n    ```python\n    dashboard = meraki.DashboardAPI()\n    ```\n\n5. Make dashboard API calls in your source code, using the format _client.scope.operation_, where _client_ is the name\n   you defined in the previous step (**dashboard** above), _scope_ is the corresponding scope that represents the first\n   tag from the OpenAPI spec, and _operation_ is the operation of the API endpoint. For example, to make a call to get\n   the list of organizations accessible by the API key defined in step 1, use this function call:\n\n    ```python\n    my_orgs = dashboard.organizations.getOrganizations()\n    ```\n\n### Examples\n\nYou can find fully working example scripts in the **examples** folder.\n\n| Script                  | Purpose                                                                                                                                                                                               |\n|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| **org_wide_clients.py** | That code collects the clients of all networks, in all orgs to which the key has access. No changes are made, since only GET endpoints are called, and the data is written to local CSV output files. |\n\n## AsyncIO\n\n**asyncio** is a library to write concurrent code using the **async/await** syntax. Special thanks to Heimo\nStieg ([@coreGreenberet](https://github.com/coreGreenberet)) who has ported the API to asyncio.\n\n### Installation on macOS\n\nIf you use a Mac, then you may need to take\n[additional Python installation steps](https://bugs.python.org/issue43404) that aren't required on other platforms. This\nis [a limitation of macOS and not the library](https://github.com/meraki/dashboard-api-python/issues/226). This step is\nnot required on Windows.\n\n### Usage\n\nThe usage is similiar to the sequential version above. However it has has some differences.\n\n1. Export your API key as\n   an [environment variable](https://www.twilio.com/blog/2017/01/how-to-set-environment-variables.html), for example:\n\n    ```shell\n    export MERAKI_DASHBOARD_API_KEY=YOUR_KEY_HERE\n    ```\n\n2. Alternatively, define your API key as a variable in your source code; this method is not recommended due to its\n   inherent insecurity.\n\n3. Single line of code to import and use the library goes at the top of your script:\n\n    ```python\n    import meraki.aio\n    ```\n\n4. Instantiate the client (API consumer class), optionally specifying any of the parameters available to set:\n\n    ```python\n    async with meraki.aio.AsyncDashboardAPI() as aiomeraki:\n    ```\n   The **async with** statement is important here to make sure, that the client sessions will be closed after using the\n   api.\n\n5. Make dashboard API calls in your source code, using the format await _client.section.operation_, where _client_ is\n   the name you defined in the previous step (**aiomeraki** above), _section_ is the corresponding group (or tag from\n   the OpenAPI spec) from the [API docs](https://developer.cisco.com/meraki/api/#/rest), and _operation_ is the name (or\n   operation ID from OpenAPI) of the API endpoint. For example, to make a call to get the list of organizations\n   accessible by the API key defined in step 1, use this function call:\n\n    ```python\n    my_orgs = await aiomeraki.organizations.getOrganizations()\n    ```\n6. Run everything inside an event loop.\n\n```python\nimport asyncio\n\nif __name__ == \"__main__\":\n    # replace my_async_entry_point with the name of your entry point method\n    asyncio.run(my_async_entry_point())\n```\n\n### Examples\n\nYou can find fully working example scripts in the **examples** folder.\n| Script | Purpose |\n|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| **aio_org_wide_clients.py** | That code is a asyncio port from org_wide_clients.py and collects the clients of all\nnetworks, in all orgs to which the key has access. No changes are made, since only GET endpoints are called, and the\ndata is written to local CSV output files. |\n| **aio_ips2firewall.py**     | That code will collect the source IP of security events and creates L7 firewall rules to\nblock them. `usage: aio_ips2firewall.py [-h] -o ORGANIZATIONS [ORGANIZATIONS ...] [-f FILTER] [-s] [-d DAYS]` |\n\n## Note for application developers and ecosystem partners\n\nWe're so glad that you're leveraging our Python library. It's best practice to identify your application with every API\nrequest that you make. You can easily do this automatically just by following the format defined\nin [config.py](https://github.com/meraki/dashboard-api-python/blob/master/meraki/config.py) and passing the session\nkwarg:\n\n``` Python\nMERAKI_PYTHON_SDK_CALLER\n```\n\nUnless you are an ecosystem partner, this identifier is optional.\n\n1. If you are an ecosystem partner and you have questions about this requirement, please reach out to your ecosystem\n   rep.\n2. If you have any questions about the formatting, please ask your question by opening an issue in this repo.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Cisco Meraki Dashboard API library",
    "version": "1.46.0",
    "project_urls": {
        "Homepage": "https://github.com/meraki/dashboard-api-python"
    },
    "split_keywords": [
        "meraki",
        " dashboard",
        " cisco"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8eaec4ea06cff5ad8dddb1ba1e385a71590fca7b9855c7897455686ab7d87edd",
                "md5": "04465056a22654a23b8bfe19d60d5be7",
                "sha256": "5b2ec79458563e88e2b6556e6b4afb28b7c6f76efb0e3c4b7fce6a0d8784da1d"
            },
            "downloads": -1,
            "filename": "meraki-1.46.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "04465056a22654a23b8bfe19d60d5be7",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 280857,
            "upload_time": "2024-05-02T20:41:33",
            "upload_time_iso_8601": "2024-05-02T20:41:33.677711Z",
            "url": "https://files.pythonhosted.org/packages/8e/ae/c4ea06cff5ad8dddb1ba1e385a71590fca7b9855c7897455686ab7d87edd/meraki-1.46.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e8fa227101501f0379973f6d2383c5c9c048130e0399d32aa19082e5e5187a98",
                "md5": "e135e2a2653b7c5cf1ad92fd708983af",
                "sha256": "7f72bee7dfbd34edf718ed5205984a7ea1cf3bda79922bc378b35defcd1c66ef"
            },
            "downloads": -1,
            "filename": "meraki-1.46.0.tar.gz",
            "has_sig": false,
            "md5_digest": "e135e2a2653b7c5cf1ad92fd708983af",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 252168,
            "upload_time": "2024-05-02T20:41:36",
            "upload_time_iso_8601": "2024-05-02T20:41:36.211788Z",
            "url": "https://files.pythonhosted.org/packages/e8/fa/227101501f0379973f6d2383c5c9c048130e0399d32aa19082e5e5187a98/meraki-1.46.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-02 20:41:36",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "meraki",
    "github_project": "dashboard-api-python",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "meraki"
}
        
Elapsed time: 0.24058s