Skip to main content

A Python tool for sending Slack notifications on job completion.

Project description

SlackNotifPy

slacknotifpy is a Python CLI tool that sends notifications to a specified Slack channel on job completion. This can be especially useful for tracking automated job results, such as success or failure, directly in Slack.

Features

  • Runs a Python script or shell command and sends a Slack notification upon completion.
  • Customizable success and failure messages.
  • Simple configuration for Slack tokens and channel IDs.

Installation

Install slacknotifpy from PyPI:

pip install slacknotifpy

Configuration

To use slacknotifpy, you need to configure it with your Slack token and channel ID. These settings will be saved in a .slacknotif_config file.

  1. Run the following command to set up the configuration:
slacknotif init
  1. Follow the prompts to enter:
  • Slack Token
  • Slack Channel ID
  • Custom success and failure messages (optional)

You can find the Slack token and channel ID in your Slack app settings.

Custom Messages

To update the success and failure messages for a project, use:

slacknotif config setmessages

Resetting the Configuration

The initialized config file can be reset using the command:

slacknotif config setconfig

and following the prompts.

Usage

After configuring slacknotifpy, you can use it to run scripts and send notifications:

slacknotif run <script_path> [job_name]
  • script_path: The path to the Python script you want to run.
  • job_name (optional): A name for the job, used in the Slack message. Defaults to the script filename.

Example:

slacknotif run my_script.py "Data Processing Job"

A shell command can be run instead of a Python script by using the --cmd or -c flag:

slacknotif run -c "<SHELL COMMAND>" [job_name]

Example:

slacknotif run -c "ls -l /tmp" "My Shell Comand Job"

Running without a config file

You can run the tool without first running the init command by passing in the API token and channel ID (and optionally the custom messages) as arguments. The arguments will override values in the config file if it does exist.

slacknotif run <script_path> [job_name] [--token TOKEN] [--channel CHANNEL] [--success-msg SUCCESS_MSG] [--failure-msg FAILURE_MSG]

Example:

slacknotif run my_script.py "Data Processing Job" --token "MY-API-TOKEN" --channel "Random"

Example Slack Notification Messages

  • Success: "Data Processing Job completed successfully"
  • Failure: "Data Processing Job failed"

You can customize these messages using {job_name} as a placeholder in the config.

You can also tag users using thier real or display names using {@John Doe} or {@JohnDoe42}

Command Reference

  • Configure SlackNotifPy: slacknotif init
  • Re-Configure SlackNotifPy: slacknotif config setconfig
  • Set Custom Messages: slacknotif config setmessages
  • Run Script and Notify: slacknotif run <script_path> [job_name]
  • Run Shell Command and Notify: slacknotif run -c "<SHELL COMMAND>" [job_name]
  • Run Script and Notify and override config settings: slacknotif run <script_path> [job_name] [--token TOKEN] [--channel CHANNEL] [--success-msg SUCCESS_MSG] [--failure-msg FAILURE_MSG]

License

This project is licensed under the MIT License.

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

slacknotifpy-1.0.7.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

slacknotifpy-1.0.7-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file slacknotifpy-1.0.7.tar.gz.

File metadata

  • Download URL: slacknotifpy-1.0.7.tar.gz
  • Upload date:
  • Size: 6.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for slacknotifpy-1.0.7.tar.gz
Algorithm Hash digest
SHA256 e618b42e1e8e5be47c102261c4fba6b2d5c8073912b479bff4e5b2a3ad2c3a23
MD5 4b4e33a6e3f3ac6d0c37df0a9054ff89
BLAKE2b-256 48e6ba23f474c3c1dbd8cb9c3e5b29456b4bcde645003794983be5dbd77297e4

See more details on using hashes here.

File details

Details for the file slacknotifpy-1.0.7-py3-none-any.whl.

File metadata

  • Download URL: slacknotifpy-1.0.7-py3-none-any.whl
  • Upload date:
  • Size: 6.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for slacknotifpy-1.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 c77f1e9430282c4c91abbe364d4e43664eedef9c52520ed7dbfe3a2319380405
MD5 38c7143a21f58218947b3e72a00d56ca
BLAKE2b-256 14b74d55f5a644d8bb9d7602664ea7121e5dd3ccb3b0a6ae77112648b2ef1a82

See more details on using hashes here.

Supported by

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