# tahoma
[UP TO DATE] This is a very easy API for controlling Somfy Tahoma's devices written in Python3, thanks to the pyoverkiz API.
You just need a three-word input to control a device.
It was created with Tahoma but can also works with Somfy Connectivity Kit, Connexoon, Cozytouch
![Somfy](https://www.voletsdusud.com/wp-content/uploads/2018/04/logo-tahoma.jpg)
# Install the main package :
Install tahoma :
#########################################
On the next version of Python and Linux you will need to install in this way (using virtual env) :
```
sudo apt install pipx
pipx install tahoma
```
To update tahoma to the latest version :
`pipx upgrade tahoma`
If tahoma has been installed in ~/.local/bin you will need to add this file to the PATH : ~/.local/bin (if it's not already done) :
`sudo echo 'export PATH=$PATH:~/.local/bin' >> ~/.bashrc`
[How to create a PATH on Linux ?](https://linuxize.com/post/how-to-add-directory-to-path-in-linux/)
#########################################
Normal way to install on Linux :
```
python3 -m pip install -U tahoma
```
#########################################
For Windows users :
Open a terminal (Powershell) as administrator (Win+X and A) and type this command :
```
python3 -m pip install -U tahoma
```
Then search tahoma.exe and add the folder named 'scripts' (which contain tahoma.exe) to the PATH of Windows or simply copy tahoma.exe wherever you want and add the destination folder to the PATH of Windows.
[How to create a PATH on Windows ?](https://www.computerhope.com/issues/ch000549.htm)
# Configure :
It's very easy to configure, there are just two commands to execute once for all the first time :
All is explained in tahoma --help and tahoma --info
1. Specify your Somfy-connect login's info and choose the Somfy server :
Open a terminal and type :
- `tahoma --config` or `tahoma -c`
For Windows users : (Go to the folder of tahoma.exe and open a terminal if tahoma.exe is not in the PATH of Windows) :
- `.\tahoma -c`
or
- C:\foler\of\tahoma\tahoma.exe -c
2. Configure the API and get the list of your personal Somfy's devices :
Open a terminal and type :
- `tahoma --getlist` or `tahoma -g`
For Windows users : Go to the folder of tahoma.exe and open a terminal if tahoma.exe is not in the PATH of Windows) :
- `.\tahoma -g`
or
- C:\foler\of\tahoma\tahoma.exe -g
3. And now, you are ready to use tahoma :
# Usage :
`python3 tahoma.py [ACTION] [CATEGORY] [NAME]`
For instance : `tahoma open shutter kitchen` or `tahoma ouvrir volet cuisine`
- You can also close a shutter or a sunscreen to a specific level. For example, to close to 25%, you can use the commands : `tahoma 25 shutter kitchen` or `tahoma 25 sunscreen kitchen`. Please note that this feature only works with IO protocols and not with RTS.
- As name you can use a unic word like `bath` or the full name with `[""]` like `["bath 1st floor"]`
- You can also run many commands during the same process without restarting tahoma :
For instance : `tahoma arm alarm garden open shutter ["room 6"] confort heater dining off plug office 25 sunscreen kitchen launch scene morning`
- There is also a wait functionality with `wait for <SECOND(S)>` or `sleep for <SECOND(S)>` or `attendre pendant <SECOND(S)>` :
For instance : `tahoma open shutter kitchen wait for 20 close shutter kitchen`
- You can also wait for a specific time with `wait for <HOUR:MINUTE>` (24-hour format)
For instance : `tahoma wait for 13:32 open shutten kitchen`
- Since it is impossible to stop an RTS device, there is the possibility to cancel the immediate preceding command (without affecting a 'wait for <SECONDS>' command). To do this you can use the command 'cancel last action' or 'annuler precedente commande' just after a command that opens or closes an RTS device.
For example :
`tahoma open shutter kitchen wait for 2 cancel last action` : It will stop the kitchen shutter after 2 seconds
`tahoma open shutter kitchen open shutter room6 cancel last action` : It will only stop the room6 shutter
Examples :
Here are some example commands :
- tahoma open shutter kitchen
- tahoma 25 sunscreen Velux3 (You can close a shutter or a sunscreen to a specifique level. Here it will close to 25% )
- tahoma get sensor ["Luminance sensor garden"] (You can use the full name of the device with `["<NAME>"]` )
- tahoma get sensor door (You will receive all the informations about all the sensors with the name `door` in the house in one time)
- tahoma get sensor ["Front door"]
- tahoma on plug office
- tahoma on light ["kitchen light"]
- tahoma off spotalarm spot
- tahoma open shutter ["room 6"]
- tahoma toggle plug kitchen (For IO devices only)
- tahoma arm alarm garden
- tahoma confort heater dining
- tahoma get sensor ['heater dining room']
- tahoma launch scene morning
- tahoma wait for 13:32 open shutten kitchen
- tahoma arm alarm garden wait for 10 open shutter room6 sleep for 7 confort heater dining off plug office 25 sunscreen kitchen launch scene morning get sensor ['heater dining room']
- tahoma comfort heater dining wait for 3 get sensor ["Heater dining room"]
- tahoma open shutter kitchen open shutter room6 wait for 2 cancel last action (It will stop the room6 shutter after 2 seconds)
- tahoma open shutter kitchen --local (It will override default API set in `tahoma -c` with the `--local` argument for using the local API (For Tahoma hubs only))
- tahoma open shutter kitchen --username mail@address.com --password password --remote (You can provide the username and password with arguments to override the logins stored. This is useful if you have more than one Tahoma box)
- tahoma my shutter kitchen --token 2343d8c7f23dd5f328de --pin 1234-1234-1234 --local (It will use the local API (for Tahoma hubs only) with the pin and token arguments. This is useful if you have more than one Tahoma box)
- tahoma manual heater kitchen wait for 2 19 heater kitchen --server atlantic_cozytouch --username cozytouch_username --password cozytouch_password --remote (For some atlantic_cozytouch heaters, it is possible to use other ACTIONS than comfort, eco, off...with auto, manual, standby, prog, NUMBER. As a Cozytouch hub is not compatible with the local API, you can add the `--remote` argument. In this example tahoma will change the heater's mode to manual and will give the ability to modify the temperature to 19°C using the cloud API)
Special note:
If you want to use the local API for Tahoma hubs only, you will need to activate developer mode (www.somfy.com > My Account > Activate developer mode).
The local API allows controlling some devices without a cloud connection for Tahoma hubs only.
The local API is only compatible with some devices (shutters, sunscreens, heaters).
You can configure the local API with the `tahoma -c` command or override the default API set in `tahoma -c` with the `--local` or `--remote` argument
# But first you need to retrieve your PERSONALS commands :
## Get a list of all possibles [ACTIONS] for each [CATEGORIES] :
Open a terminal and type :
- `tahoma --list-actions` or `tahoma -la`
or
- `tahoma --list-actions-french` or `tahoma -laf`
## Get a list of availables [CATEGORIES] :
Open a terminal and type :
- `tahoma --list-categories` or `tahoma -lc`
or
- `tahoma --list-categories-french` or `tahoma -lcf`
## Get the [NAMES] you have given to your personal devices in the Somfy's App :
Open a terminal and type :
- `tahoma --list-names` or `tahoma -ln`
or
- `tahoma --list-names-french` or `tahoma -lnf`
Enjoy ! For more info `tahoma -h` or `tahoma -i`
# Create a PATH to tahoma :
If you have installed tahoma without the `sudo` command on Linux you will need to create a PATH for starting tahoma with the `tahoma` command.
Indead, to be able to run tahoma directly in the terminal, without going to the source package, you should add the tahoma's folder to the PATH :
On Linux, it can be permanently done by executing : `sudo gedit ~/.bashrc` and adding, at the end of the document, this line :
`export PATH=$PATH:/place/of/the/folder/tahoma`
If you want to temporarily test it before, you can just execute this command in the terminal :
`export PATH=$PATH:/place/of/the/folder/tahoma`
It will be restored on the next reboot.
By doing this, instead of taping `python3 '/place/of/the/folder/tahoma/tahoma.py open shutter kitchen'`,
you will be able to directly tape in the terminal : `tahoma open shutter kitchen`.
Then execute tahoma just like this : `tahoma arm alarm garden close shutter room6 confort heater dining off plug office 25 sunscreen kitchen launch scene morning` and that's all !
For :
Somfy Connectivity Kit
Somfy Connexoon IO
Somfy Connexoon RTS
Somfy TaHoma
Somfy TaHoma Beecon
Somfy TaHoma Switch
Thermor Cozytouch
And more...
Supported devices :
Alarm
Shutter
Plug
Heater
Sensors
Scenes
and more if you ask me on github :
[@pzim-devdata GitHub Pages](https://github.com/pzim-devdata/tahoma/issues)
<p align="center" width="100%">
<img width="33%" src="https://avatars.githubusercontent.com/u/52496172?v=4">
</p>
------------------------------------------------------------------
- [Licence](https://github.com/pzim-devdata/DATA-developer/raw/master/LICENSE)
MIT License Copyright (c) 2023 pzim-devdata
------------------------------------------------------------------
Created by @pzim-devdata - feel free to contact me!
Raw data
{
"_id": null,
"home_page": null,
"name": "tahoma",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "tahoma, somfy, api",
"author": null,
"author_email": "Pzim-devdata <contact@pzim.fr>",
"download_url": "https://files.pythonhosted.org/packages/bc/ce/3da3a16a4e75f6904b65a2a278fc02aa64699e3e62af7f747b82517b8deb/tahoma-3.0.3.tar.gz",
"platform": null,
"description": "# tahoma\n[UP TO DATE] This is a very easy API for controlling Somfy Tahoma's devices written in Python3, thanks to the pyoverkiz API.\nYou just need a three-word input to control a device.\nIt was created with Tahoma but can also works with Somfy Connectivity Kit, Connexoon, Cozytouch\n\n\n![Somfy](https://www.voletsdusud.com/wp-content/uploads/2018/04/logo-tahoma.jpg)\n\n\n\n\n# Install the main package :\n\n\nInstall tahoma :\n\n#########################################\n\nOn the next version of Python and Linux you will need to install in this way (using virtual env) :\n\n```\nsudo apt install pipx\npipx install tahoma\n```\nTo update tahoma to the latest version :\n`pipx upgrade tahoma`\n\nIf tahoma has been installed in ~/.local/bin you will need to add this file to the PATH : ~/.local/bin (if it's not already done) :\n\n`sudo echo 'export PATH=$PATH:~/.local/bin' >> ~/.bashrc`\n\n[How to create a PATH on Linux ?](https://linuxize.com/post/how-to-add-directory-to-path-in-linux/)\n\n#########################################\n\nNormal way to install on Linux :\n\n```\npython3 -m pip install -U tahoma\n```\n\n\n#########################################\n\nFor Windows users :\n\nOpen a terminal (Powershell) as administrator (Win+X and A) and type this command :\n\n```\npython3 -m pip install -U tahoma\n```\nThen search tahoma.exe and add the folder named 'scripts' (which contain tahoma.exe) to the PATH of Windows or simply copy tahoma.exe wherever you want and add the destination folder to the PATH of Windows.\n[How to create a PATH on Windows ?](https://www.computerhope.com/issues/ch000549.htm)\n\n\n\n# Configure :\n\n\nIt's very easy to configure, there are just two commands to execute once for all the first time :\n\nAll is explained in tahoma --help and tahoma --info\n\n\n1. Specify your Somfy-connect login's info and choose the Somfy server :\n\nOpen a terminal and type :\n- `tahoma --config` or `tahoma -c`\n\nFor Windows users : (Go to the folder of tahoma.exe and open a terminal if tahoma.exe is not in the PATH of Windows) :\n- `.\\tahoma -c`\nor\n- C:\\foler\\of\\tahoma\\tahoma.exe -c\n\n\n2. Configure the API and get the list of your personal Somfy's devices :\n\nOpen a terminal and type :\n- `tahoma --getlist` or `tahoma -g`\n\nFor Windows users : Go to the folder of tahoma.exe and open a terminal if tahoma.exe is not in the PATH of Windows) :\n- `.\\tahoma -g`\nor\n- C:\\foler\\of\\tahoma\\tahoma.exe -g\n\n3. And now, you are ready to use tahoma :\n\n\n# Usage : \n`python3 tahoma.py [ACTION] [CATEGORY] [NAME]`\n\n\nFor instance : `tahoma open shutter kitchen` or `tahoma ouvrir volet cuisine`\n\n- You can also close a shutter or a sunscreen to a specific level. For example, to close to 25%, you can use the commands : `tahoma 25 shutter kitchen` or `tahoma 25 sunscreen kitchen`. Please note that this feature only works with IO protocols and not with RTS.\n\n- As name you can use a unic word like `bath` or the full name with `[\"\"]` like `[\"bath 1st floor\"]`\n\n- You can also run many commands during the same process without restarting tahoma :\n\nFor instance : `tahoma arm alarm garden open shutter [\"room 6\"] confort heater dining off plug office 25 sunscreen kitchen launch scene morning`\n\n- There is also a wait functionality with `wait for <SECOND(S)>` or `sleep for <SECOND(S)>` or `attendre pendant <SECOND(S)>` :\n\nFor instance : `tahoma open shutter kitchen wait for 20 close shutter kitchen`\n\n- You can also wait for a specific time with `wait for <HOUR:MINUTE>` (24-hour format)\n\nFor instance : `tahoma wait for 13:32 open shutten kitchen`\n\n- Since it is impossible to stop an RTS device, there is the possibility to cancel the immediate preceding command (without affecting a 'wait for <SECONDS>' command). To do this you can use the command 'cancel last action' or 'annuler precedente commande' just after a command that opens or closes an RTS device.\n\nFor example :\n\n`tahoma open shutter kitchen wait for 2 cancel last action` : It will stop the kitchen shutter after 2 seconds\n\n`tahoma open shutter kitchen open shutter room6 cancel last action` : It will only stop the room6 shutter\n\nExamples :\nHere are some example commands :\n\n- tahoma open shutter kitchen\n- tahoma 25 sunscreen Velux3 (You can close a shutter or a sunscreen to a specifique level. Here it will close to 25% )\n- tahoma get sensor [\"Luminance sensor garden\"] (You can use the full name of the device with `[\"<NAME>\"]` )\n- tahoma get sensor door (You will receive all the informations about all the sensors with the name `door` in the house in one time)\n- tahoma get sensor [\"Front door\"] \n- tahoma on plug office\n- tahoma on light [\"kitchen light\"]\n- tahoma off spotalarm spot\n- tahoma open shutter [\"room 6\"]\n- tahoma toggle plug kitchen (For IO devices only)\n- tahoma arm alarm garden\n- tahoma confort heater dining\n- tahoma get sensor ['heater dining room']\n- tahoma launch scene morning\n- tahoma wait for 13:32 open shutten kitchen\n- tahoma arm alarm garden wait for 10 open shutter room6 sleep for 7 confort heater dining off plug office 25 sunscreen kitchen launch scene morning get sensor ['heater dining room']\n- tahoma comfort heater dining wait for 3 get sensor [\"Heater dining room\"]\n- tahoma open shutter kitchen open shutter room6 wait for 2 cancel last action (It will stop the room6 shutter after 2 seconds)\n- tahoma open shutter kitchen --local (It will override default API set in `tahoma -c` with the `--local` argument for using the local API (For Tahoma hubs only))\n- tahoma open shutter kitchen --username mail@address.com --password password --remote (You can provide the username and password with arguments to override the logins stored. This is useful if you have more than one Tahoma box)\n- tahoma my shutter kitchen --token 2343d8c7f23dd5f328de --pin 1234-1234-1234 --local (It will use the local API (for Tahoma hubs only) with the pin and token arguments. This is useful if you have more than one Tahoma box)\n- tahoma manual heater kitchen wait for 2 19 heater kitchen --server atlantic_cozytouch --username cozytouch_username --password cozytouch_password --remote (For some atlantic_cozytouch heaters, it is possible to use other ACTIONS than comfort, eco, off...with auto, manual, standby, prog, NUMBER. As a Cozytouch hub is not compatible with the local API, you can add the `--remote` argument. In this example tahoma will change the heater's mode to manual and will give the ability to modify the temperature to 19\u00b0C using the cloud API)\n\nSpecial note:\n\nIf you want to use the local API for Tahoma hubs only, you will need to activate developer mode (www.somfy.com > My Account > Activate developer mode).\nThe local API allows controlling some devices without a cloud connection for Tahoma hubs only.\nThe local API is only compatible with some devices (shutters, sunscreens, heaters).\nYou can configure the local API with the `tahoma -c` command or override the default API set in `tahoma -c` with the `--local` or `--remote` argument\n\n\n# But first you need to retrieve your PERSONALS commands :\n\n\n## Get a list of all possibles [ACTIONS] for each [CATEGORIES] : \n\nOpen a terminal and type :\n- `tahoma --list-actions` or `tahoma -la`\n\nor\n\n- `tahoma --list-actions-french` or `tahoma -laf`\n \n \n \n## Get a list of availables [CATEGORIES] :\n\nOpen a terminal and type :\n- `tahoma --list-categories` or `tahoma -lc`\n\nor \n\n- `tahoma --list-categories-french` or `tahoma -lcf`\n\n\n\n## Get the [NAMES] you have given to your personal devices in the Somfy's App :\n\nOpen a terminal and type :\n- `tahoma --list-names` or `tahoma -ln`\n\nor\n\n- `tahoma --list-names-french` or `tahoma -lnf`\n\n\n\nEnjoy ! For more info `tahoma -h` or `tahoma -i` \n\n\n\n\n# Create a PATH to tahoma :\n\n\nIf you have installed tahoma without the `sudo` command on Linux you will need to create a PATH for starting tahoma with the `tahoma` command.\n\nIndead, to be able to run tahoma directly in the terminal, without going to the source package, you should add the tahoma's folder to the PATH :\n\nOn Linux, it can be permanently done by executing : `sudo gedit ~/.bashrc` and adding, at the end of the document, this line :\n\n`export PATH=$PATH:/place/of/the/folder/tahoma`\n\n\n\nIf you want to temporarily test it before, you can just execute this command in the terminal : \n\n`export PATH=$PATH:/place/of/the/folder/tahoma` \n\nIt will be restored on the next reboot.\n\n\n\nBy doing this, instead of taping `python3 '/place/of/the/folder/tahoma/tahoma.py open shutter kitchen'`,\n\n you will be able to directly tape in the terminal : `tahoma open shutter kitchen`.\n\n\nThen execute tahoma just like this : `tahoma arm alarm garden close shutter room6 confort heater dining off plug office 25 sunscreen kitchen launch scene morning` and that's all !\n\n\n\n\n\n\nFor :\n\nSomfy Connectivity Kit\n\nSomfy Connexoon IO\n\nSomfy Connexoon RTS\n\nSomfy TaHoma\n\nSomfy TaHoma Beecon\n\nSomfy TaHoma Switch\n\nThermor Cozytouch\n\nAnd more...\n\n\nSupported devices :\n\nAlarm\nShutter\nPlug\nHeater\nSensors\nScenes\nand more if you ask me on github : \n\n[@pzim-devdata GitHub Pages](https://github.com/pzim-devdata/tahoma/issues)\n\n\n\n\n\n\n\n\n\n\n\n\n<p align=\"center\" width=\"100%\">\n <img width=\"33%\" src=\"https://avatars.githubusercontent.com/u/52496172?v=4\"> \n</p>\n\n------------------------------------------------------------------\n\n- [Licence](https://github.com/pzim-devdata/DATA-developer/raw/master/LICENSE)\nMIT License Copyright (c) 2023 pzim-devdata\n\n------------------------------------------------------------------\n\nCreated by @pzim-devdata - feel free to contact me!\n",
"bugtrack_url": null,
"license": null,
"summary": "This is a very easy API for controlling Somfy Tahoma's devices written in Python3, thanks to the pyoverkiz API. You just need a three-word input to control a device",
"version": "3.0.3",
"project_urls": {
"Bug Tracker": "https://github.com/pzim-devdata/tahoma/issues",
"Homepage": "https://github.com/pzim-devdata/tahoma"
},
"split_keywords": [
"tahoma",
" somfy",
" api"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "fd0c2968806b1c43deae253f7c7c46ec20100893bab0b282841e3c9daa6857fe",
"md5": "99b6c1d9c399576f72a7d42ef75fe13d",
"sha256": "190fb1047e060767cf189b341f08611da8cd874fd37488e1e1112e6f7a9cab08"
},
"downloads": -1,
"filename": "tahoma-3.0.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "99b6c1d9c399576f72a7d42ef75fe13d",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 68879,
"upload_time": "2024-12-07T16:37:33",
"upload_time_iso_8601": "2024-12-07T16:37:33.706841Z",
"url": "https://files.pythonhosted.org/packages/fd/0c/2968806b1c43deae253f7c7c46ec20100893bab0b282841e3c9daa6857fe/tahoma-3.0.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "bcce3da3a16a4e75f6904b65a2a278fc02aa64699e3e62af7f747b82517b8deb",
"md5": "181f6a3f920d69a76f17eef9c4396947",
"sha256": "eefb1313d11ce7087e553903da9f3a0fc8797416b9696f05ead9f00c7f8d5153"
},
"downloads": -1,
"filename": "tahoma-3.0.3.tar.gz",
"has_sig": false,
"md5_digest": "181f6a3f920d69a76f17eef9c4396947",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 72679,
"upload_time": "2024-12-07T16:37:35",
"upload_time_iso_8601": "2024-12-07T16:37:35.585481Z",
"url": "https://files.pythonhosted.org/packages/bc/ce/3da3a16a4e75f6904b65a2a278fc02aa64699e3e62af7f747b82517b8deb/tahoma-3.0.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-07 16:37:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "pzim-devdata",
"github_project": "tahoma",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [
{
"name": "aiohttp",
"specs": [
[
">=",
"3.8.4"
]
]
},
{
"name": "aiosignal",
"specs": [
[
">=",
"1.3.1"
]
]
},
{
"name": "async-timeout",
"specs": [
[
">=",
"4.0.2"
]
]
},
{
"name": "attrs",
"specs": [
[
">=",
"22.2.0"
]
]
},
{
"name": "backoff",
"specs": [
[
">=",
"2.2.1"
]
]
},
{
"name": "boto3",
"specs": [
[
">=",
"1.26.77"
]
]
},
{
"name": "botocore",
"specs": [
[
">=",
"1.29.77"
]
]
},
{
"name": "certifi",
"specs": [
[
">=",
"2022.12.7"
]
]
},
{
"name": "charset-normalizer",
"specs": [
[
">=",
"3.0.1"
]
]
},
{
"name": "ecdsa",
"specs": [
[
">=",
"0.18.0"
]
]
},
{
"name": "envs",
"specs": [
[
">=",
"1.4"
]
]
},
{
"name": "frozenlist",
"specs": [
[
">=",
"1.3.3"
]
]
},
{
"name": "idna",
"specs": [
[
">=",
"3.4"
]
]
},
{
"name": "jmespath",
"specs": [
[
">=",
"1.0.1"
]
]
},
{
"name": "multidict",
"specs": [
[
">=",
"6.0.4"
]
]
},
{
"name": "pyasn1",
"specs": [
[
">=",
"0.4.8"
]
]
},
{
"name": "pyhumps",
"specs": [
[
">=",
"3.8.0"
]
]
},
{
"name": "pyoverkiz",
"specs": [
[
">=",
"1.7.4"
]
]
},
{
"name": "python-dateutil",
"specs": [
[
">=",
"2.8.2"
]
]
},
{
"name": "python-jose",
"specs": [
[
">=",
"3.3.0"
]
]
},
{
"name": "requests",
"specs": [
[
">=",
"2.28.2"
]
]
},
{
"name": "rsa",
"specs": [
[
">=",
"4.9"
]
]
},
{
"name": "s3transfer",
"specs": [
[
">=",
"0.6.0"
]
]
},
{
"name": "six",
"specs": [
[
">=",
"1.16.0"
]
]
},
{
"name": "urllib3",
"specs": [
[
">=",
"1.26.14"
]
]
},
{
"name": "warrant-lite",
"specs": [
[
">=",
"1.0.4"
]
]
},
{
"name": "yarl",
"specs": [
[
">=",
"1.8.2"
]
]
}
],
"lcname": "tahoma"
}