Commit Graph

257 Commits

Author SHA1 Message Date
d3cdbdf3e2 docs(postgres-hooks): document hectic bundle + responsibility split
Add lib/hook/sql/README.md describing bundle layout, apply order, Nix API
(self.lib.hectic.*), shell helper contract, and the steps for adding a new
SQL file. Rewrite db-tool README's hectic section: drop stale
PG_HECTIC_INHERITANCE / HECTIC_INHERITANCE_SQL env vars, add
HECTIC_DOTENV_FILE, document the postgres-init / migrator init / database
hydrate responsibility split.
2026-04-30 22:12:18 +00:00
3d5e3fdb36 feat: postgres hooks 2026-04-30 21:59:53 +00:00
bf7ee34716 feat: start impliment postgres hooks 2026-04-30 21:36:22 +00:00
2eaa568f5b feat(db-tool): hectic-inheritance: add hectic.immutable + diff coverage
Add a hectic.immutable parent table. Tables inheriting it get auto-attached
BEFORE INSERT/UPDATE/DELETE/TRUNCATE row+statement triggers that block DML
unless the session sets hectic.migration_mode='on' (intended use: SET LOCAL
inside a migration transaction). Same exemptions as the rest of the bundle
apply (hectic schema, partitions, temp tables, GUC-excluded schemas).

database diff now appends an --- IMMUTABLE TABLE DATA --- section to its
output, with per-table unified row diffs of every table inheriting
hectic.immutable, surfacing drift in 'frozen' reference data alongside schema
drift. Subcommand exits non-zero when either schema or data differs.

Test postgres-init-hectic-inheritance extended to 10 cases covering
immutable triggers, DML blocked outside migration_mode, SET LOCAL allowing
DML inside a transaction, GUC not leaking past COMMIT, and TRUNCATE under
migration_mode.
2026-04-30 16:10:38 +00:00
31d2994997 feat(db-tool): postgres-init: apply hectic-inheritance by default
Flip PG_HECTIC_INHERITANCE default 0 -> 1. Set PG_HECTIC_INHERITANCE=0 to opt out.
2026-04-30 15:48:33 +00:00
58e9aa8fad feat(db-tool): hectic-inheritance: bootstrap hectic.created_at / hectic.updated_at inheritance hook
Adds a SQL bundle plus event triggers that enforce `INHERITS (hectic.created_at)`
on every user CREATE TABLE and auto-attach a BEFORE UPDATE row trigger when a
table inherits `hectic.updated_at`. Always-exempt: `hectic`, `information_schema`,
`pg_*`, declarative partitions, temp tables. Per-DB opt-out via the GUC
`hectic.inheritance_extra_excluded_schemas`.

Exposed three ways:
  * `pkgs.hectic.hectic-inheritance` — derivation with the SQL at
    $out/share/hectic/hectic-inheritance.sql
  * `self.lib.hecticInheritance.{sql,path}` — pkgs-free Nix surface
  * `postgres-init` opt-in via `PG_HECTIC_INHERITANCE=1` (HECTIC_INHERITANCE_SQL
    overrides the default)

Test postgres-init-hectic-inheritance covers all six branches: bootstrap,
non-inheriting reject, accepting inheritance, auto updated_at trigger fires,
GUC exclusion, declarative partition exemption.
2026-04-30 15:16:57 +00:00
7d5300853b fix(db-tool): postgres-init: createdb on reuse when target DB missing
Previously when PG_REUSE=1 and PG_VERSION existed but the target database had
never been successfully created (e.g. devshell exited mid-init in a prior run),
postgres-init skipped createdb and the subsequent psql connection failed with
'database "<db>" does not exist'.

Now on reuse path we probe pg_database and create the target DB if missing,
making postgres-init fully idempotent across stale-state recovery.

