Skip to main content

Interactive diagnostics/triage guard for Pactown on VPS

Project description

img.png

Pactown - Executable Markdown SaaS Platform

Deploy URL: [app]{sep}[username].DOMAIN (domyślnie sep = -, np. 3-tom-sapletta-com.pactown.com)

Platforma SaaS umożliwiająca użytkownikom tworzenie i uruchamianie aplikacji poprzez edytor Markdown z integracją LLM (OpenRouter) i płatnościami.

img_1.png

Quick Start

# 1. Sklonuj repo
git clone https://github.com/wronai/pactown-com.git
cd pactown-com

# 2. Skonfiguruj środowisko
make config

# 3. Zainstaluj na serwerze VPS (Podman + Quadlet)
make install

# 4. Zainicjalizuj Traefik i środowisko
make quadlet-init

# 5. Uruchom wszystkie serwisy
make up

# 6. Sprawdź status
make status

Wymagania Serwera

  • VPS: 8GB RAM, 8 vCPU (np. Hetzner CX31 ~€17/msc)
  • OS: Ubuntu 22.04/24.04 lub Fedora 39+
  • Domena: pactown.com z wildcard DNS (*.pactown.com)
  • Porty: 80, 443

Dlaczego Podman Quadlet zamiast Docker Swarm?

Cecha Docker Swarm Podman Quadlet
Daemonless ❌ Wymaga dockerd ✅ Bez demona
Rootless ⚠️ Eksperymentalny ✅ Natywny
Systemd integration ❌ Osobne zarządzanie ✅ Natywne
Security isolation ⚠️ Shared daemon ✅ Per-user namespaces
Auto-restart ✅ Via systemd
Memory footprint ~100MB daemon ~0MB (on-demand)
Multi-tenant ⚠️ Labels ✅ User namespaces

Pactown wykorzystuje wewnętrzny moduł pactown.deploy.quadlet z pełnym wsparciem dla:

  • Sanityzacji nazw, zmiennych, ścieżek (security)
  • Generowania Traefik jako Quadlet
  • Izolacji tenantów przez user namespaces
  • Walidacji volume mounts

Architektura

