5.7 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			5.7 KiB
		
	
	
	
	
	
	
	
VoxBlog Admin Project Plan
Vision
Voice-first authoring tool for single-user Ghost blog. Capture audio, refine with AI, manage rich media, and publish seamlessly via a secure admin dashboard.
Architecture Snapshot
- Frontend: apps/admin– React + TypeScript, Vite, Material UI, authenticated single-user dashboard.
- Backend: apps/api– Node.js (Express) providing auth, media upload, OpenAI & Ghost integrations, leveraging shared utilities.
- Storage: MinIO (S3-compatible) running on VPS (S3 API at http://<vps>:9000), with local dev fallback as needed.
- Shared: packages/for shared TypeScript types, client SDK, and utility modules.
Milestones & Tasks
- M1 · Access & Shell (Scope: Goals 1 + infrastructure)
- Scaffold workspace structure (frontend, backend, shared packages).
- Implement .env management & secrets handling guidelines.
- Build password gate (frontend form + backend verification).
- Connect FE<->BE via Vite proxy and enable CORS.
- Load .env in API with explicit path.
- Bootstrap base admin layout with navigation placeholders.
- Document manual test checklist for auth flow.
 
- M2 · Voice Capture Pipeline (Scope: Goal 2)
- Add browser audio recorder UI & permissions handling.
- Stream/upload audio blobs to backend endpoint.
- Persist raw audio (S3/local) with metadata.
 
- M3 · Speech-to-Text Integration (Scope: Goal 3)
- Invoke OpenAI STT API server-side.
- Surface transcript in rich editor state with status feedback.
- Log conversion lifecycle for debug.
 
- M4 · Rich Editor Enhancements (Scope: Goal 4)
- Integrate block-based editor (e.g., TipTap/Rich text) with custom nodes.
- Implement file/image upload widget wired to storage.
- Support color picker, code blocks, and metadata fields.
 
- M5 · AI Editing Tools (Scope: Goal 5)
- Prompt templates for tone/style suggestions via OpenAI.
- Inline improvement workflow with diff/revert capabilities.
 
- M6 · Ghost Publication Flow (Scope: Goal 6)
- Map editor content to Ghost post payload.
- Implement publish/draft triggers with status reports.
- Handle tags, feature image, and canonical URL settings.
 
- M7 · Media Management (Scope: Goal 7)
- Centralize media library view with reuse.
- Background cleanup/retention policies.
 
- M8 · UX Polish & Hardening (Scope: Goal 8)
- Loading/error states across workflows.
- Responsive layout tuning & accessibility audit.
- Smoke test scripts for manual verification.
 
Environment & Tooling TODOs
- Core tooling
- Configure PNPM workspaces (or Nx/Turbo) for multi-app repo.
- ESLint + Prettier shared config.
- Commit hooks (lint-staged, Husky) optional.
 
- Secrets
- .env.examplefor common keys (ADMIN_PASSWORD_HASH, OPENAI_API_KEY, GHOST_ADMIN_API_KEY, S3 credentials).
- Instructions for local secret population.
 
Tooling Decisions
- Dependency manager: Adopt PNPM with workspace support for mono-repo friendliness and fast installs.
- Task runner: Use Turborepo for orchestrating build/test scripts across apps/packages.
- Package structure: Maintain apps/for runtime targets andpackages/for shared libraries.
Immediate Next Actions
- Create admin layout shell (header/sidebar, container)
- Persist auth state (cookie/localStorage flag after success)
- Add simple health route /api/healthand error handler
- Begin audio capture UI (mic permission + basic recorder)
Upcoming Next Actions
- Backend endpoint for audio upload /api/media/audio(accept WebM/PCM) — implemented with MinIO via AWS SDK v3
- S3-compatible adapter using MinIO (S3_ENDPOINT,S3_ACCESS_KEY,S3_SECRET_KEY)
- Backend STT endpoint /api/stt(download from MinIO, call OpenAI STT, return transcript)
- Add STT trigger in UI: call /api/sttwith{ bucket, key }and render transcript
Next Priorities
- Save transcript into an editor document (draft state) and display in editor.
- List uploaded media items and allow re-use/deletion.
- Add simple document persistence API (CRUD) and local storage autosave.
MinIO Integration Checklist
- Deploy MinIO on VPS (console :9001, API:9000).
- Create bucket voxblogand access keys.
- Configure .envwith:- S3_ENDPOINT=http://<vps>:9000
- S3_BUCKET=voxblog
- S3_REGION=us-east-1
- S3_ACCESS_KEY=...
- S3_SECRET_KEY=...
 
- Optional: Set bucket policy to allow public reads for media.
Scaffolding Plan (Draft)
- Frontend (apps/admin)- pnpm create vite apps/admin --template react-ts
- Add Material UI (pnpm add @mui/material @mui/icons-material @emotion/react @emotion/styled -C apps/admin).
 
- Backend (apps/api)- pnpm dlx degit expressjs/express apps/api
- Install TypeScript + tooling (pnpm add -D typescript ts-node-dev @types/node @types/express -C apps/api).
 
- Shared packages
- pnpm create @tsconfig/bases packages/config-ts(or manual- tsconfigshared file).
- Create packages/typesfor shared TypeScript definitions.
 
- Workspace root
- Initialize PNPM workspace: pnpm init, addpnpm-workspace.yamlwithapps/**andpackages/**.
- Configure Turborepo: pnpm add -D turbo, addturbo.jsonwith build/dev/lint pipelines.
 
- Initialize PNPM workspace: 
Risks & Assumptions
- OpenAI & Ghost API access available with required scopes.
- Single admin user requirement simplifies auth; if multi-user emerges, revisit architecture.
- Browser recording support assumed for target browsers (Chrome/Edge latest).
References
- Ghost Admin API docs
- OpenAI Whisper/Speech-to-Text API docs
- AWS S3 SDK for Node.js