duxcocpp


Nameduxcocpp JSON
Version 0.2.2 PyPI version JSON
download
home_pagehttps://github.com/duxincai/ocpp
SummaryPython package implementing the JSON version of the Open Charge Point Protocol (OCPP).
upload_time2024-05-08 07:09:18
maintainerNone
docs_urlNone
authorAndré Duarte
requires_python<4.0,>=3.8
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            .. image:: https://github.com/duxincai/ocpp/actions/workflows/pull-request.yml/badge.svg?style=svg
   :target: https://github.com/duxincai/ocpp/actions/workflows/pull-request.yml

.. image:: https://img.shields.io/pypi/pyversions/ocpp.svg
   :target: https://pypi.org/project/ocpp/

.. image:: https://img.shields.io/readthedocs/ocpp.svg
   :target: https://ocpp.readthedocs.io/en/latest/

OCPP
----

Python package implementing the JSON version of the Open Charge Point Protocol
(OCPP). Currently OCPP 1.6 (errata v4), OCPP 2.0 and OCPP 2.0.1 (Final Version)
are supported.

You can find the documentation on `rtd`_.

Installation
------------

You can either the project install from Pypi:

.. code-block:: bash

   $ pip install ocpp

Or clone the project and install it manually using:

.. code-block:: bash

   $ pip install .

Quick start
-----------

Below you can find examples on how to create a simple OCPP 1.6 or 2.0.1 Central
Charging Station/Charge Point.

.. note::

   To run these examples the dependency websockets_ is required! Install it by running:

   .. code-block:: bash

      $ pip install websockets

Central system
~~~~~~~~~~~~~~

The code snippet below creates a simple OCPP 2.0 central system which is able
to handle BootNotification calls. You can find a detailed explanation of the
code in the `Central System documentation`_.


.. code-block:: python

    import asyncio
    import logging
    import websockets
    from datetime import datetime

    from ocpp.routing import on
    from ocpp.v201 import ChargePoint as cp
    from ocpp.v201 import call_result
    from ocpp.v201.enums import RegistrationStatusType

    logging.basicConfig(level=logging.INFO)


    class ChargePoint(cp):
        @on('BootNotification')
        async def on_boot_notification(self, charging_station, reason, **kwargs):
            return call_result.BootNotificationPayload(
                current_time=datetime.utcnow().isoformat(),
                interval=10,
                status=RegistrationStatusType.accepted
            )


    async def on_connect(websocket, path):
        """ For every new charge point that connects, create a ChargePoint
        instance and start listening for messages.
        """
        try:
            requested_protocols = websocket.request_headers[
                'Sec-WebSocket-Protocol']
        except KeyError:
            logging.info("Client hasn't requested any Subprotocol. "
                     "Closing Connection")
            return await websocket.close()

        if websocket.subprotocol:
            logging.info("Protocols Matched: %s", websocket.subprotocol)
        else:
            # In the websockets lib if no subprotocols are supported by the
            # client and the server, it proceeds without a subprotocol,
            # so we have to manually close the connection.
            logging.warning('Protocols Mismatched | Expected Subprotocols: %s,'
                            ' but client supports  %s | Closing connection',
                            websocket.available_subprotocols,
                            requested_protocols)
            return await websocket.close()

        charge_point_id = path.strip('/')
        cp = ChargePoint(charge_point_id, websocket)

        await cp.start()


    async def main():
        server = await websockets.serve(
            on_connect,
            '0.0.0.0',
            9000,
            subprotocols=['ocpp2.0.1']
        )
        logging.info("WebSocket Server Started")
        await server.wait_closed()

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

Charge point
~~~~~~~~~~~~

.. code-block:: python

    import asyncio

    from ocpp.v201.enums import RegistrationStatusType
    import logging
    import websockets

    from ocpp.v201 import call
    from ocpp.v201 import ChargePoint as cp

    logging.basicConfig(level=logging.INFO)


    class ChargePoint(cp):

        async def send_boot_notification(self):
            request = call.BootNotificationPayload(
                charging_station={
                    'model': 'Wallbox XYZ',
                    'vendor_name': 'anewone'
                },
                reason="PowerUp"
            )
            response = await self.call(request)

            if response.status == RegistrationStatusType.accepted:
                print("Connected to central system.")


    async def main():
        async with websockets.connect(
                'ws://localhost:9000/CP_1',
                subprotocols=['ocpp2.0.1']
        ) as ws:
            cp = ChargePoint('CP_1', ws)

            await asyncio.gather(cp.start(), cp.send_boot_notification())


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

Debugging
---------

Python's default log level is `logging.WARNING`. As result most of the logs
generated by this package are discarded. To see the log output of this package
lower the log level to `logging.DEBUG`.

.. code-block:: python

  import logging
  logging.basicConfig(level=logging.DEBUG)

However, this approach defines the log level for the complete logging system.
In other words: the log level of all dependencies is set to `logging.DEBUG`.

