Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support to send Teams messages as HTML content #224

Merged
merged 3 commits into from
May 7, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 2 additions & 3 deletions custom_components/o365/classes/teamssensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
from homeassistant.components.sensor import SensorEntity
from homeassistant.const import ATTR_NAME, CONF_EMAIL
from homeassistant.exceptions import ServiceValidationError

from O365.teams import PreferredActivity, PreferredAvailability

from ..const import (
Expand Down Expand Up @@ -168,15 +167,15 @@ def extra_state_attributes(self):
attributes[ATTR_DATA] = self.coordinator.data[self.entity_key][ATTR_DATA]
return attributes

def send_chat_message(self, chat_id, message):
def send_chat_message(self, chat_id, message, content_type):
"""Send a message to the specified chat."""
if not self._validate_chat_permissions():
return False

chats = self.teams.get_my_chats()
for chat in chats:
if chat.object_id == chat_id:
message = chat.send_message(content=message)
message = chat.send_message(content=message, content_type=content_type)
self._raise_event(EVENT_SEND_CHAT_MESSAGE, chat_id)
return True
_LOGGER.warning("Chat %s not found for send message", chat_id)
Expand Down
5 changes: 5 additions & 0 deletions custom_components/o365/const.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
"""Constants."""

from enum import Enum


Expand All @@ -22,6 +23,7 @@ class EventResponse(Enum):
ATTR_CHAT_ID = "chat_id"
ATTR_CHAT_TYPE = "chat_type"
ATTR_COMPLETED = "completed"
ATTR_CONTENT_TYPE = "content_type"
ATTR_CREATED = "created"
ATTR_COLOR = "color"
ATTR_CONTENT = "content"
Expand Down Expand Up @@ -136,6 +138,9 @@ class EventResponse(Enum):
CONST_GROUP = "group:"
CONST_PRIMARY = "$o365-primary$"
CONST_UTC_TIMEZONE = "UTC"

CONTENT_TYPES = ["text", "html"]

DATETIME_FORMAT = "%Y-%m-%dT%H:%M:%S%z"
DEFAULT_OFFSET = "!!"
DOMAIN = "o365"
Expand Down
13 changes: 3 additions & 10 deletions custom_components/o365/schema.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
ATTR_TITLE,
)
from homeassistant.const import CONF_EMAIL, CONF_ENABLED, CONF_NAME

from O365.calendar import ( # pylint: disable=no-name-in-module
AttendeeType,
EventSensitivity,
Expand All @@ -30,6 +29,7 @@
ATTR_CATEGORIES,
ATTR_CHAT_ID,
ATTR_COMPLETED,
ATTR_CONTENT_TYPE,
ATTR_DESCRIPTION,
ATTR_DUE,
ATTR_EMAIL,
Expand Down Expand Up @@ -99,6 +99,7 @@
CONF_TRACK_NEW_CALENDAR,
CONF_URL,
CONF_YAML_TASK_LIST_ID,
CONTENT_TYPES,
EventResponse,
)

Expand Down Expand Up @@ -337,13 +338,5 @@
CHAT_SERVICE_SEND_MESSAGE_SCHEMA = {
vol.Required(ATTR_CHAT_ID): cv.string,
vol.Required(ATTR_MESSAGE): cv.string,
}

CHAT_SERVICE_SEND_MESSAGE_SCHEMA = {
vol.Required(ATTR_CHAT_ID): cv.string,
vol.Required(ATTR_MESSAGE): cv.string,
}
CHAT_SERVICE_SEND_MESSAGE_SCHEMA = {
vol.Required(ATTR_CHAT_ID): cv.string,
vol.Required(ATTR_MESSAGE): cv.string,
vol.Optional(ATTR_CONTENT_TYPE, default="text"): vol.In(CONTENT_TYPES),
}
13 changes: 13 additions & 0 deletions custom_components/o365/services.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -465,6 +465,19 @@ send_chat_message:
required: true
selector:
text:
content_type:
name: Content Type
description: The type of content to send, html if you are sending a HTML message or text for plain text
example: text
required: false
selector:
select:
mode: dropdown
options:
- label: HTML
Comment on lines +468 to +477
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

suggestion (code_refinement): Consider marking 'content_type' as required if it's critical for message formatting.

If the content type is essential for the message to be formatted correctly, it might be better to enforce its specification by making it required.

value: html
- label: Text
value: text

update_user_status:
name: Update user Teams status
Expand Down
1 change: 1 addition & 0 deletions docs/services.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,7 @@ target:
data:
chat_id: xxxxxxxxxxxxxxxxxxxxxxxxx
message: Hello world
content_type: text
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

suggestion (code_clarification): Update documentation to explain the optional nature of 'content_type' and its defaults.

Expanding the documentation to clarify when and how to use the 'content_type' field can enhance user understanding and correct usage of the API.

Suggested change
content_type: text
content_type: text
# The `content_type` field specifies the type of content being sent.
# Use this field to define the format of the message content.
# For example, 'text' indicates that the message content is plain text.

```

## Status Services
Expand Down