Skip to content

Release: Sync develop to main#5

Merged
ChesnoTech merged 2 commits intomainfrom
develop
Mar 25, 2026
Merged

Release: Sync develop to main#5
ChesnoTech merged 2 commits intomainfrom
develop

Conversation

@ChesnoTech
Copy link
Copy Markdown
Owner

Summary

Sync all develop changes to main (Git Flow release merge).

Includes: BSL license, landing page, pricing tiers, CBR reports,
hardware bindings, DPK import, email alerts, Git Flow setup.

ChesnoTech and others added 2 commits March 24, 2026 11:41
- Protected main: require PR + CI (PHP Lint, Frontend Build, Docker)
- Protected develop: require PR + CI (PHP Lint, Frontend Build)
- Updated PR template with Git Flow branch types and testing checklist
- Rewrote CONTRIBUTING.md with full Git Flow workflow, branch naming,
  and development setup instructions
- Repo is now public (BSL licensed)

Co-authored-by: ChesnoTech <263363000+ChesnoTech@users.noreply.github.com>
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
…boot recovery (#6)

Handles connection loss, forced shutdowns, and duplicate instances:

- Single-instance mutex: prevents two KeyGate instances running simultaneously
- Persistent state file (C:\ProgramData\KeyGate\activation-state.json):
  writes state BEFORE each step, survives power cuts
- Connection monitor: 2-second polling with auto-resume on reconnect
- Invoke-WithRetry: wraps API calls with automatic retry + connection wait
- Boot recovery scheduled task: on next boot, checks for pending state
  and reports activation result to server
- Resume-FromState: on next launch, detects interrupted session and
  resumes from the correct phase (hw_submitted, key_installed, activated)

Tested on Windows 11:
- Mutex: correctly blocks second instance
- State file: atomic write (tmp + move) survives interruption
- Connection check: ping + HTTP health fallback works
- Boot recovery: requires admin (CMD launcher always runs as admin)

Co-authored-by: ChesnoTech <263363000+ChesnoTech@users.noreply.github.com>
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
@ChesnoTech ChesnoTech merged commit 05733a0 into main Mar 25, 2026
8 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant