Documentation site operations
The Docusaurus repository is the canonical source for SHAFT product, architecture, usage, migration, and maintainer documentation. The canonical public URL is shafthq.github.io.
GitHub Pages publishes the public guide for users. Cloudflare Workers hosts the
/api/gemini-proxy backend API that AutoBot calls from the browser and can also
serve the same static build as an operational mirror. Do not change Squarespace
DNS for this GitHub Pages recovery path.
Local development
Use Node.js 20 and Yarn:
yarn install
yarn start
Cloudflare Workers Builds uses wrangler.toml, builds with yarn build,
uploads build/ through [assets], and routes /api/gemini-proxy through
worker/index.js. Set YARN_VERSION=1.22.22 and GEMINI_API_KEY in
Cloudflare environment variables; do not commit secrets.
Netlify uses yarn build, publishes build/, and serves functions from
netlify/functions/. GEMINI_API_KEY belongs in the Netlify environment; it
must never be embedded in the browser bundle.
GitHub Pages uses .github/workflows/deploy.yml and publishes build/ as the
canonical public guide at https://shafthq.github.io/.
Egypt accessibility
If Egyptian users cannot open the guide, test both providers before changing site code:
curl -4 -I https://shafthq.github.io/
curl -4 -I https://shaft-engine.mohab-mohieeldeen.workers.dev/autobot-index.json
curl -4 -i -X OPTIONS https://shaft-engine.mohab-mohieeldeen.workers.dev/api/gemini-proxy \
-H "Origin: https://shafthq.github.io" \
-H "Access-Control-Request-Method: POST" \
-H "Access-Control-Request-Headers: content-type"
On 2026-06-23, Cairo probes on Link Egypt timed out against Netlify while
Cloudflare and GitHub Pages returned HTTP 200. The recovery path is to keep
users on https://shafthq.github.io/ and let AutoBot call the Cloudflare Worker
API with CORS enabled for that origin.
Validation
yarn test
yarn typecheck
yarn build
yarn test:playwright
The build fails on broken Markdown links and duplicated long prose or code blocks. The Playwright suite covers desktop and mobile rendering, canonical routes, code copying, and dark mode.
Search and AutoBot
Local search indexes public product documentation. A post-build integrity step
removes /docs/archive/ and /docs/maintainers/ entries. Because search is
static, it works anywhere the Docusaurus assets load.
AutoBot indexes Markdown and MDX by route and heading at startup, retrieves the
eight best chunks for each question, and caps injected documentation context at
80,000 characters. yarn build writes static/autobot-index.json; the
Cloudflare function fetches that static index at runtime, so AutoBot does not
depend on GitHub Pages server-side code or Netlify filesystem access. Archive
and maintainer routes are excluded. The public HTTP request and response
contract remains unchanged.
Content changes
- Keep one canonical page per concept.
- Reuse commands and dependency snippets from
src/components/DocSnippets. - Put historical records under
docs/archive/; archive routes are unlisted and emitnoindex. - Add redirects in
netlify.tomlwhen replacing a public route. - Coordinate public behavior changes with a linked SHAFT_ENGINE pull request.