Skip to main content

Local mock server for social media platform APIs - auth, publishing, the lot

Project description

posthole

Project Status: WIP – Initial development is in progress, but there has not yet been a stable, usable release suitable for the public. CI

[!WARNING] Pre-release / alpha. APIs and UI may break without notice. Not yet recommended for any production use.

Local mock server for social media platform APIs - auth, publishing, the lot.

posthole is a developer tool that stands in for real social media platform APIs so you can build and test integrations end-to-end on your laptop. Run it next to your app, point your code at 127.0.0.1:5176 instead of the real provider, and an inbox-style UI shows every post you've published alongside the complete HTTP transcript of each call. Instagram is the first platform supported; TikTok, Facebook, and others are on the roadmap.

It mocks the parts of these APIs you actually need while developing:

  • OAuth flows — authorize dialogs, token exchange, and token refresh.
  • Content publishing — images, videos, reels, stories, and carousels (including mixed-media), modeled on the real multi-step container → poll → publish lifecycle.
  • Accounts and permissions — switch between seeded test accounts and simulate revoked permissions.
  • Per-endpoint behavior toggles — flip any endpoint into a failure mode at runtime: rate-limited, validation error, media URL unreachable, reel duration too long, expired token, async-finished-with-error, slow response.
  • Scenarios — named bundles of behaviors (Validation, Quota, Auth, Async, Latency) so a single switch flips a whole class of failures on at once and you can watch how your code copes.

On the roadmap: replay (re-drive a captured request chain under a different scenario without re-running your app), inject (seed posts manually to reproduce specific UI states), more platforms (TikTok, Facebook, then YouTube and Threads), and richer device-preview frames.

Quick start

Docker (recommended):

docker run --rm -p 5176:5176 ghcr.io/socialpyre/posthole:latest
# → http://127.0.0.1:5176

As a uv tool (once published to PyPI):

uvx posthole
# → http://127.0.0.1:5176

Getting started

Prerequisites

  • Python 3.12+
  • uv ≥ 0.11 — curl -LsSf https://astral.sh/uv/install.sh | sh
  • Node 22 + pnpm 11nvm use (reads .nvmrc) then corepack enable
  • Docker (optional, only if you want to run the containerized image or test it locally)

Clone, install, run

git clone https://github.com/socialpyre/posthole
cd posthole
make install            # uv sync + pnpm install
make dev                # server + asset watchers + browser auto-reload

Then open http://127.0.0.1:5176.

Configurable knobs live in .env.schema; copy to .env.local to override locally. See CONTRIBUTING.md for the workflow.

Common make targets

Command What it does
make help Show available targets
make install Sync Python (uv sync) + Node (pnpm install) deps
make dev Run FastAPI server + esbuild + Tailwind watchers + browser auto-reload
make run Run the FastAPI server only (no watchers), with varlock-injected env
make assets One-shot rebuild of app.js + app.css
make test Run pytest + vitest
make lint ruff check + ruff format --check + prettier --check
make format ruff format + ruff check --fix + prettier --write
make typecheck ty check (Python) + tsc --noEmit (TypeScript)
make check Everything CI runs (lint + typecheck + test)
make build Build wheel + sdist into dist/
make docker Build the Docker image locally as posthole:dev
make docker-run Run the locally built image

Live reload

make dev runs the processes declared in Procfile.dev under honcho, so a single Ctrl-C tears them all down:

  • fastapi dev restarts the server on .py / .toml edits via watchfiles.
  • esbuild --watch rebuilds src/posthole/static/app.js on .ts edits.
  • tailwindcss --watch rebuilds src/posthole/static/app.css on template / CSS edits.
  • arel is mounted on /hot-reload (gated by POSTHOLE_DEV_RELOAD=1) and reloads the browser when watched files change.

See CONTRIBUTING.md for the full development workflow, commit conventions, and release process.

License

MIT — see LICENSE.

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

posthole-0.5.2.tar.gz (272.3 kB view details)

Uploaded Source

Built Distribution

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

posthole-0.5.2-py3-none-any.whl (169.9 kB view details)

Uploaded Python 3

File details

Details for the file posthole-0.5.2.tar.gz.

File metadata

  • Download URL: posthole-0.5.2.tar.gz
  • Upload date:
  • Size: 272.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for posthole-0.5.2.tar.gz
Algorithm Hash digest
SHA256 c33a2de85d0885a84643d0a7aa424504282c7f401ee8dd1f22eedf6838ff24da
MD5 53c946fbeaa0c333af7bcd3fa63dc0d0
BLAKE2b-256 fc483c0139e2b9bd756deff904e016f6017b96a1dc7a256e033c178d89629dd3

See more details on using hashes here.

Provenance

The following attestation bundles were made for posthole-0.5.2.tar.gz:

Publisher: release.yml on socialpyre/posthole

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file posthole-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: posthole-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 169.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for posthole-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c9f83d9b27b8c48f1dd994825e0a96bbca971f3f6c5a7458c4dfd6ff4f405c4b
MD5 759b27f8d64ea6723f1a5698f4bae721
BLAKE2b-256 ffc0d0d4e591031c911bf8859d0a002a5d02c7b5ece69428a82e3dab8f969a67

See more details on using hashes here.

Provenance

The following attestation bundles were made for posthole-0.5.2-py3-none-any.whl:

Publisher: release.yml on socialpyre/posthole

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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