Adds postgres-init-reuse-missing-db test.
2026-04-30 12:16:09 +00:00
e732ecb878 feat(db-tool): expose overridable postgresql arg and PG_CONF_FILE env
Wrap db-tool, postgres-init, postgres-cleanup with lib.makeOverridable so
consumers can inject extension-enabled PostgreSQL via .override { postgresql = ...; }.
Add PG_CONF_FILE: when set, replaces script-generated postgresql.conf entirely
(runtime port and unix_socket_directories still appended/overridden).
2026-04-30 12:00:08 +00:00
705f5bbd01 fix(db-tool): postgres-init: always invoke main so sourcing exports vars
Previous basename guard only ran the function when invoked as the
postgres-init binary, but consumer shellHooks source the script to
inherit POSTGRESQL_HOST/PGURL/etc. Sourcing left the function defined
but never called, leaving WIPE_PGURL/PGURL unset and breaking devshell
entry in proxydoe and ruststats.
2026-04-30 11:37:19 +00:00
06a5d16ee3 fix(package): db-tool: call postgres-init/cleanup binaries instead of local devshell scripts
Ultraworked with [Sisyphus](https://github.com/code-yeongyu/oh-my-openagent)

Co-authored-by: Sisyphus <clio-agent@sisyphuslabs.ai>
2026-04-30 10:10:11 +00:00
5713eaad14 fix(package): db-tool: default PGURL to empty in dispatch to fix pull_staging exit=3 contract 2026-04-30 09:24:58 +00:00
b5dcbf08a1 feat(\db-tool\): introduce unified db-tool package with postgres harness and tests (T0-T8) 2026-04-30 09:06:44 +00:00
62757df384 fix(package): sentinèlla: use dig(1) instead of host(1) which is not in bind.dnsutils 2026-04-27 17:30:01 +00:00
f2ea372742 debug(package): sentinèlla: surface host(1) and SRV-parse failures in watcher 2026-04-27 17:28:01 +00:00
f158a80492 fix(package): sentinèlla: use ip(8) for local-IP detection (inetutils hostname lacks -I); harden numeric parsing 2026-04-27 17:21:00 +00:00
0c81c0454d feat(package): sentinèlla: switch peer discovery from A records to SRV records 2026-04-27 14:08:23 +00:00
7268ec3704 fix(package): sentinèlla: probe — use socat EXEC pipes to avoid pty CR/LF mangling 2026-04-27 13:34:52 +00:00
0dfbee6472 feat: sentinella: some 2026-04-27 12:58:36 +00:00
6035397e9b feat(sentinèlla): p2p topology with DNS peer discovery
- Replace central sentinel with watcher: each node polls peers discovered
  via a single DNS name with multiple A records (e.g. peers.sentinella.com)
- Auto-detect own IPs via hostname -I; SELF env var available as optional
  override for NAT/floating-IP setups
- Fix Basic Auth bug in router.sh: compare tok against AUTH_TOKENS instead
  of unset $USER/$PASS
- Rename sentinel binary to watcher; drop unused shellplot dep
- Add inetutils to watcher runtime deps for hostname -I
- Update NixOS module: replace sentinel options with watcher p2p options
  (peersDns, self, peersPort, peersScheme, pollingIntervalSec)
- Add sentinèlla test suite: probe-status-empty, probe-disk, watcher-state-file
2026-04-26 21:54:07 +00:00
b9730784ba fix: deploy: logs 2026-03-01 09:36:22 +00:00
577c167d5a feat: migrator: +multifiles migrations 2026-02-28 21:19:29 +00:00
525c6a220b chore: 2026-02-28 20:25:13 +00:00
0d7b84e3bc refactor: derustification 2026-02-20 17:36:20 +00:00
d8a51cd389 refactor: update to 25.11 2026-02-20 17:18:38 +00:00
63a7fd716f apply patch from neuro 2026-02-20 12:51:32 +00:00
9010b2678e refactor: deploy: update logs 2026-02-20 12:04:15 +00:00
26bdecb8e0 fix: migrator: more accurate check for hectic.migrator isntalled 2026-02-17 16:50:08 +00:00
ff87e8c411 chore: something about hemar tree sitter 2026-02-17 16:17:47 +00:00
d7ada535d4 feat: +pol bfs server 2026-02-17 16:13:58 +00:00
7490ef2fe9 fix: nvim-pager close all pages on q 2026-02-17 08:55:41 +00:00
043b333654 feat: migrator: colorize help in migrator.sh 2026-02-06 08:38:36 +00:00
4a9bb42015 feat(nixos): some moves to nixos server 2025-12-28 19:18:15 +00:00
3d84864382 fix(package): migrator: sqlite transactions 2025-12-23 19:31:44 +00:00
cb96de6125 fix(package): migrator: handle sqlite posible settings 2025-12-23 18:30:26 +00:00
686a794a69 fix(pakcage): migrator: -z -> +x 2025-12-23 18:18:51 +00:00
2ffe187b12 fix(package): migrator: awk dependency 2025-12-21 13:19:46 +00:00
89ab7d56af feat(pakcage): migrator: add dependency 2025-12-20 01:19:40 +00:00
01f13723a8 feat(package): migrator: up to latest 2025-12-18 00:45:09 +00:00
9c25e82c79 fix(package): migrator: uncomplite RAISE on sqlite 2025-12-17 03:28:03 +00:00
956239ab79 feat(package): migrator: ! sqlite support 2025-12-17 03:24:59 +00:00
bb2ae34758 feat(package): migrator: mvp 2025-12-16 17:28:36 +00:00
13fdfac2ef test(hemar): update parser test to match better paths 2025-12-09 14:21:03 +00:00
93a7636c61 fix(package): hemar: paths better handling 2025-12-09 14:13:34 +00:00
6fb3ee1af8 test(hemar): many tests but not pass 2025-12-09 13:49:43 +00:00
73dc9aee9e feat(package): hemar: json_escape() 2025-12-09 03:47:27 +00:00
71082b6414 feat(package): hemar: interpolation 2025-12-08 23:47:33 +00:00
65a96c860b feat(package): accord: some cli things 2025-12-08 01:55:33 +00:00
1beb980b95 refactor(nixos): bfs: some secrets 2025-12-07 02:25:29 +00:00
082b80f252 feate(package): accord: init 2025-12-06 23:49:14 +00:00
373a3fe3f0 fix(package): migrator: index_of subshell issue 2025-12-06 04:47:31 +00:00