Skip to main content

No project description provided

Project description

Talkback Messenger

Python 2.7 and 3 compatible PyPI version License: GNU AGPLv3

Talkback Messenger is an application that finds the InfoSec content you're interested in from talkback.sh, and posts it to Slack in a digestible format.

The app can be scheduled to run looking for content from the past 1 to 24 hours, and has a Docker container available for scheduling execution. This means you can run it regularly to give you a constant feed of content.

[!Note] Talkback Messenger is currently in beta. If you use it and find any bugs, please open an issue

Contents

About Talkback

Talkback is a project developed by Elttam to help the community be more efficient and effective at keeping up with cyber-security content.

It aggregates InfoSec resources from a number of sources and enriches them with metadata, including AI summaries and categorisation.

You can find out more information about Talkback via blog posts and conference talks at Elttam's website

How it works

Talkback Messenger uses the Talkback API to collect content, and then enriches this with information that isn't available using the API by scraping the resource webpage.

Using the concept of subscriptions, Talkback Messenger is able to find resources that are relevant to you. These resources, if they meet the criteria you've set in your subscription, are then posted the Slack users/channels of your choice.

The messages contain a digestible summary of the content, leveraging Talkback's AI summarisation and categorisation, as well as links to the original resource.

Requirements

Slack App with Bot Token

You will need to create a Slack App and Bot Token to use with Talkback Messenger. You can find instructions on how to do this here.

Your app will require the following scopes:

"chat:write",
"chat:write.public",
"links:write",
"im:write",
"users:read",
"users:read.email"

I've included an app manifest file that you can use to create your app in the directory docs/slack/app_manifest.json. There is also an app icon you can use.

Once you've installed your Slack app, generate and safely store your bot token.

[!Note] To post to private Slack channels, you will need to first add the bot to the channel.

Talkback API Token

You will also need an API token for Talkback. You can find instructions on how to do this here.

Generate and store the JWT for use with Talkback Messenger.

[!Important] Currently, Talkback API tokens expire after 7 days. You will need to regenerate a new token once it expires.

Configuration File

Lastly, you will need to generate a talkback.yml configuration file. This file defines what content you want to collect from Talkback, and where you want to post it. In-depth instructions on how to create this file can be found here.

An example configuration has also been included in the directory docs/talkback_conf.

Installation

Talkback Messanger can be installed via pipx from PyPi:

pipx install talkback-messanger

There is also a Docker container available on DockerHub:

docker pull papermtn/talkback-messenger

Usage

Talkback Messenger can be run from the command line with the following options:

usage: talkback-messenger [-h] [-v] [--config CONFIG] --timeframe {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24} [--debug]

Talkback Messenger

options:
  -h, --help            show this help message and exit
  -v, --version         show programs version number and exit
  --config CONFIG       Path to the configuration file. Do not use if you are running in a container and have mounted the config file
  --timeframe {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24}
                        How many hours back to search (1-24)
  --debug, -d           Turn on debug level logging

Example:

talkback-messenger --config /path/to/talkback.yml --timeframe 1

Docker/Containerised

Talkback Messanger has been designed to also run in a container, meaning you can schedule it to run at regular intervals to keep you up to date with the latest content.

You will need to pass the configuration file to the container by mounting it as a volume. Talkback Messenger will look for the configuration file at /etc/talkback-messenger/talkback.yml.

To run the Docker container, you can use the following command:

docker run -v /path/to/talkback.yml:/etc/talkback-messenger/talkback.yml papermtn/talkback-messenger --timeframe 1

[!Important] The config file must be mounted in the following path: /etc/talkback-messenger/talkback.yml

The --config option is not required if you are running the container and have mounted the configuration file.

Future additions

Talkback Messenger is a work in progress, and currently in pre-release.

Possible future additions to the app include:

  • Add the ability to post to multiple channels
  • Add posting to individual users via DM from the bot
  • Add channels and users as destinations for specific subscriptions
  • Add integration with Microsoft Teams

If you have any suggestions or feature requests, please feel free to open an issue.

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

talkback_messenger-0.9.0.tar.gz (28.6 kB view details)

Uploaded Source

Built Distribution

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

talkback_messenger-0.9.0-py3-none-any.whl (31.9 kB view details)

Uploaded Python 3

File details

Details for the file talkback_messenger-0.9.0.tar.gz.

File metadata

  • Download URL: talkback_messenger-0.9.0.tar.gz
  • Upload date:
  • Size: 28.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.8 Linux/6.8.0-1020-azure

File hashes

Hashes for talkback_messenger-0.9.0.tar.gz
Algorithm Hash digest
SHA256 568004da8188f207db84f9195ede2374b4b9fd9d64b48282e21efd6a8087422b
MD5 c8d87b7d80c5ea97dea89a076de89838
BLAKE2b-256 db567ef19382aa02ba83885c36707d897ad69943b513be50e88ca31f08887a84

See more details on using hashes here.

File details

Details for the file talkback_messenger-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: talkback_messenger-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 31.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.8 Linux/6.8.0-1020-azure

File hashes

Hashes for talkback_messenger-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b2b6c345e96e9da9afd23b7fd36c6ffa0589581b2f0083d7760a549933629c13
MD5 d3d2718bfb562397d5467d8353e38e7f
BLAKE2b-256 7ba4e46ae618d2d73cb80acaeca167a7bb4fcba6434e74cdc2dfb8f78902d507

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