diff --git a/homeassistant/components/supla/__init__.py b/homeassistant/components/supla/__init__.py
index 96fe8f39aa92ef5a5b93764c204d6971e76fbce7..541b31eb0a3d8d98cf96fe56e6fa559a3a2cdac3 100644
--- a/homeassistant/components/supla/__init__.py
+++ b/homeassistant/components/supla/__init__.py
@@ -14,10 +14,7 @@ from homeassistant.helpers.aiohttp_client import async_get_clientsession
 import homeassistant.helpers.config_validation as cv
 from homeassistant.helpers.discovery import async_load_platform
 from homeassistant.helpers.typing import ConfigType
-from homeassistant.helpers.update_coordinator import (
-    CoordinatorEntity,
-    DataUpdateCoordinator,
-)
+from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
 
 _LOGGER = logging.getLogger(__name__)
 
@@ -155,58 +152,3 @@ async def discover_devices(hass, hass_config):
     # Load discovered devices
     for component_name, config in component_configs.items():
         await async_load_platform(hass, component_name, DOMAIN, config, hass_config)
-
-
-class SuplaChannel(CoordinatorEntity):
-    """Base class of a Supla Channel (an equivalent of HA's Entity)."""
-
-    def __init__(self, config, server, coordinator):
-        """Init from config, hookup[ server and coordinator."""
-        super().__init__(coordinator)
-        self.server_name = config["server_name"]
-        self.channel_id = config["channel_id"]
-        self.server = server
-
-    @property
-    def channel_data(self):
-        """Return channel data taken from coordinator."""
-        return self.coordinator.data.get(self.channel_id)
-
-    @property
-    def unique_id(self) -> str:
-        """Return a unique ID."""
-        return "supla-{}-{}".format(
-            self.channel_data["iodevice"]["gUIDString"].lower(),
-            self.channel_data["channelNumber"],
-        )
-
-    @property
-    def name(self) -> str | None:
-        """Return the name of the device."""
-        return self.channel_data["caption"]
-
-    @property
-    def available(self) -> bool:
-        """Return True if entity is available."""
-        if self.channel_data is None:
-            return False
-        if (state := self.channel_data.get("state")) is None:
-            return False
-        return state.get("connected")
-
-    async def async_action(self, action, **add_pars):
-        """Run server action.
-
-        Actions are currently hardcoded in components.
-        Supla's API enables autodiscovery
-        """
-        _LOGGER.debug(
-            "Executing action %s on channel %d, params: %s",
-            action,
-            self.channel_data["id"],
-            add_pars,
-        )
-        await self.server.execute_action(self.channel_data["id"], action, **add_pars)
-
-        # Update state
-        await self.coordinator.async_request_refresh()
diff --git a/homeassistant/components/supla/cover.py b/homeassistant/components/supla/cover.py
index df4e9c7e1097a95c046a39b9603280e0153fbadf..53e57fe18540eb260f70d1bd7ea8453f33e22000 100644
--- a/homeassistant/components/supla/cover.py
+++ b/homeassistant/components/supla/cover.py
@@ -10,7 +10,8 @@ from homeassistant.core import HomeAssistant
 from homeassistant.helpers.entity_platform import AddEntitiesCallback
 from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
 
-from . import DOMAIN, SUPLA_COORDINATORS, SUPLA_SERVERS, SuplaChannel
+from . import DOMAIN, SUPLA_COORDINATORS, SUPLA_SERVERS
+from .entity import SuplaEntity
 
 _LOGGER = logging.getLogger(__name__)
 