To lower the logs for this package only use the following code:

.. code-block:: python

  import logging
  logging.getLogger('ocpp').setLevel(level=logging.DEBUG)
  logging.getLogger('ocpp').addHandler(logging.StreamHandler())

License
-------

Except from the documents in `docs/v16` and `docs/v201` everything is licensed under MIT_.
© `The Mobility House`_

The documents in `docs/v16` and `docs/v201` are licensed under Creative Commons
Attribution-NoDerivatives 4.0 International Public License.

.. _Central System documentation: https://ocpp.readthedocs.io/en/latest/central_system.html
.. _MIT: https://github.com/mobilityhouse/ocpp/blob/master/LICENSE
.. _rtd: https://ocpp.readthedocs.io/en/latest/index.html
.. _The Mobility House: https://www.mobilityhouse.com/int_en/
.. _websockets: https://pypi.org/project/websockets/

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/duxincai/ocpp",
    "name": "duxcocpp",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.8",
    "maintainer_email": null,
    "keywords": null,
    "author": "Andr\u00e9 Duarte",
    "author_email": "andre15x@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/39/fb/faf19d4542608dc6a35050802fb9ce22d2dcb480d47cb44d09c4af35299e/duxcocpp-0.2.2.tar.gz",
    "platform": null,
    "description": ".. image:: https://github.com/duxincai/ocpp/actions/workflows/pull-request.yml/badge.svg?style=svg\n   :target: https://github.com/duxincai/ocpp/actions/workflows/pull-request.yml\n\n.. image:: https://img.shields.io/pypi/pyversions/ocpp.svg\n   :target: https://pypi.org/project/ocpp/\n\n.. image:: https://img.shields.io/readthedocs/ocpp.svg\n   :target: https://ocpp.readthedocs.io/en/latest/\n\nOCPP\n----\n\nPython package implementing the JSON version of the Open Charge Point Protocol\n(OCPP). Currently OCPP 1.6 (errata v4), OCPP 2.0 and OCPP 2.0.1 (Final Version)\nare supported.\n\nYou can find the documentation on `rtd`_.\n\nInstallation\n------------\n\nYou can either the project install from Pypi:\n\n.. code-block:: bash\n\n   $ pip install ocpp\n\nOr clone the project and install it manually using:\n\n.. code-block:: bash\n\n   $ pip install .\n\nQuick start\n-----------\n\nBelow you can find examples on how to create a simple OCPP 1.6 or 2.0.1 Central\nCharging Station/Charge Point.\n\n.. note::\n\n   To run these examples the dependency websockets_ is required! Install it by running:\n\n   .. code-block:: bash\n\n      $ pip install websockets\n\nCentral system\n~~~~~~~~~~~~~~\n\nThe code snippet below creates a simple OCPP 2.0 central system which is able\nto handle BootNotification calls. You can find a detailed explanation of the\ncode in the `Central System documentation`_.\n\n\n.. code-block:: python\n\n    import asyncio\n    import logging\n    import websockets\n    from datetime import datetime\n\n    from ocpp.routing import on\n    from ocpp.v201 import ChargePoint as cp\n    from ocpp.v201 import call_result\n    from ocpp.v201.enums import RegistrationStatusType\n\n    logging.basicConfig(level=logging.INFO)\n\n\n    class ChargePoint(cp):\n        @on('BootNotification')\n        async def on_boot_notification(self, charging_station, reason, **kwargs):\n            return call_result.BootNotificationPayload(\n                current_time=datetime.utcnow().isoformat(),\n                interval=10,\n                status=RegistrationStatusType.accepted\n            )\n\n\n    async def on_connect(websocket, path):\n        \"\"\" For every new charge point that connects, create a ChargePoint\n        instance and start listening for messages.\n        \"\"\"\n        try:\n            requested_protocols = websocket.request_headers[\n                'Sec-WebSocket-Protocol']\n        except KeyError:\n            logging.info(\"Client hasn't requested any Subprotocol. \"\n                     \"Closing Connection\")\n            return await websocket.close()\n\n        if websocket.subprotocol:\n            logging.info(\"Protocols Matched: %s\", websocket.subprotocol)\n        else:\n            # In the websockets lib if no subprotocols are supported by the\n            # client and the server, it proceeds without a subprotocol,\n            # so we have to manually close the connection.\n            logging.warning('Protocols Mismatched | Expected Subprotocols: %s,'\n                            ' but client supports  %s | Closing connection',\n                            websocket.available_subprotocols,\n                            requested_protocols)\n            return await websocket.close()\n\n        charge_point_id = path.strip('/')\n        cp = ChargePoint(charge_point_id, websocket)\n\n        await cp.start()\n\n\n    async def main():\n        server = await websockets.serve(\n            on_connect,\n            '0.0.0.0',\n            9000,\n            subprotocols=['ocpp2.0.1']\n        )\n        logging.info(\"WebSocket Server Started\")\n        await server.wait_closed()\n\n    if __name__ == '__main__':\n        asyncio.run(main())\n\nCharge point\n~~~~~~~~~~~~\n\n.. code-block:: python\n\n    import asyncio\n\n    from ocpp.v201.enums import RegistrationStatusType\n    import logging\n    import websockets\n\n    from ocpp.v201 import call\n    from ocpp.v201 import ChargePoint as cp\n\n    logging.basicConfig(level=logging.INFO)\n\n\n    class ChargePoint(cp):\n\n        async def send_boot_notification(self):\n            request = call.BootNotificationPayload(\n                charging_station={\n                    'model': 'Wallbox XYZ',\n                    'vendor_name': 'anewone'\n                },\n                reason=\"PowerUp\"\n            )\n            response = await self.call(request)\n\n            if response.status == RegistrationStatusType.accepted:\n                print(\"Connected to central system.\")\n\n\n    async def main():\n        async with websockets.connect(\n                'ws://localhost:9000/CP_1',\n                subprotocols=['ocpp2.0.1']\n        ) as ws:\n            cp = ChargePoint('CP_1', ws)\n\n            await asyncio.gather(cp.start(), cp.send_boot_notification())\n\n\n    if __name__ == '__main__':\n        asyncio.run(main())\n\nDebugging\n---------\n\nPython's default log level is `logging.WARNING`. As result most of the logs\ngenerated by this package are discarded. To see the log output of this package\nlower the log level to `logging.DEBUG`.\n\n.. code-block:: python\n\n  import logging\n  logging.basicConfig(level=logging.DEBUG)\n\nHowever, this approach defines the log level for the complete logging system.\nIn other words: the log level of all dependencies is set to `logging.DEBUG`.\n\nTo lower the logs for this package only use the following code:\n\n.. code-block:: python\n\n  import logging\n  logging.getLogger('ocpp').setLevel(level=logging.DEBUG)\n  logging.getLogger('ocpp').addHandler(logging.StreamHandler())\n\nLicense\n-------\n\nExcept from the documents in `docs/v16` and `docs/v201` everything is licensed under MIT_.\n\u00a9 `The Mobility House`_\n\nThe documents in `docs/v16` and `docs/v201` are licensed under Creative Commons\nAttribution-NoDerivatives 4.0 International Public License.\n\n.. _Central System documentation: https://ocpp.readthedocs.io/en/latest/central_system.html\n.. _MIT: https://github.com/mobilityhouse/ocpp/blob/master/LICENSE\n.. _rtd: https://ocpp.readthedocs.io/en/latest/index.html\n.. _The Mobility House: https://www.mobilityhouse.com/int_en/\n.. _websockets: https://pypi.org/project/websockets/\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python package implementing the JSON version of the Open Charge Point Protocol (OCPP).",
    "version": "0.2.2",
    "project_urls": {
        "Documentation": "https://ocpp.readthedocs.io/en/latest/",
        "Homepage": "https://github.com/duxincai/ocpp",
        "Repository": "https://github.com/duxincai/ocpp"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "2ec8a0c1d55b22bf74ed1cbb2e00b1d154c49ad1d47efbffbde1b2cad4e75f36",
                "md5": "3a51f30cc348fb7ecaa2b304dc147970",
                "sha256": "113d3607016523ed39f9d556acfcaa407db8a86d3c7ea0f2d1c4216e4e8a24d6"
            },
            "downloads": -1,
            "filename": "duxcocpp-0.2.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "3a51f30cc348fb7ecaa2b304dc147970",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.8",
            "size": 230238,
            "upload_time": "2024-05-08T07:09:17",
            "upload_time_iso_8601": "2024-05-08T07:09:17.173926Z",
            "url": "https://files.pythonhosted.org/packages/2e/c8/a0c1d55b22bf74ed1cbb2e00b1d154c49ad1d47efbffbde1b2cad4e75f36/duxcocpp-0.2.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "39fbfaf19d4542608dc6a35050802fb9ce22d2dcb480d47cb44d09c4af35299e",
                "md5": "4d1ee5924044550ddb3c91e4a7f6cde1",
                "sha256": "7ec283da787584e9b0d571966165e92b84ad1a5b75d5a16a6e48989cf7b9336b"
            },
            "downloads": -1,
            "filename": "duxcocpp-0.2.2.tar.gz",
            "has_sig": false,
            "md5_digest": "4d1ee5924044550ddb3c91e4a7f6cde1",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.8",
            "size": 105443,
            "upload_time": "2024-05-08T07:09:18",
            "upload_time_iso_8601": "2024-05-08T07:09:18.645146Z",
            "url": "https://files.pythonhosted.org/packages/39/fb/faf19d4542608dc6a35050802fb9ce22d2dcb480d47cb44d09c4af35299e/duxcocpp-0.2.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-08 07:09:18",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "duxincai",
    "github_project": "ocpp",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "duxcocpp"
}
        
Elapsed time: 0.22182s