Skip to main content

Get notified when your functions finish running

Project description

FuncNotify ⏰

Get notified when your code finishes/crashes with one line of code

Build Deploy DOC LCommit release License wheel

Documentation | GitHub | PyPI

Installation:

$ pip install FuncNotify

Quick Guide:

# Add more as projects grow!
from FuncNotify import time_func, time_text, time_slack


@time_func(NotifyMethod="Text", use_env=True, env_path".env", update_env=True, phone="8001234567")
def wait_func():
    """This function will use the text method and pull env variables from
    `.env`, it will update the already determined env variables too!"""
    do_something()


@time_Text()
def wait_func2():
    """All parameters are optional and each method has a personal decorator, 
    even the function call is optional see below"""
    do_something()

@time_Text
def wait_func3():
    """Auto pull from `.env` is enabled by default with Method specific 
    time decorators"""
    do_something()

@time_func(multi_target=[{...}, {...}], multi_env=["1.env", "2.env"])
def wait_func4():
    """Send to multiple sources either through specifiying multiple 
    dictionaries of kwargs or multiple .env paths, or both in pairs!"""
    do_something()

custom_message("HELLO WORLD", NotifyMethod="Text", multi_target=[{...}, {...}], multi_env=["1.env", "2.env"])
"""Custom messaging is here, pass the same arguments in as time_func and you 
can mass send messages in many methods"""

if __name__ == "__main__":
    """You don't even need to use the timer as a decorator, 
    use it as a normal function This is how we do testing 😊 """
    time_func(function=wait_func5)(*func5_args, **func5_kwargs)

All accomplish the same objective of notifying the user after wait_func() completes, one does so with the phone number saved as an env variable in .env so it never accidentally gets exposed.

CLI arguments:

$ FuncNotify [command here] --kwargs NotifyMethod=Text phone=8001234567

$ FuncNotify go run main.go --kwargs NotifyMethod=Email multi_env=1.env multi_env=2.env

$ FuncNotify sleep 5 --kwargs NotifyMethod=Text multi_target="[{'NotifyMethod': 'Print', 'verbose': True}, {'phone': '8001234567'}]"

Anything after --kwargs with an equal sign will automatically be parsed as a key-word argument for FuncNotify. The remainder without = will be executed. Wrap lists, dicts, and tuples in " so they get read properly. This allows you to time any script.

Demo:

$ pip install FuncNotify

$ FuncNotify sleep 5 --kwargs NotifyMethod=Print

To expand, create a .env file and a twilio account according to these instructions (it's free!). Instead of hard coding variables or exporting them to your env, just put them in the twilio alerts section of your .env, skip installing twilio as it's already installed. Then try:

$ FuncNotify sleep 5 --kwargs NotifyMethod=Text

Supported Notify Methods:

Platform
Console Print
Email Twilio
Email Yagmail
Text
Slack
Microsoft Teams

Create following .env in CWD

.env

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

FuncNotify-1.3.7.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

FuncNotify-1.3.7-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file FuncNotify-1.3.7.tar.gz.

File metadata

  • Download URL: FuncNotify-1.3.7.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0

File hashes

Hashes for FuncNotify-1.3.7.tar.gz
Algorithm Hash digest
SHA256 36375dd2e55c0f5ec7021ef52be0bbee50932761e9776ed88ffa986de65e3118
MD5 a42f66b4aeec763b1a1960fa2622bbed
BLAKE2b-256 1f455c3aba354e8003fc1df51ee48efebce9564b5b831fa9bcbb1b8160ad127d

See more details on using hashes here.

File details

Details for the file FuncNotify-1.3.7-py3-none-any.whl.

File metadata

  • Download URL: FuncNotify-1.3.7-py3-none-any.whl
  • Upload date:
  • Size: 29.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0

File hashes

Hashes for FuncNotify-1.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 fd80b6b2d8fc8b7bd73678dd31d915557134f74c901956fc8abc599663736d18
MD5 a75e90366e28755ce41b643f0626c73b
BLAKE2b-256 53048e4b3ba31ebedebd39db4de1c5cb9b6c42da7ad03614725fa017c96827be

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page