===================================================================== Big day! V4 is finally live. This INCLUDES some BREAKING CHANGES to ZSH TYPE scwrypts! Please refer to the readme for upgrade details (more specifically docs/upgrade/v3-to-v4.md) Upgrade is SUPER EASY, so please take the time to do so. --- New Features ---------------------------------------------------- - zsh type scwrypts have an upgraded runstring to improve context setup and simplicity to the scwrypt-writer - scwrypts now publishes the package (scwrypts) to PyPi; this provides a simple way to invoke scwrypts from python-based environments as well as the entire scwrypts python library suite pip install scwrypts - scwrypts now publishes the package (scwrypts) to npm; this provides a simple way to invoke scwrypts from nodesjs environments npm install scwrypts --- Bug Fixes ------------------------------------------------------- - scwrypts runner prompts which use the zshbuiltin "read" now appropriately read input from tty, pipe, files, and user input - virtualenv refresh now loads and prepares the scwrypts virtual environments correctly --- Changes --------------------------------------------------------- - created the (-v, --log-level) scwrypts arguments as improvements of and replacements to the --verbose and --no-log flags - (-n) is now an alias for (--log-level 0) - (--no-log) is the same as (-n) for compatibility, but will be removed in 4.2 - zsh/lib/utils/io print functions now *interact with log-level* various log levels will now only display the appropriate console prints for the specified log level - zsh/lib/utils/io:INFO has been renamed to DEBUG to align with log-level output; please use DEBUG for debug messages and REMINDER for important user messages - created zsh/lib/utils/io:FZF_USER_INPUT as a *drop-in replacement* for the confusing FZF_HEAD and FZF_TAIL commands. Update by literally changing any instances of FZF_HEAD or FZF_TAIL with FZF_USER_INPUT - FZF_HEAD and FZF_TAIL will be removed in 4.2 - zsh/lib/utils/io:READ (and other zshbuiltin/read-based prompts) now accept a --force-user-input flag in case important checks should require an admin's approval. This flag will ensure that piped input and the `scwrypts -y` flag are ignored for the single prompt. - zsh/lib/utils/color has been updated to use color names which match the ANSI color names - zsh/hello-world has been reduced to a minimal example; this is to emphasize ease-of-use with v4 - zsh/sanity-check is a scwrypts/run testing helper and detailed starting reference (helpful since hello-world is now minimal) - various refactor, updates, and improvements to the scwrypts runner - migrated all zsh scwrypts and plugins to use v4 runner syntax - zsh - plugins/kubectl - plugins/ci - refactored py/lib into py/lib/scwrypts (PyPi)
58 lines
1.7 KiB
Python
58 lines
1.7 KiB
Python
from json import dumps
|
|
from time import sleep
|
|
|
|
from .client import get_client
|
|
|
|
|
|
def send_sms(to, from_, body, max_char_count=300, stream=None):
|
|
'''
|
|
abstraction for twilio.client.messages.create which will break
|
|
messages into multi-part SMS rather than throwing an error or
|
|
requiring the use of MMS data
|
|
|
|
@param to messages.create parameter
|
|
@param from_ messages.create parameter
|
|
@param body messages.create parameter
|
|
@param max_char_count 1 ≤ N ≤ 1500 (default 300)
|
|
@param stream used to report success/failure (optional)
|
|
|
|
@return a list of twilio MessageInstance objects
|
|
'''
|
|
client = get_client()
|
|
messages = []
|
|
|
|
max_char_count = max(1, min(max_char_count, 1500))
|
|
|
|
total_sms_parts = 1 + len(body) // max_char_count
|
|
contains_multiple_parts = total_sms_parts > 1
|
|
|
|
for i in range(0, len(body), max_char_count):
|
|
msg_body = body[i:i+max_char_count]
|
|
current_part = 1 + i // max_char_count
|
|
|
|
if contains_multiple_parts:
|
|
msg_body = f'{current_part}/{total_sms_parts}\n{msg_body}'
|
|
|
|
message = client.messages.create(
|
|
to = to,
|
|
from_ = from_,
|
|
body = msg_body,
|
|
)
|
|
|
|
messages.append(message)
|
|
|
|
if stream is not None:
|
|
stream.writeline(
|
|
dumps({
|
|
'sid': message.sid,
|
|
'to': to,
|
|
'from': from_,
|
|
'body': msg_body,
|
|
})
|
|
)
|
|
|
|
if contains_multiple_parts:
|
|
sleep(2 if max_char_count <= 500 else 5)
|
|
|
|
return messages
|