@@ -38,7 +39,7 @@ async def async_setup_platform(
 
         if device_name == SUPLA_SHUTTER:
             entities.append(
-                SuplaCover(
+                SuplaCoverEntity(
                     device,
                     hass.data[DOMAIN][SUPLA_SERVERS][server_name],
                     hass.data[DOMAIN][SUPLA_COORDINATORS][server_name],
@@ -47,7 +48,7 @@ async def async_setup_platform(
 
         elif device_name in {SUPLA_GATE, SUPLA_GARAGE_DOOR}:
             entities.append(
-                SuplaDoor(
+                SuplaDoorEntity(
                     device,
                     hass.data[DOMAIN][SUPLA_SERVERS][server_name],
                     hass.data[DOMAIN][SUPLA_COORDINATORS][server_name],
@@ -57,7 +58,7 @@ async def async_setup_platform(
     async_add_entities(entities)
 
 
-class SuplaCover(SuplaChannel, CoverEntity):
+class SuplaCoverEntity(SuplaEntity, CoverEntity):
     """Representation of a Supla Cover."""
 
     @property
@@ -91,7 +92,7 @@ class SuplaCover(SuplaChannel, CoverEntity):
         await self.async_action("STOP")
 
 
-class SuplaDoor(SuplaChannel, CoverEntity):
+class SuplaDoorEntity(SuplaEntity, CoverEntity):
     """Representation of a Supla door."""
 
     @property
diff --git a/homeassistant/components/supla/entity.py b/homeassistant/components/supla/entity.py
new file mode 100644
index 0000000000000000000000000000000000000000..ae0a627b5387a08cc8e84b361adc7837e7253341
--- /dev/null
+++ b/homeassistant/components/supla/entity.py
@@ -0,0 +1,63 @@
+"""Base class for Supla channels."""
+from __future__ import annotations
+
+import logging
+
+from homeassistant.helpers.update_coordinator import CoordinatorEntity
+
+_LOGGER = logging.getLogger(__name__)
+
+
+class SuplaEntity(CoordinatorEntity):
+    """Base class of a Supla Channel (an equivalent of HA's Entity)."""
+
+    def __init__(self, config, server, coordinator):
+        """Init from config, hookup[ server and coordinator."""
+        super().__init__(coordinator)
+        self.server_name = config["server_name"]
+        self.channel_id = config["channel_id"]
+        self.server = server
+
+    @property
+    def channel_data(self):
+        """Return channel data taken from coordinator."""
+        return self.coordinator.data.get(self.channel_id)
+
+    @property
+    def unique_id(self) -> str:
+        """Return a unique ID."""
+        return "supla-{}-{}".format(
+            self.channel_data["iodevice"]["gUIDString"].lower(),
+            self.channel_data["channelNumber"],
+        )
+
+    @property
+    def name(self) -> str | None:
+        """Return the name of the device."""
+        return self.channel_data["caption"]
+
+    @property
+    def available(self) -> bool:
+        """Return True if entity is available."""
+        if self.channel_data is None:
+            return False
+        if (state := self.channel_data.get("state")) is None:
+            return False
+        return state.get("connected")
+
+    async def async_action(self, action, **add_pars):
+        """Run server action.
+
+        Actions are currently hardcoded in components.
+        Supla's API enables autodiscovery
+        """
+        _LOGGER.debug(
+            "Executing action %s on channel %d, params: %s",
+            action,
+            self.channel_data["id"],
+            add_pars,
+        )
+        await self.server.execute_action(self.channel_data["id"], action, **add_pars)
+
+        # Update state
+        await self.coordinator.async_request_refresh()
diff --git a/homeassistant/components/supla/switch.py b/homeassistant/components/supla/switch.py
index 9c4c53c1e9f16bbf423e11154f63f2fe5007a1c8..b270f4300e16218957ac4b0ca6c0524d917ce47d 100644
--- a/homeassistant/components/supla/switch.py
+++ b/homeassistant/components/supla/switch.py
@@ -10,7 +10,8 @@ from homeassistant.core import HomeAssistant
 from homeassistant.helpers.entity_platform import AddEntitiesCallback
 from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
 
-from . import DOMAIN, SUPLA_COORDINATORS, SUPLA_SERVERS, SuplaChannel
+from . import DOMAIN, SUPLA_COORDINATORS, SUPLA_SERVERS
+from .entity import SuplaEntity
 
 _LOGGER = logging.getLogger(__name__)
 
@@ -32,7 +33,7 @@ async def async_setup_platform(
         server_name = device["server_name"]
 
         entities.append(
-            SuplaSwitch(
+            SuplaSwitchEntity(
                 device,
                 hass.data[DOMAIN][SUPLA_SERVERS][server_name],
                 hass.data[DOMAIN][SUPLA_COORDINATORS][server_name],
@@ -42,7 +43,7 @@ async def async_setup_platform(
     async_add_entities(entities)
 
 
-class SuplaSwitch(SuplaChannel, SwitchEntity):
+class SuplaSwitchEntity(SuplaEntity, SwitchEntity):
     """Representation of a Supla Switch."""
 
     async def async_turn_on(self, **kwargs: Any) -> None: