-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
89 lines (67 loc) · 2.49 KB
/
Makefile
File metadata and controls
89 lines (67 loc) · 2.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
.PHONY: dev stop shell logs clean clean-compacted test test-up test-down export export-html api-docs dump-system status prod-start prod-stop prod-deploy deploy-all prod-git-unlock prod-logs prod-logs-all prod-logs-clear
dev: test-down
@test -d prompts || (mkdir -p prompts && cp -rn prompts-default/* prompts/)
rm -f state/eliezer.log
docker compose up -d --build init searxng
docker compose wait init 2>/dev/null || true
docker compose up -d --build --force-recreate --no-deps eliezer
@for i in 1 2 3 4 5 6 7 8 9 10; do \
if curl -sf http://localhost:3200/info/health >/dev/null 2>&1; then \
echo "eliezer is healthy"; exit 0; \
fi; \
if ! docker compose ps eliezer --format '{{.State}}' 2>/dev/null | grep -q running; then \
echo "ERROR: eliezer crashed on startup:"; \
docker compose logs eliezer --tail=20; \
exit 1; \
fi; \
sleep 1; \
done; \
echo "ERROR: eliezer not healthy after 10s:"; \
docker compose logs eliezer --tail=20; \
exit 1
stop:
docker compose down
shell:
docker compose exec eliezer /bin/bash
logs:
docker compose logs -f
clean:
docker compose down -v 2>/dev/null || true
docker compose -f docker-compose.test.yml down -v 2>/dev/null || true
clean-compacted:
sqlite3 state/eliezer.db "UPDATE messages SET archived = 0; DELETE FROM compacted;"
@echo "Reset: all messages unarchived, compacted table cleared"
test-up:
docker compose -f docker-compose.test.yml up -d
test-down:
docker compose -f docker-compose.test.yml down
test: stop test-up
npx tsc --noEmit
@npm test; ret=$$?; $(MAKE) test-down; exit $$ret
export:
@npx tsx export-chat.mts
export-html:
@npx tsx export-chat-html.mts
api-docs:
@npx tsx -e "const s=require('fs').readFileSync('server.mts','utf-8');for(const l of s.split('\n')){const m=l.match(/^\t\t\/\/ ?(.*)/);if(m)console.log(m[1])}"
status:
@curl -sf http://localhost:3200/info/memory >/dev/null || (echo "ERROR: eliezer not reachable at localhost:3200"; exit 1)
@curl -sf http://localhost:3200/info/memory | jq -rf scripts/status.jq
dump-system:
@npx tsx scripts/dump-system.mts state/system-dump.txt
prod-start:
systemctl start eliezer
prod-stop:
systemctl stop eliezer
prod-git-unlock:
@echo 'eval "$$(ssh-agent -s)"; ssh-add /root/.ssh/git_access'
prod-deploy:
$(MAKE) -C deploy deploy
deploy-all:
$(MAKE) -C /opt/clawchat prod-deploy && $(MAKE) prod-deploy
prod-logs:
journalctl -u eliezer -f
prod-logs-all:
journalctl -u eliezer --no-pager | less
prod-logs-clear:
journalctl --rotate && journalctl --vacuum-time=1s -u eliezer