Skip to main content

AutoPub plugins maintained by Strawberry GraphQL

Project description

strawberry-autopub-plugins

AutoPub plugins maintained by Strawberry GraphQL.

Included plugins

  • InviteContributorsPlugin (strawberry_autopub_plugins.invite_contributors:InviteContributorsPlugin)
    • Invites pull request contributors to a GitHub organization after autopub publish.
    • Can also add invited users to a GitHub team.
  • TypefullyPlugin (strawberry_autopub_plugins.typefully:TypefullyPlugin)
    • Creates Typefully drafts or scheduled posts for release announcements.
    • Supports per-platform templates for x, linkedin, threads, bluesky, and mastodon.

Installation

pip install strawberry-autopub-plugins

Usage

Add one or more plugin paths to your AutoPub config:

[tool.autopub]
plugins = [
  "poetry",
  "github",
  "strawberry_autopub_plugins.invite_contributors:InviteContributorsPlugin",
  "strawberry_autopub_plugins.typefully:TypefullyPlugin",
]

Plugin config is keyed by each plugin's id:

  • invite_contributors
  • typefully

InviteContributorsPlugin

Plugin path:

strawberry_autopub_plugins.invite_contributors:InviteContributorsPlugin

Environment variables used when the plugin needs to call the GitHub API:

  • GITHUB_TOKEN
  • GITHUB_REPOSITORY

Optional environment variables:

  • GITHUB_EVENT_PATH

GITHUB_TOKEN must be able to invite users to the target organization.

Example config:

[tool.autopub.plugin_config.invite_contributors]
organization = "strawberry-graphql"
team-slug = "strawberry-contributors"
role = "direct_member"
skip-bots = true
include-co-authors = true
exclude-users = ["renovate[bot]"]
dry-run = false

Options:

  • organization: Target GitHub organization. If omitted, the plugin falls back to the repository organization.
  • team-slug: Optional team slug to add invited contributors to.
  • role: One of direct_member, admin, or billing_manager. Default: direct_member.
  • skip-bots: Skip logins ending in [bot]. Default: true.
  • include-co-authors: Include Co-authored-by: trailers found in commit messages. Default: true.
  • exclude-users: Additional usernames to skip. Defaults to dependabot-preview[bot], dependabot-preview, dependabot, and dependabot[bot].
  • dry-run: Print which users would be invited without sending invitations. Default: false.

TypefullyPlugin

Plugin path:

strawberry_autopub_plugins.typefully:TypefullyPlugin

Environment variables used when the plugin needs to create a Typefully draft:

  • TYPEFULLY_API_KEY

Optional environment variables:

  • TYPEFULLY_SOCIAL_SET_ID

You can provide the social set ID either through social-set-id in config or TYPEFULLY_SOCIAL_SET_ID. In dry-run mode, the plugin can render the request body without requiring either value.

Example config:

[tool.autopub.plugin_config.typefully]
social-set-id = "abc-123"
platforms = ["x", "linkedin", "bluesky"]
project-name = "Strawberry"
message-template = "{project_name} {version} has been released!\n\n{release_notes}"
publish-mode = "draft"
tags = ["release", "python"]
max-length = 280
truncation-suffix = "..."
dry-run = false

[tool.autopub.plugin_config.typefully.platform-templates]
x = "{project_name} {version} is out now.\n\n{release_notes}"
linkedin = "{project_name} {version} has been released.\n\n{release_notes}"

Options:

  • social-set-id: Typefully social set to post into. Required unless TYPEFULLY_SOCIAL_SET_ID is set.
  • platforms: Platforms to enable. Supported values: x, linkedin, threads, bluesky, mastodon. Default: ["x"].
  • message-template: Default template for all platforms. Default: {project_name} {version} has been released!\n\n{release_notes}.
  • platform-templates: Per-platform template overrides.
  • project-name: Value exposed to templates as {project_name}.
  • publish-mode: One of draft, now, next-free-slot, or scheduled. Default: draft.
  • publish-at: Required when publish-mode = "scheduled".
  • tags: Optional Typefully tags to attach to the draft.
  • max-length: Maximum post length before truncation. Default: 280.
  • truncation-suffix: Suffix appended after truncation. Default: ....
  • dry-run: Print the request body without calling the Typefully API. Default: false.

Template variables:

  • {project_name}
  • {version}
  • {release_type}
  • {release_notes}
  • {previous_version}

Release-specific override from RELEASE.md frontmatter:

---
release type: patch
social_message: |
  Strawberry {version} is out now.

  Highlights:
  {release_notes}
---

- Fixed X
- Added Y

When social_message is present in AutoPub frontmatter, the plugin uses it as the message template for all configured platforms and still expands the same template variables listed above.

Development

uv sync
uv run pytest

When changing dependencies, update the lockfile:

uv lock

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

strawberry_autopub_plugins-0.1.2.tar.gz (61.8 kB view details)

Uploaded Source

Built Distribution

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

strawberry_autopub_plugins-0.1.2-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file strawberry_autopub_plugins-0.1.2.tar.gz.

File metadata

  • Download URL: strawberry_autopub_plugins-0.1.2.tar.gz
  • Upload date:
  • Size: 61.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for strawberry_autopub_plugins-0.1.2.tar.gz
Algorithm Hash digest
SHA256 d3eb4e3cef057b52c20ebd18645bbab7e7830212d09bc4196ec7627b27a62ed7
MD5 c2e1995fa5b7de9bbbb4d3d7eeaa5827
BLAKE2b-256 4af88db024c3249b1042fb14c6be0f151cad78c03174e49f02a2f3e086ef5d50

See more details on using hashes here.

File details

Details for the file strawberry_autopub_plugins-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: strawberry_autopub_plugins-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for strawberry_autopub_plugins-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c12da0a4831815206c9ab58320a2fb12b4628756be2897121c666decdc385abf
MD5 3665b9fabe80f32443763fdd3afdc8be
BLAKE2b-256 e6070bde9c2c0f4bcbed2d82f29c93e1619c3e05966d4e7a091f2f5b91c415f9

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