Skip to main content

Bluesky comments support for MarkPub websites

Project description

Bluesky Comment support for MarkPub and MassiveWiki websites

Python package to
(1) post a MarkPub or MassiveWiki webpage link to Bluesky, and
(2) display any comments and likes made to that Bluesky post on the referenced website page.

Tested with Python 3.12.

This code is an excerpt of the code described in the blog post "Posting via the Bluesky API".

Gratitude to Emily Liu and Cory Zue


To install:

pip install --extra-index-url https://test.pypi.org/simple/ markpub_bskypost

Note: this package will be transferred from this test index to pypi.org .

For a list of options and arguments:

markpub_bskypost -h

Some configuration notes and suggestions

Bluesky and GitHub credentials are needed to post to Bluesky and to update pages in a GitHub repository. These can be provided as arguments on the command line, or as local shell environment variables.

Environment Variables:

Create a .env file in your project root with the following variables:

ATP_PDS_HOST=your_bluesky_host_here
ATP_AUTH_HANDLE=your_bluesky_handle_here
ATP_AUTH_PASSWORD=your_bluesky_password_here
GH_TOKEN=your_GitHub_token_here

If ATP_PDS_HOST is not specified “https://bsky.social” is the default.

N.B.: Never commit your .env file to version control. Add it to your .gitignore file.

Website host and Git repository:

The host on which the website is deployed, and the repository holding the Markdown files can be specified on the command line, or in a file in the working directory named bskypost.yaml . Here is an example file:

deploy_site: socialpraxis.netlify.app
repo_name: band/technosocial-praxis

Use example:

This program is run in a terminal application and from the .markpub directory of your repository.

Running markpub_bskypost yields

Enter the Markdown file name: 

One can enter a full-path, or a relative path, to a Markdown file in the repository, or an Obsidian URL (copied from the Obsidian file browser;
for example: `obsidian://open?vault=technosocial-praxis&file=notas%2F20250325-testnote)

markpub_bksypost generates the webpage URL to embed in the post and then prompts for the content of the Bluesky post (showing how many characters are available for the post text).

Enter bluesky post text (238 characters available): 

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

markpub_bskypost-0.9.3.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

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

markpub_bskypost-0.9.3-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file markpub_bskypost-0.9.3.tar.gz.

File metadata

  • Download URL: markpub_bskypost-0.9.3.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.13.2 Darwin/24.3.0

File hashes

Hashes for markpub_bskypost-0.9.3.tar.gz
Algorithm Hash digest
SHA256 e68bac39d880ad87c05bb37dca445c5f6e3e66737beaa02769669c9f7a654c37
MD5 a60a40e2ffe0f7671f2749c336e2f1a9
BLAKE2b-256 040110ebad49427c2b1188285fd818ccae4c57f0c5d1f9324108e02e39ff5499

See more details on using hashes here.

File details

Details for the file markpub_bskypost-0.9.3-py3-none-any.whl.

File metadata

  • Download URL: markpub_bskypost-0.9.3-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.13.2 Darwin/24.3.0

File hashes

Hashes for markpub_bskypost-0.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 63077b7659d21842885d51be7f460a3a1c8700d1dc88a2f83d606b29eeae160c
MD5 db7546f2d55cfd6124be4b5cf65c38bc
BLAKE2b-256 b84a645a573c44e425b9503dc61e12da15f30814821131bce2b1b01f2c1b1074

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