┌─────────────────────────────────────────────────────────────────┐
│                    pactown.com (Traefik Quadlet)                │
├─────────────────────────────────────────────────────────────────┤
│  *.pactown.com → Wildcard SSL (Let's Encrypt)                   │
│                                                                 │
│  ┌──────────┐  ┌──────────┐  ┌──────────┐  ┌──────────────┐     │
│  │   Web    │  │   API    │  │  Editor  │  │ User Apps    │     │
│  │ :3000    │  │  :8000   │  │  :3001   │  │ :10000-20000 │     │
│  │ Next.js  │  │ FastAPI  │  │ TipTap   │  │ markpact     │     │
│  └──────────┘  └──────────┘  └──────────┘  └──────────────┘     │
│       │              │             │              │              │
│  [Quadlet]      [Quadlet]     [Quadlet]       [Quadlet]         │
│       │              │             │              │              │
│       ▼              ▼             ▼              ▼              │
│  ┌──────────────────────────────────────────────────────────┐   │
│  │       systemd user services (rootless containers)        │   │
│  └──────────────────────────────────────────────────────────┘   │
│                              │                                  │
│  ┌──────────────────────────────────────────────────────────┐   │
│  │              PostgreSQL + Redis (Quadlet)                │   │
│  └──────────────────────────────────────────────────────────┘   │
└─────────────────────────────────────────────────────────────────┘

Ważne elementy implementacji:

  • [Auth (sesja)] access_token jako httpOnly cookie (token nie jest przekazywany w URL i nie jest trzymany w localStorage).
  • [Runner status realtime] Dashboard korzysta z SSE (GET /runner/status/stream) zamiast polling.
  • [Admin auth] admin_token jako httpOnly cookie.

Struktura Projektu

pactown-com/
├── Makefile              # Wszystkie komendy (make quadlet-*)
├── scripts/              # Skrypty wywoływane przez Makefile
│   ├── config.sh         # Interaktywna konfiguracja
│   ├── install.sh        # Instalacja Podman
│   ├── up.sh             # Uruchamianie serwisów
│   ├── dev.sh            # Tryb development
│   ├── test.sh           # Runner testów
│   └── diag-remote.sh    # Diagnostyka produkcji
├── quadlet/              # Pliki jednostek Quadlet
├── .env.example          # Template konfiguracji
├── backend/
│   ├── app/
│   │   ├── main.py       # FastAPI app
│   │   ├── routers/auth.py # OAuth2 (Google, GitHub)
│   │   ├── config.py     # Pydantic Settings
│   │   └── ...           
│   └── tests/
├── frontend/
│   ├── src/
│   ├── e2e/              # Testy Playwright
│   │   └── oauth.spec.ts # Testy OAuth
│   └── package.json
├── infra/scripts/        # Skrypty infrastruktury
│   ├── diagnostics.sh    # Pełna diagnostyka
│   └── init-quadlet.sh   # Inicjalizacja Quadlet
└── docs/                 # Dokumentacja

Komendy Makefile

Komenda Opis
make config Interaktywna konfiguracja .env
make install Instalacja Podman + zależności
make dev Tryb development (docker-compose)
make build Zbuduj obrazy localhost/pactown-api:latest i localhost/pactown-web:latest
make pull Pobierz obrazy z registry i otaguj jako localhost/*
make up Uruchom produkcję (Quadlet)
make down Zatrzymaj serwisy
make restart Restart wszystkich serwisów
make status Status serwisów
make logs Logi serwisów
make diag Diagnostyka systemu
make diag-remote Diagnostyka produkcji (DNS, SSL)
make test Testy API + frontend
make test-oauth Testy OAuth (Playwright)
make deploy Deploy produkcyjny

Dokumentacja (repo)

  • docs/README.md (menu): ./docs/README.md
  • CLI + mapowanie API→shell (curl/make): ./docs/CLI_API.md
  • Produkcja (VPS): przykłady komend make / pactowncom: ./docs/CLI_API.md#produkcja-vps

Pactown Guard (pactown-guard)

pactown-guard to transparentny guard do diagnostyki VPS: uruchamiasz go ręcznie i dostajesz interaktywny shell.

Szybkie użycie (z repo)

python3 infra/scripts/pactown_guard.py --prod

Po uruchomieniu zobaczysz podsumowanie i prompt:

pactown-guard>

Komendy w shellu

  • help Pokaż dostępne komendy.
  • diag Uruchom ponownie diagnostykę (infra/scripts/diagnostics.sh --json).
  • suggest Pokaż propozycje bezpiecznych akcji (bez wykonywania zmian).
  • apply Zastosuj proponowane akcje, ale zawsze pyta o potwierdzenie dla każdej z nich.
  • restart <service> Restart pojedynczej usługi systemd --user (tylko z allowlisty; z potwierdzeniem).
  • logs <service> Podejrzyj logi journalctl --user -u <service>.
  • triage Otwórz sesję tmux z logami (domyślnie pactown-triage).
  • exit / quit Wyjście.

Instalacja komendy pactown-guard (w PATH)

Po make install instalacja jest robiona automatycznie w trybie editable (pip --user -e .). Jeśli chcesz to zrobić ręcznie:

pactown-guard install

Aktualizacja pactown-guard

Najprościej:

pactown-guard update

Domyślnie (gdy jesteś w repo) zrobi git pull + reinstalację -e. Jeśli uruchamiasz poza repo, wykona update z PyPI.

Opcjonalny systemd timer (niezalecane jako domyślne)

Guard jest projektowany jako narzędzie manualne. Jeśli chcesz uruchamiać go okresowo:

make guard-init
make guard-enable-timer
make guard-status

Wyłączenie timera:

make guard-disable

Publikacja paczki (PyPI)

make publish

Wymaga ustawionych poświadczeń (np. TWINE_USERNAME, TWINE_PASSWORD).

Funkcjonalności MVP

1. Social Login

2. Markdown Editor (TipTap)

  • WYSIWYG editing
  • Code blocks z syntax highlighting
  • markpact:* codeblocks
  • Live preview

3. LLM Integration (OpenRouter)

  • Generowanie projektów z opisu
  • Auto-fix błędów runtime
  • Darmowe modele (nemotron)

4. Płatności

  • Stripe (karty, BLIK via P24)
  • Tpay (natywne polskie płatności)

5. User Services

  • Dynamiczne tworzenie subdomen
  • Konfigurowalny separator subdomen (SUBDOMAIN_SEPARATOR: - lub .)
  • Izolacja kontenerów
  • Health checks

6. Diagnostyka / zgłaszanie problemów

  • Dashboard: synchronizacja stanu UI z parametrami URL (m.in. view, project, terminal, terminal_tab, settings)
  • Dashboard: ślad działań użytkownika jako token trace + trace_id (korelacja logów)
  • Dashboard: „Zgłoś problem” (modal) z możliwością dołączenia zrzutu ekranu
  • Backend: POST /users/me/issue-report zapisuje zgłoszenie w activity_log oraz (opcjonalnie) screenshot w katalogu logów użytkownika

Changelog / Roadmap

Konfiguracja DNS

# Dodaj rekordy DNS dla pactown.com:
A     @         <IP_SERWERA>
A     *         <IP_SERWERA>
AAAA  @         <IPv6_SERWERA> (opcjonalnie)
AAAA  *         <IPv6_SERWERA> (opcjonalnie)

Dokumentacja

Dokument Opis
docs/AUTH.md Konfiguracja OAuth (Google, GitHub, Clerk)
docs/IMPLEMENTATION.md Szczegóły implementacji (cookies auth, SSE runner status, proxy, admin/public pages, cache env)
docs/CONFIGURATION.md Pełna konfiguracja .env
docs/DEV_SETUP.md Setup środowiska dev
docs/SECURITY.md Bezpieczeństwo i best practices
docs/SERVICE_PROVIDER.md Wymagania dla providera usług / hostingu (pod skalowanie runnerów)
docs/IAC.md Infrastructure as Code

Licencja

2026 Softreck. Wszelkie prawa zastrzeżone.


Ostatnia aktualizacja: Styczeń 2026

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

pactown_guard-0.1.3.tar.gz (2.3 MB view details)

Uploaded Source

Built Distribution

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

pactown_guard-0.1.3-py3-none-any.whl (2.7 MB view details)

Uploaded Python 3

File details

Details for the file pactown_guard-0.1.3.tar.gz.

File metadata

  • Download URL: pactown_guard-0.1.3.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pactown_guard-0.1.3.tar.gz
Algorithm Hash digest
SHA256 b9dd764236eff7aeb67a280723a174a48e621a9b2864ec7cc20066a6cae100b1
MD5 6419c7e4edbcc8e016f0f90bc4608644
BLAKE2b-256 012a06e272495f2623e31ec7caa4955f69c46f606708c86288acfc649956ef43

See more details on using hashes here.

File details

Details for the file pactown_guard-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: pactown_guard-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 2.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pactown_guard-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 530352e6b7a22a93c5628d176843f3c27a9dbfde975e3c163fbd616638cce68a
MD5 c47fff5416bbc31d30caff50067553af
BLAKE2b-256 b6bb31932306b47f3d3414e3a403a51ca3918c496450e1255eec9166eef72839

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