Updated own integrations for new HA version
This commit is contained in:
		
							parent
							
								
									6ee8c9c348
								
							
						
					
					
						commit
						f6379fe687
					
				|  | @ -510,14 +510,12 @@ media_player: | |||
|     host: server.fritz.box | ||||
|   - platform: squeezebox_telnet | ||||
|     host: musikserverWohnzimmerOben.fritz.box     | ||||
|   - platform: denonavr | ||||
|     host: avreceiver.fritz.box | ||||
| 
 | ||||
| 
 | ||||
| vacuum: | ||||
|   - platform: xiaomi_miio | ||||
|     host: vacuum.fritz.box | ||||
|     token: !secret vacuum_token | ||||
| # set up via frontend :( | ||||
| #vacuum: | ||||
| #  - platform: xiaomi_miio | ||||
| #    host: vacuum.fritz.box | ||||
| #    token: !secret vacuum_token | ||||
| 
 | ||||
| 
 | ||||
| sensor: | ||||
|  |  | |||
|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| { | ||||
|   "domain": "cover_half", | ||||
|   "name": "Cover Half", | ||||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| { | ||||
|   "domain": "dimmer", | ||||
|   "name": "DimmerIntegration", | ||||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| import voluptuous as vol | ||||
| import logging | ||||
| 
 | ||||
| from homeassistant.components.binary_sensor import PLATFORM_SCHEMA, BinarySensorDevice, \ | ||||
| from homeassistant.components.binary_sensor import PLATFORM_SCHEMA, BinarySensorEntity, \ | ||||
|     DEVICE_CLASS_MOTION, DEVICE_CLASS_OPENING, DEVICE_CLASS_BATTERY | ||||
| from homeassistant.const import CONF_NAME | ||||
| import homeassistant.helpers.config_validation as cv | ||||
|  | @ -35,7 +35,7 @@ async def async_setup_platform(hass, config, async_add_entities, discovery_info= | |||
|     async_add_entities([sensor]) | ||||
| 
 | ||||
| 
 | ||||
| class FhemBinarySensor(BinarySensorDevice): | ||||
| class FhemBinarySensor(BinarySensorEntity): | ||||
| 
 | ||||
|     def __init__(self, connection, name, ids, sensor_type): | ||||
|         self._on = None | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| import voluptuous as vol | ||||
| import logging | ||||
| 
 | ||||
| from homeassistant.components.cover import PLATFORM_SCHEMA, CoverDevice, SUPPORT_OPEN, SUPPORT_CLOSE, \ | ||||
| from homeassistant.components.cover import PLATFORM_SCHEMA, CoverEntity, SUPPORT_OPEN, SUPPORT_CLOSE, \ | ||||
|     SUPPORT_SET_POSITION, SUPPORT_STOP, ATTR_POSITION | ||||
| from homeassistant.const import CONF_NAME | ||||
| import homeassistant.helpers.config_validation as cv | ||||
|  | @ -27,7 +27,7 @@ async def async_setup_platform(hass, config, async_add_entities, discovery_info= | |||
|     async_add_entities([cover]) | ||||
| 
 | ||||
| 
 | ||||
| class FhemCover(CoverDevice): | ||||
| class FhemCover(CoverEntity): | ||||
| 
 | ||||
|     def __init__(self, connection, name, ids): | ||||
|         self._position = None | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| import voluptuous as vol | ||||
| import logging | ||||
| 
 | ||||
| from homeassistant.components.light import ATTR_BRIGHTNESS, PLATFORM_SCHEMA, SUPPORT_BRIGHTNESS, Light, ATTR_TRANSITION | ||||
| from homeassistant.components.light import ATTR_BRIGHTNESS, PLATFORM_SCHEMA, SUPPORT_BRIGHTNESS, LightEntity, ATTR_TRANSITION | ||||
| from homeassistant.const import CONF_NAME | ||||
| import homeassistant.helpers.config_validation as cv | ||||
| from . import DATA_FHEM, device_error_reporting, CONF_FHEM_IDS | ||||
|  | @ -29,7 +29,7 @@ async def async_setup_platform(hass, config, async_add_entities, discovery_info= | |||
|     async_add_entities([light]) | ||||
| 
 | ||||
| 
 | ||||
| class FhemLight(Light): | ||||
| class FhemLight(LightEntity): | ||||
| 
 | ||||
|     def __init__(self, connection, name, ids, dimmer=False): | ||||
|         self._brightness = None | ||||
|  |  | |||
|  | @ -5,5 +5,6 @@ | |||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [] | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| import voluptuous as vol | ||||
| import logging | ||||
| 
 | ||||
| from homeassistant.components.switch import SwitchDevice, PLATFORM_SCHEMA | ||||
| from homeassistant.components.switch import SwitchEntity, PLATFORM_SCHEMA | ||||
| from homeassistant.const import CONF_NAME | ||||
| import homeassistant.helpers.config_validation as cv | ||||
| from . import DATA_FHEM, device_error_reporting, CONF_FHEM_IDS | ||||
|  | @ -24,7 +24,7 @@ async def async_setup_platform(hass, config, async_add_entities, discovery_info= | |||
|     async_add_entities([switch]) | ||||
| 
 | ||||
| 
 | ||||
| class FhemSwitch(SwitchDevice): | ||||
| class FhemSwitch(SwitchEntity): | ||||
| 
 | ||||
|     def __init__(self, connection, name, ids): | ||||
|         self._on = None | ||||
|  |  | |||
|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| { | ||||
|   "domain": "httpsispmctl", | ||||
|   "name": "sispmctl integration", | ||||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -4,7 +4,7 @@ from collections import defaultdict | |||
| import homeassistant.helpers.config_validation as cv | ||||
| from homeassistant.helpers import aiohttp_client | ||||
| from homeassistant.const import CONF_HOST, CONF_PORT, CONF_NAME | ||||
| from homeassistant.components.switch import SwitchDevice, PLATFORM_SCHEMA | ||||
| from homeassistant.components.switch import SwitchEntity, PLATFORM_SCHEMA | ||||
| from aiohttp import ClientConnectionError | ||||
| 
 | ||||
| 
 | ||||
|  | @ -75,7 +75,7 @@ class SispmctlHost: | |||
|             await switch.set_state(on=None, reachable=False) | ||||
| 
 | ||||
| 
 | ||||
| class HttpSispmctlSwitch(SwitchDevice): | ||||
| class HttpSispmctlSwitch(SwitchEntity): | ||||
|     def __init__(self, basename, number): | ||||
|         self._basename = basename | ||||
|         self._number = number | ||||
|  |  | |||
|  | @ -34,7 +34,6 @@ async def async_setup(hass, config): | |||
|         connection = LircConnection(hass, config_element) | ||||
|         hass.data[DATA_LIRC_NETWORK].append(connection) | ||||
|         await connection.start() | ||||
|     _LOGGER.warning("About to return true in async_setup") | ||||
|     return True | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,5 +4,6 @@ | |||
|   "documentation": "", | ||||
|   "requirements": [], | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"] | ||||
|   "codeowners": ["@mabau"], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| { | ||||
|   "domain": "long_click", | ||||
|   "name": "Long click", | ||||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -0,0 +1,78 @@ | |||
| import asyncio | ||||
| import logging | ||||
| 
 | ||||
| import voluptuous as vol | ||||
| 
 | ||||
| from homeassistant.config_entries import ConfigEntry | ||||
| from homeassistant.const import CONF_USERNAME, CONF_PASSWORD | ||||
| from homeassistant.core import HomeAssistant | ||||
| from homeassistant.helpers import config_entry_oauth2_flow, config_validation as cv | ||||
| 
 | ||||
| from . import config_flow | ||||
| from .const import DOMAIN, OAUTH2_AUTHORIZE, OAUTH2_TOKEN | ||||
| 
 | ||||
| _LOGGER = logging.getLogger(__name__) | ||||
| 
 | ||||
| CONFIG_SCHEMA = vol.Schema( | ||||
|     { | ||||
|         DOMAIN: vol.Schema( | ||||
|             { | ||||
|                 vol.Required(CONF_USERNAME): cv.string, | ||||
|                 vol.Required(CONF_PASSWORD): cv.string, | ||||
|             } | ||||
|         ) | ||||
|     }, | ||||
|     extra=vol.ALLOW_EXTRA, | ||||
| ) | ||||
| 
 | ||||
| PLATFORMS = ["sensor"] | ||||
| 
 | ||||
| 
 | ||||
| async def async_setup(hass: HomeAssistant, config: dict): | ||||
|     """Set up the ondilo component.""" | ||||
|     hass.data[DOMAIN] = {} | ||||
|     print("Init1") | ||||
|     if DOMAIN not in config: | ||||
|         print("Init early out") | ||||
|         return True | ||||
| 
 | ||||
|     config_flow.OndiloFlowHandler.async_register_implementation( | ||||
|         hass, | ||||
|         config_entry_oauth2_flow.LocalOAuth2Implementation( | ||||
|             hass, | ||||
|             DOMAIN, | ||||
|             config[DOMAIN][CONF_USERNAME], | ||||
|             config[DOMAIN][CONF_PASSWORD], | ||||
|             OAUTH2_AUTHORIZE, | ||||
|             OAUTH2_TOKEN, | ||||
|         ), | ||||
|     ) | ||||
|     print("init finish") | ||||
|     return True | ||||
| 
 | ||||
| 
 | ||||
| async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry): | ||||
|     """Set up ondilo from a config entry.""" | ||||
|     implementation = await config_entry_oauth2_flow.async_get_config_entry_implementation( | ||||
|         hass, entry | ||||
|     ) | ||||
|     session = config_entry_oauth2_flow.OAuth2Session(hass, entry, implementation) | ||||
|     hass.data[DOMAIN] = {"session": session} | ||||
|     hass.async_create_task(hass.config_entries.async_forward_entry_setup(entry, "sensor")) | ||||
|     return True | ||||
| 
 | ||||
| 
 | ||||
| async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry): | ||||
|     """Unload a config entry.""" | ||||
|     unload_ok = all( | ||||
|         await asyncio.gather( | ||||
|             *[ | ||||
|                 hass.config_entries.async_forward_entry_unload(entry, component) | ||||
|                 for component in PLATFORMS | ||||
|             ] | ||||
|         ) | ||||
|     ) | ||||
|     if unload_ok: | ||||
|         hass.data[DOMAIN] = {} | ||||
| 
 | ||||
|     return unload_ok | ||||
|  | @ -0,0 +1,35 @@ | |||
| """Config flow for Ondilo.""" | ||||
| import logging | ||||
| 
 | ||||
| from homeassistant import config_entries | ||||
| from homeassistant.helpers import config_entry_oauth2_flow | ||||
| 
 | ||||
| from .const import DOMAIN | ||||
| 
 | ||||
| _LOGGER = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| class OndiloFlowHandler(config_entry_oauth2_flow.AbstractOAuth2FlowHandler, domain=DOMAIN): | ||||
|     """Config flow to handle Ondilo OAuth2 authentication.""" | ||||
| 
 | ||||
|     DOMAIN = DOMAIN | ||||
|     CONNECTION_CLASS = config_entries.CONN_CLASS_CLOUD_POLL | ||||
| 
 | ||||
|     @property | ||||
|     def logger(self) -> logging.Logger: | ||||
|         """Return logger.""" | ||||
|         return logging.getLogger(__name__) | ||||
| 
 | ||||
|     async def async_step_user(self, user_input=None): | ||||
|         """Handle a flow start.""" | ||||
|         print("async_step_user!!") | ||||
|         if self.hass.config_entries.async_entries(DOMAIN): | ||||
|             print("abort because already setup") | ||||
|             return self.async_abort(reason="already_setup") | ||||
|         print("works!") | ||||
|         return await super().async_step_user(user_input) | ||||
| 
 | ||||
|     async def async_step_homekit(self, homekit_info): | ||||
|         """Handle HomeKit discovery.""" | ||||
|         print("async_step_homekit!!") | ||||
|         return await self.async_step_user() | ||||
|  | @ -0,0 +1,4 @@ | |||
| DOMAIN = "ondilo" | ||||
| OAUTH2_AUTHORIZE = "https://interop.ondilo.com/oauth2/authorize" | ||||
| OAUTH2_TOKEN = "https://interop.ondilo.com/oauth2/token" | ||||
| URL_API_PREFIX = "https://interop.ondilo.com/api/customer/v1" | ||||
|  | @ -0,0 +1,10 @@ | |||
| { | ||||
|   "domain": "ondilo", | ||||
|   "name": "Ondilo Pool Monitor", | ||||
|   "documentation": "", | ||||
|   "requirements": [], | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "config_flow": true, | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -0,0 +1,52 @@ | |||
| 
 | ||||
| from .const import DOMAIN, URL_API_PREFIX | ||||
| from datetime import timedelta | ||||
| from homeassistant.helpers.entity import Entity | ||||
| from homeassistant.util import Throttle | ||||
| import logging | ||||
| 
 | ||||
| MIN_TIME_BETWEEN_UPDATES = timedelta(minutes=5) | ||||
| 
 | ||||
| _LOGGER = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| async def api_call(session, url, data={}): | ||||
|     return await session.async_request(method="GET", | ||||
|                                        url=f"{URL_API_PREFIX}/{url}", | ||||
|                                        json=data).json() | ||||
| 
 | ||||
| 
 | ||||
| class OndiloData: | ||||
|     def __init__(self, session): | ||||
|         self._session = session | ||||
| 
 | ||||
|     @Throttle(MIN_TIME_BETWEEN_UPDATES) | ||||
|     async def async_update(self): | ||||
|         pass | ||||
| 
 | ||||
| 
 | ||||
| class PHSensor(Entity): | ||||
|     def __init__(self, data): | ||||
|         self._data = data | ||||
| 
 | ||||
|     async def async_update(self): | ||||
|         self._data.async_update() | ||||
| 
 | ||||
| 
 | ||||
| class ORPSensor(Entity): | ||||
|     def __init__(self, data): | ||||
|         self._data = data | ||||
| 
 | ||||
|     async def async_update(self): | ||||
|         self._data.async_update() | ||||
| 
 | ||||
| 
 | ||||
| async def async_setup_entry(hass, entry, async_add_entities): | ||||
|     session = hass.data[DOMAIN]['session'] | ||||
|     res = await api_call(session, "pools") | ||||
|     print(res) | ||||
|     _LOGGER.warn(res) | ||||
|     # data = OndiloData(session) | ||||
|     # get pools | ||||
|     # sensors = [PHSensor(data), ORPSensor(data)] | ||||
|     # async_add_entities(sensors) | ||||
|  | @ -1,11 +1,11 @@ | |||
| import asyncio | ||||
| import logging | ||||
| from homeassistant.const import EVENT_HOMEASSISTANT_STOP | ||||
| from homeassistant.components.binary_sensor import BinarySensorDevice | ||||
| from homeassistant.components.binary_sensor import BinarySensorEntity | ||||
| import socket | ||||
| 
 | ||||
| 
 | ||||
| class IsConnectedSensor(BinarySensorDevice): | ||||
| class IsConnectedSensor(BinarySensorEntity): | ||||
| 
 | ||||
|     def __init__(self, name): | ||||
|         self._on = True | ||||
|  |  | |||
|  | @ -4,5 +4,6 @@ | |||
|   "documentation": "", | ||||
|   "requirements": [], | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"] | ||||
|   "codeowners": ["@mabau"], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  |  | |||
|  | @ -6,10 +6,10 @@ import sys | |||
| from typing import List, Tuple | ||||
| import voluptuous as vol | ||||
| from ..reconnecting_client import ReconnectingClient | ||||
| from .radio import find_local_radio_url_by_name | ||||
| from .radio import find_local_radio_url_by_name, fill_station_cache_async | ||||
| 
 | ||||
| from homeassistant.components.media_player import ( | ||||
|     MediaPlayerDevice, PLATFORM_SCHEMA) | ||||
|     MediaPlayerEntity, PLATFORM_SCHEMA) | ||||
| from homeassistant.components.media_player.const import ( | ||||
|     ATTR_MEDIA_ENQUEUE, DOMAIN, MEDIA_TYPE_MUSIC, | ||||
|     SUPPORT_CLEAR_PLAYLIST, SUPPORT_NEXT_TRACK, SUPPORT_PAUSE, | ||||
|  | @ -22,6 +22,7 @@ from homeassistant.const import ( | |||
|     STATE_IDLE, STATE_OFF, STATE_PAUSED, STATE_PLAYING) | ||||
| import homeassistant.helpers.config_validation as cv | ||||
| from homeassistant.util.dt import utcnow | ||||
| from homeassistant.helpers.aiohttp_client import async_get_clientsession | ||||
| 
 | ||||
| _LOGGER = logging.getLogger(__name__) | ||||
| 
 | ||||
|  | @ -67,6 +68,8 @@ async def async_setup_platform(hass, config, async_add_entities, | |||
|     """Set up the squeezebox platform.""" | ||||
|     import socket | ||||
|      | ||||
|     await fill_station_cache_async(async_get_clientsession(hass)) | ||||
| 
 | ||||
|     known_servers = hass.data.get(KNOWN_SERVERS) | ||||
|     if known_servers is None: | ||||
|         hass.data[KNOWN_SERVERS] = known_servers = set() | ||||
|  | @ -249,7 +252,7 @@ class LogitechMediaServer(ReconnectingClient): | |||
|             _LOGGER.warning("LMS Ignoring line " + line) | ||||
| 
 | ||||
| 
 | ||||
| class SqueezeBoxDevice(MediaPlayerDevice): | ||||
| class SqueezeBoxDevice(MediaPlayerEntity): | ||||
|     """Representation of a SqueezeBox device.""" | ||||
| 
 | ||||
|     def __init__(self, lms, playerid, name, **attributes): | ||||
|  |  | |||
|  | @ -1,7 +1,14 @@ | |||
| import xml.etree.ElementTree as ET | ||||
| from urllib.request import urlopen | ||||
| import aiohttp | ||||
| import asyncio | ||||
| 
 | ||||
| 
 | ||||
| ompl_radio_browse_url = 'http://opml.radiotime.com/Browse.ashx' | ||||
| # goto ompl.radiotime with parameter ?c=local and look for your city there then paste id here | ||||
| query_url = ompl_radio_browse_url + '?id=r100765' | ||||
| 
 | ||||
| STATION_CACHE = {} | ||||
| 
 | ||||
| 
 | ||||
| def radio_name_cleanup(radio_name): | ||||
|  | @ -17,15 +24,7 @@ def radio_name_cleanup(radio_name): | |||
|     return " ".join(res) | ||||
| 
 | ||||
| 
 | ||||
| def get_sender_information(queryURL): | ||||
|     """ | ||||
|         Example Query: GET http://opml.radiotime.com/Browse.ashx?partnerId=<partnerid>&serial=<serial> | ||||
|                        partnerid and serial does not seem to be necessary - so we do not use it here, | ||||
|     """ | ||||
|     xmlfile = urlopen(queryURL) | ||||
|     tree = ET.ElementTree(file=xmlfile) | ||||
|     rootnode = tree.getroot() | ||||
| 
 | ||||
| def parse_sender_information(rootnode): | ||||
|     result = dict() | ||||
|     for node in rootnode.iter('outline'): | ||||
|         if 'type' not in node.attrib or node.attrib['type'] != "audio": | ||||
|  | @ -39,16 +38,15 @@ def get_sender_information(queryURL): | |||
|     return result | ||||
| 
 | ||||
| 
 | ||||
| def get_related_radio_stations(stationID): | ||||
|     query_url = ompl_radio_browse_url + '?id=' + stationID | ||||
|     return get_sender_information(query_url) | ||||
| 
 | ||||
| 
 | ||||
| def get_local_radio_stations(): | ||||
|     # goto ompl.radiotime with parameter ?c=local and look for your city there then paste id here | ||||
|     query_url = ompl_radio_browse_url + '?id=r100765' | ||||
|     result = get_sender_information(query_url) | ||||
|     return result | ||||
|     """ | ||||
|         Example Query: GET http://opml.radiotime.com/Browse.ashx?partnerId=<partnerid>&serial=<serial> | ||||
|                        partnerid and serial does not seem to be necessary - so we do not use it here, | ||||
|     """     | ||||
|     xmlfile = urlopen(query_url) | ||||
|     tree = ET.ElementTree(file=xmlfile) | ||||
|     return parse_sender_information(tree.getroot() | ||||
| ) | ||||
| 
 | ||||
| 
 | ||||
| def find_local_radio_url_by_name(search_name): | ||||
|  | @ -58,19 +56,23 @@ def find_local_radio_url_by_name(search_name): | |||
|         return search_name | ||||
| 
 | ||||
|     # first try: find a station that starts with the search expression | ||||
|     for radio_id, radio in find_local_radio_url_by_name.stations.items(): | ||||
|     for radio_id, radio in STATION_CACHE.items(): | ||||
|         if radio['name'].lower().startswith(search_name): | ||||
|             return radio['url'] | ||||
| 
 | ||||
|     # second try: containment is enough | ||||
|     for radio_id, radio in find_local_radio_url_by_name.stations.items(): | ||||
|     for radio_id, radio in STATION_CACHE.items(): | ||||
|         if search_name in radio['name'].lower(): | ||||
|             return radio['url'] | ||||
| 
 | ||||
|     raise ValueError("Could not find radio station " + search_name) | ||||
| 
 | ||||
| 
 | ||||
| find_local_radio_url_by_name.stations = get_local_radio_stations() | ||||
| async def fill_station_cache_async(client_session): | ||||
|     print("-------- Fill station cache async") | ||||
|     global STATION_CACHE | ||||
|     async with client_session.get(query_url) as resp: | ||||
|         STATION_CACHE = parse_sender_information(ET.fromstring(await resp.text())) | ||||
|          | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|  |  | |||
|  | @ -1,12 +1,12 @@ | |||
| from . import DATA_SYSDWEB | ||||
| import logging | ||||
| from homeassistant.components.binary_sensor import BinarySensorDevice | ||||
| from homeassistant.components.binary_sensor import BinarySensorEntity | ||||
| from homeassistant.helpers import aiohttp_client | ||||
| 
 | ||||
| _LOGGER = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| class ServiceStateSensor(BinarySensorDevice): | ||||
| class ServiceStateSensor(BinarySensorEntity): | ||||
| 
 | ||||
|     def __init__(self, name, url, auth): | ||||
|         self._on = None | ||||
|  |  | |||
|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| { | ||||
|   "domain": "sysdweb", | ||||
|   "name": "sysdweg", | ||||
|   "documentation": "", | ||||
|   "dependencies": [], | ||||
|   "codeowners": ["@mabau"], | ||||
|   "requirements": [], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  | @ -8,5 +8,6 @@ | |||
|   "dependencies": [], | ||||
|   "codeowners": [ | ||||
|     "@rutkai" | ||||
|   ] | ||||
|   ], | ||||
|   "version": "0.1" | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue