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 (X)

Installation

Requires Python 3.12+

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

# Install dependencies
pipx install .

Usage

Command Line Interface

# List available plugins
sbutterfly --list-plugins

# Validate Twitter credentials
sbutterfly --plugins twitter --method validate

# Post a message to Twitter
sbutterfly --plugins twitter --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:

Twitter

TWITTER_CONSUMER_KEY
TWITTER_CONSUMER_SECRET
TWITTER_ACCESS_TOKEN
TWITTER_ACCESS_TOKEN_SECRET

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-0.1.0.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

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

sbutterfly-0.1.0-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for sbutterfly-0.1.0.tar.gz
Algorithm Hash digest
SHA256 2f7582bd16ed95b37ad4ec0e4651a083d12a461178c8b5259263d8ca53139fc1
MD5 e2800941f59e18e174b0f5b224b29158
BLAKE2b-256 72c4769b4db6228d3a040e9d93f3ee457e20c623f27a8fe203be5a1fbf043a1d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for sbutterfly-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 55af950274501cb3cc7927a883e020cf0b898dec573aed46863cb1a8b0ef97c4
MD5 feb886520ea4f924235d1adfa21b61b9
BLAKE2b-256 2d6d52f2f3f434f19577645acb934be485c0e75d787efc00021a037aa29f4105

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