Skip to main content

Allows you to post to your socials

Project description

Butterfly

A lightweight, extensible social media management tool.

Overview

Butterfly is a Python framework for managing posts across multiple social media platforms through a unified interface. It uses a plugin-based architecture to support different social media services.

Currently supported platforms:

  • Twitter
  • Mastodon
  • BlueSky

Installation

Requires Python 3.12+

# Clone the repository
git clone https://github.com/danwald/butterfly.git
cd butterfly

# Install
pipx install .

Usage

Command Line Interface

# List available plugins
sbutterfly --list-plugins

# Validate credentials
sbutterfly --method validate

# Post a message
sbutterfly --plugins twitter --method execute --message "Hello from Butterfly!"
sbutterfly --plugins mastodon --method execute --message "Hello from Butterfly!"
sbutterfly --plugins bluesky --method execute --message "Hello from Butterfly!"
# or
sbutterfly --method execute --message "Hello from Butterfly!"

Using as a Library

from plugins.twitter import Twitter

# Create a Twitter plugin instance
twitter = Twitter()

# Validate credentials
if twitter.validate():
    # Post a message
    twitter.execute("Hello from Butterfly!")

Configuration

Butterfly uses environment variables for authentication:

Environment Variables

TWITTER_CONSUMER_KEY
TWITTER_CONSUMER_SECRET
TWITTER_ACCESS_TOKEN
TWITTER_ACCESS_TOKEN_SECRET
MASTODON_BEARER_TOKEN
BSKY_USERNAME
BSKY_PASSWORD

Extending Butterfly

To create a new social media plugin:

  1. Create a new file in the plugins directory
  2. Implement a class that adheres to the Plugin protocol:
    • get_name(): Returns the plugin's name
    • validate(): Validates the plugin's credentials
    • execute(): Posts content to the social media platform

See plugins/twitter.py for an example implementation.

Development

# Install development dependencies
uv pip install -e ".[dev]"

# Run tests
make test

# Run linting
make lint
make type

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

sbutterfly-1.2.0.tar.gz (9.2 kB view details)

Uploaded Source

Built Distribution

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

sbutterfly-1.2.0-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file sbutterfly-1.2.0.tar.gz.

File metadata

  • Download URL: sbutterfly-1.2.0.tar.gz
  • Upload date:
  • Size: 9.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.8

File hashes

Hashes for sbutterfly-1.2.0.tar.gz
Algorithm Hash digest
SHA256 739d3a1a3bbe5f2db46a67666b8b40a0c15e2894a5b679d19fde1329f8cb7123
MD5 20af8fd2daaaf5f8557c7bad70b25644
BLAKE2b-256 a96118e52fdf65da4d5871114c066c68882ac614cfbab10b7325f72403caefd1

See more details on using hashes here.

File details

Details for the file sbutterfly-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: sbutterfly-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.8

File hashes

Hashes for sbutterfly-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 40eceea6de6c7412566e3b907f103f3e749073dd85d34085392bace8dfaab2d8
MD5 e4cfe4589fb6aafb026144170f46bd5e
BLAKE2b-256 fcf4b9c8c8f8251847b2b77079b5615618420e5c031e085fcc2e70a5e7f7ff01

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