mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 03:07:37 +00:00
Implement Twilio SMS notify MediaUrl support (#24971)
* Implement Twilio SMS notify MediaUrl support Adds support for setting the `media_url` parameter of the twilio API client with an optional attribute under the notify `data` attribute. Per the twilio docs (https://www.twilio.com/docs/sms/send-messages#include-medi$ this feature is only available in the US and Canada, for GIF, PNG, or JPEG content. * lint: fix 80 char ruler * use kwargs to set the media_url after testing locally, seems like the previous way of using object() was not working. this seems to be working * re-use the ATTR_MEDIAURL attribute
This commit is contained in:
parent
84cf76ba36
commit
32685f16bf
@ -7,11 +7,13 @@ from homeassistant.components.twilio import DATA_TWILIO
|
|||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
|
|
||||||
from homeassistant.components.notify import (ATTR_TARGET, PLATFORM_SCHEMA,
|
from homeassistant.components.notify import (ATTR_TARGET, PLATFORM_SCHEMA,
|
||||||
BaseNotificationService)
|
BaseNotificationService,
|
||||||
|
ATTR_DATA)
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
CONF_FROM_NUMBER = "from_number"
|
CONF_FROM_NUMBER = "from_number"
|
||||||
|
ATTR_MEDIAURL = "media_url"
|
||||||
|
|
||||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
||||||
vol.Required(CONF_FROM_NUMBER):
|
vol.Required(CONF_FROM_NUMBER):
|
||||||
@ -39,6 +41,14 @@ class TwilioSMSNotificationService(BaseNotificationService):
|
|||||||
def send_message(self, message="", **kwargs):
|
def send_message(self, message="", **kwargs):
|
||||||
"""Send SMS to specified target user cell."""
|
"""Send SMS to specified target user cell."""
|
||||||
targets = kwargs.get(ATTR_TARGET)
|
targets = kwargs.get(ATTR_TARGET)
|
||||||
|
data = kwargs.get(ATTR_DATA) or {}
|
||||||
|
twilio_args = {
|
||||||
|
'body': message,
|
||||||
|
'from_': self.from_number
|
||||||
|
}
|
||||||
|
|
||||||
|
if ATTR_MEDIAURL in data:
|
||||||
|
twilio_args[ATTR_MEDIAURL] = data[ATTR_MEDIAURL]
|
||||||
|
|
||||||
if not targets:
|
if not targets:
|
||||||
_LOGGER.info("At least 1 target is required")
|
_LOGGER.info("At least 1 target is required")
|
||||||
@ -46,4 +56,4 @@ class TwilioSMSNotificationService(BaseNotificationService):
|
|||||||
|
|
||||||
for target in targets:
|
for target in targets:
|
||||||
self.client.messages.create(
|
self.client.messages.create(
|
||||||
to=target, body=message, from_=self.from_number)
|
to=target, **twilio_args)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user