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.6.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.6-py3-none-any.whl (2.7 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pactown_guard-0.1.6.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.6.tar.gz
Algorithm Hash digest
SHA256 507d01efea2adacb6c0bdf06e67380df1d5ed026277983e5e406d28ea443016d
MD5 f1470ca7cd9ac277f870571b02944e0a
BLAKE2b-256 36304b88cda8217eb094955832f93975279e79e1a01f9ccc9515181343e3f60d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pactown_guard-0.1.6-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.6-py3-none-any.whl
Algorithm Hash digest
SHA256 91668e8755f6c5a80f6fd989a73235e801a6faf08b69b64f2b0747d8d88ab4ae
MD5 c0d7e1e6b9054961bf879196c79771e3
BLAKE2b-256 d4a6c3a56dd99168506928141917bb8b342aed6a2c838ef6f33879d723817e42

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