vivintpy


Namevivintpy JSON
Version 2024.2.1 PyPI version JSON
download
home_pagehttps://github.com/natekspencer/vivintpy
SummaryPython library for interacting with a Vivint security and smart home system.
upload_time2024-11-01 21:52:18
maintainerNone
docs_urlNone
authorNathan Spencer
requires_python<4.0.0,>=3.9.0
licenseMIT
keywords vivint alarm system security smart home home automation asynchronous
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![pypi](https://img.shields.io/pypi/v/vivintpy?style=for-the-badge)](https://pypi.org/project/vivintpy)
[![downloads](https://img.shields.io/pypi/dm/vivintpy?style=for-the-badge)](https://pypi.org/project/vivintpy)
[![Buy Me A Coffee/Beer](https://img.shields.io/badge/Buy_Me_A_☕/🍺-F16061?style=for-the-badge&logo=ko-fi&logoColor=white&labelColor=grey)](https://ko-fi.com/natekspencer)

# vivintpy

Python library for interacting with a Vivint security and smart home system.

This was built to support the [`Vivint`](https://github.com/natekspencer/hacs-vivint) integration in [Home-Assistant](https://www.home-assistant.io/) but _should_ work outside of it too. Currently, it can be utilized via [HACS](https://hacs.xyz/) by adding the [hacs-vivint](https://github.com/natekspencer/hacs-vivint) custom repository.

## Credit

This was inspired by the great work done by [Mike Reibard](https://github.com/Riebart/vivint.py) to reverse engineer the Vivint Sky API and [Ovidiu Stateina](https://github.com/ovirs/pyvivint) for the repository from which this is forked and expanded on.

## Features

It currently has support for the following device types:

- alarm panels
- cameras
- door locks
- garage doors
- switches
  - binary
  - multilevel
- thermostats
- wireless sensors
  - carbon monoxide
  - door/window
  - flood
  - glass break
  - motion
  - smoke/fire
  - etc

In addition, it integrates with PubNub to receive real-time updates for devices. This subscription stops receiving notifications around 15-20 minutes unless a call is made to the Vivint Sky API periodically. This **might** be related to the cookie expiration since it expires 20 minutes after the last API call was received. If another client connects, however, the notifications start to stream again for all currently connected clients.

## Usage

See demo.py for a demonstration on how to use this library.

## TODO:

- write a better readme
- write some documentation
- add advanced support for:
  - thermostats
- add tests

---

## Support Me

I'm not employed by Vivint, and provide this python package as-is.

If you don't already own a Vivint system, please consider using [my referal code (kaf164)](https://www.vivint.com/get?refCode=kaf164&exid=165211vivint.com/get?refCode=kaf164&exid=165211) to get $50 off your bill (as well as a tip to me in appreciation)!

If you already own a Vivint system and still want to donate, consider buying me a coffee ☕ (or beer 🍺) instead by using the link below:

<a href='https://ko-fi.com/natekspencer' target='_blank'><img height='35' style='border:0px;height:46px;' src='https://az743702.vo.msecnd.net/cdn/kofi3.png?v=0' border='0' alt='Buy Me a Coffee at ko-fi.com' />

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/natekspencer/vivintpy",
    "name": "vivintpy",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0.0,>=3.9.0",
    "maintainer_email": null,
    "keywords": "Vivint, alarm system, security, smart home, home automation, asynchronous",
    "author": "Nathan Spencer",
    "author_email": "natekspencer@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/8e/03/186673e6295f27d36ddd7138460d716ad34b1b93316cbf2cdd699780b12f/vivintpy-2024.2.1.tar.gz",
    "platform": null,
    "description": "[![pypi](https://img.shields.io/pypi/v/vivintpy?style=for-the-badge)](https://pypi.org/project/vivintpy)\n[![downloads](https://img.shields.io/pypi/dm/vivintpy?style=for-the-badge)](https://pypi.org/project/vivintpy)\n[![Buy Me A Coffee/Beer](https://img.shields.io/badge/Buy_Me_A_\u2615/\ud83c\udf7a-F16061?style=for-the-badge&logo=ko-fi&logoColor=white&labelColor=grey)](https://ko-fi.com/natekspencer)\n\n# vivintpy\n\nPython library for interacting with a Vivint security and smart home system.\n\nThis was built to support the [`Vivint`](https://github.com/natekspencer/hacs-vivint) integration in [Home-Assistant](https://www.home-assistant.io/) but _should_ work outside of it too. Currently, it can be utilized via [HACS](https://hacs.xyz/) by adding the [hacs-vivint](https://github.com/natekspencer/hacs-vivint) custom repository.\n\n## Credit\n\nThis was inspired by the great work done by [Mike Reibard](https://github.com/Riebart/vivint.py) to reverse engineer the Vivint Sky API and [Ovidiu Stateina](https://github.com/ovirs/pyvivint) for the repository from which this is forked and expanded on.\n\n## Features\n\nIt currently has support for the following device types:\n\n- alarm panels\n- cameras\n- door locks\n- garage doors\n- switches\n  - binary\n  - multilevel\n- thermostats\n- wireless sensors\n  - carbon monoxide\n  - door/window\n  - flood\n  - glass break\n  - motion\n  - smoke/fire\n  - etc\n\nIn addition, it integrates with PubNub to receive real-time updates for devices. This subscription stops receiving notifications around 15-20 minutes unless a call is made to the Vivint Sky API periodically. This **might** be related to the cookie expiration since it expires 20 minutes after the last API call was received. If another client connects, however, the notifications start to stream again for all currently connected clients.\n\n## Usage\n\nSee demo.py for a demonstration on how to use this library.\n\n## TODO:\n\n- write a better readme\n- write some documentation\n- add advanced support for:\n  - thermostats\n- add tests\n\n---\n\n## Support Me\n\nI'm not employed by Vivint, and provide this python package as-is.\n\nIf you don't already own a Vivint system, please consider using [my referal code (kaf164)](https://www.vivint.com/get?refCode=kaf164&exid=165211vivint.com/get?refCode=kaf164&exid=165211) to get $50 off your bill (as well as a tip to me in appreciation)!\n\nIf you already own a Vivint system and still want to donate, consider buying me a coffee \u2615 (or beer \ud83c\udf7a) instead by using the link below:\n\n<a href='https://ko-fi.com/natekspencer' target='_blank'><img height='35' style='border:0px;height:46px;' src='https://az743702.vo.msecnd.net/cdn/kofi3.png?v=0' border='0' alt='Buy Me a Coffee at ko-fi.com' />\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python library for interacting with a Vivint security and smart home system.",
    "version": "2024.2.1",
    "project_urls": {
        "Homepage": "https://github.com/natekspencer/vivintpy",
        "Repository": "https://github.com/natekspencer/vivintpy"
    },
    "split_keywords": [
        "vivint",
        " alarm system",
        " security",
        " smart home",
        " home automation",
        " asynchronous"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "68b45053ce9d4983b4d8fb0bd45590ea840bac81596f74e27c685f5fe6b45356",
                "md5": "c6efddbcfad78e653bb561a9831ff379",
                "sha256": "829ebf407e67fd914847bc0b40ed9ed10e0afbb81e9c6bee6f778247b6b4dd41"
            },
            "downloads": -1,
            "filename": "vivintpy-2024.2.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "c6efddbcfad78e653bb561a9831ff379",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0.0,>=3.9.0",
            "size": 122323,
            "upload_time": "2024-11-01T21:52:17",
            "upload_time_iso_8601": "2024-11-01T21:52:17.090519Z",
            "url": "https://files.pythonhosted.org/packages/68/b4/5053ce9d4983b4d8fb0bd45590ea840bac81596f74e27c685f5fe6b45356/vivintpy-2024.2.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8e03186673e6295f27d36ddd7138460d716ad34b1b93316cbf2cdd699780b12f",
                "md5": "f3303833843fcf21ecb29158a57de3f2",
                "sha256": "fe534459e31317930a7f086b1151800bded722bd018128861f52ae3eb789639b"
            },
            "downloads": -1,
            "filename": "vivintpy-2024.2.1.tar.gz",
            "has_sig": false,
            "md5_digest": "f3303833843fcf21ecb29158a57de3f2",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0.0,>=3.9.0",
            "size": 112761,
            "upload_time": "2024-11-01T21:52:18",
            "upload_time_iso_8601": "2024-11-01T21:52:18.266160Z",
            "url": "https://files.pythonhosted.org/packages/8e/03/186673e6295f27d36ddd7138460d716ad34b1b93316cbf2cdd699780b12f/vivintpy-2024.2.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-01 21:52:18",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "natekspencer",
    "github_project": "vivintpy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "tox": true,
    "lcname": "vivintpy"
}
        
Elapsed time: 0.36223s