digital-boardgame-framework 0.8.0 → 0.8.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"supabase-store.d.ts","sourceRoot":"","sources":["../../../src/server/stores/supabase-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EACV,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAC9E,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"supabase-store.d.ts","sourceRoot":"","sources":["../../../src/server/stores/supabase-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EACV,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAC9E,MAAM,aAAa,CAAC;AAcrB,qBAAa,aAAc,YAAW,aAAa;IACrC,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,cAAc;IAEpC,WAAW,CAAC,IAAI,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAahD,OAAO,CAAC,SAAS;IAYX,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;IAQrD,eAAe,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAOtC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAM5D,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,SAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAUjE,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOzC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAe5D,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAQtD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAOlD,SAAS,CAAC,GAAG,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAoB3C,WAAW,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IA2B3D,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAMzE"}
|
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
import { ConflictError } from '../store.js';
|
|
2
2
|
// Supabase store. Apply supabase/schema.sql to your project first.
|
|
3
|
+
/** Supabase returns a plain error OBJECT (not an Error), so `throw error` then
|
|
4
|
+
* `String(e)` in a consumer's handler yields the useless "[object Object]".
|
|
5
|
+
* Wrap it in a real Error carrying the actual message (+ code) so the cause
|
|
6
|
+
* (e.g. "relation dbf_messages does not exist") is visible. */
|
|
7
|
+
function asError(error) {
|
|
8
|
+
const parts = [error.message, error.details].filter(Boolean).join(' — ');
|
|
9
|
+
return new Error((parts || JSON.stringify(error)) + (error.code ? ` [${error.code}]` : ''));
|
|
10
|
+
}
|
|
3
11
|
export class SupabaseStore {
|
|
4
12
|
client;
|
|
5
13
|
constructor(client) {
|
|
@@ -16,7 +24,7 @@ export class SupabaseStore {
|
|
|
16
24
|
reminder: meta.reminder ?? null,
|
|
17
25
|
});
|
|
18
26
|
if (error)
|
|
19
|
-
throw error;
|
|
27
|
+
throw asError(error);
|
|
20
28
|
}
|
|
21
29
|
rowToMeta(data) {
|
|
22
30
|
return {
|
|
@@ -33,7 +41,7 @@ export class SupabaseStore {
|
|
|
33
41
|
const { data, error } = await this.client
|
|
34
42
|
.from('dbf_games').select('*').eq('game_id', gameId).maybeSingle();
|
|
35
43
|
if (error)
|
|
36
|
-
throw error;
|
|
44
|
+
throw asError(error);
|
|
37
45
|
if (!data)
|
|
38
46
|
return null;
|
|
39
47
|
return this.rowToMeta(data);
|
|
@@ -42,21 +50,21 @@ export class SupabaseStore {
|
|
|
42
50
|
const { data, error } = await this.client
|
|
43
51
|
.from('dbf_games').select('*').eq('resolved', false);
|
|
44
52
|
if (error)
|
|
45
|
-
throw error;
|
|
53
|
+
throw asError(error);
|
|
46
54
|
return (data ?? []).map((d) => this.rowToMeta(d));
|
|
47
55
|
}
|
|
48
56
|
async postMessage(gameId, msg) {
|
|
49
57
|
const { error } = await this.client.from('dbf_messages')
|
|
50
58
|
.insert({ game_id: gameId, seat: msg.seat, body: msg.body, created_at: msg.at });
|
|
51
59
|
if (error)
|
|
52
|
-
throw error;
|
|
60
|
+
throw asError(error);
|
|
53
61
|
}
|
|
54
62
|
async listMessages(gameId, limit = 100) {
|
|
55
63
|
const { data, error } = await this.client.from('dbf_messages')
|
|
56
64
|
.select('seat,body,created_at')
|
|
57
65
|
.eq('game_id', gameId).order('created_at', { ascending: false }).limit(limit);
|
|
58
66
|
if (error)
|
|
59
|
-
throw error;
|
|
67
|
+
throw asError(error);
|
|
60
68
|
return (data ?? [])
|
|
61
69
|
.map((r) => ({ seat: r.seat, body: r.body, at: r.created_at }))
|
|
62
70
|
.reverse();
|
|
@@ -66,7 +74,7 @@ export class SupabaseStore {
|
|
|
66
74
|
// (see schema.sql). Reports have no FK and intentionally survive.
|
|
67
75
|
const { error } = await this.client.from('dbf_games').delete().eq('game_id', gameId);
|
|
68
76
|
if (error)
|
|
69
|
-
throw error;
|
|
77
|
+
throw asError(error);
|
|
70
78
|
}
|
|
71
79
|
async putSnapshot(gameId, row) {
|
|
72
80
|
// insert (not upsert): the (game_id, turn) primary key rejects a duplicate,
|
|
@@ -79,7 +87,7 @@ export class SupabaseStore {
|
|
|
79
87
|
if (error.code === '23505') {
|
|
80
88
|
throw new ConflictError(`Snapshot ${gameId}@${row.turn} already exists`);
|
|
81
89
|
}
|
|
82
|
-
throw error;
|
|
90
|
+
throw asError(error);
|
|
83
91
|
}
|
|
84
92
|
}
|
|
85
93
|
async getLatest(gameId) {
|
|
@@ -87,14 +95,14 @@ export class SupabaseStore {
|
|
|
87
95
|
.select('turn,state').eq('game_id', gameId)
|
|
88
96
|
.order('turn', { ascending: false }).limit(1).maybeSingle();
|
|
89
97
|
if (error)
|
|
90
|
-
throw error;
|
|
98
|
+
throw asError(error);
|
|
91
99
|
return data ? { turn: data.turn, state: data.state } : null;
|
|
92
100
|
}
|
|
93
101
|
async getHistory(gameId) {
|
|
94
102
|
const { data, error } = await this.client.from('dbf_snapshots')
|
|
95
103
|
.select('turn,state').eq('game_id', gameId).order('turn', { ascending: true });
|
|
96
104
|
if (error)
|
|
97
|
-
throw error;
|
|
105
|
+
throw asError(error);
|
|
98
106
|
return (data ?? []).map(r => ({ turn: r.turn, state: r.state }));
|
|
99
107
|
}
|
|
100
108
|
async putReport(row) {
|
|
@@ -115,7 +123,7 @@ export class SupabaseStore {
|
|
|
115
123
|
resolution: row.resolution ?? null,
|
|
116
124
|
});
|
|
117
125
|
if (error)
|
|
118
|
-
throw error;
|
|
126
|
+
throw asError(error);
|
|
119
127
|
}
|
|
120
128
|
async listReports(filter) {
|
|
121
129
|
let q = this.client.from('dbf_reports').select('*').order('created_at', { ascending: false });
|
|
@@ -131,7 +139,7 @@ export class SupabaseStore {
|
|
|
131
139
|
q = q.eq('game_id', filter.gameId);
|
|
132
140
|
const { data, error } = await q;
|
|
133
141
|
if (error)
|
|
134
|
-
throw error;
|
|
142
|
+
throw asError(error);
|
|
135
143
|
return (data ?? []).map(r => ({
|
|
136
144
|
reportId: r.report_id,
|
|
137
145
|
gameId: r.game_id,
|
|
@@ -154,7 +162,7 @@ export class SupabaseStore {
|
|
|
154
162
|
resolution: { at: new Date().toISOString(), note: resolution },
|
|
155
163
|
}).eq('report_id', reportId);
|
|
156
164
|
if (error)
|
|
157
|
-
throw error;
|
|
165
|
+
throw asError(error);
|
|
158
166
|
}
|
|
159
167
|
}
|
|
160
168
|
//# sourceMappingURL=supabase-store.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"supabase-store.js","sourceRoot":"","sources":["../../../src/server/stores/supabase-store.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,mEAAmE;AAEnE,MAAM,OAAO,aAAa;IACJ;IAApB,YAAoB,MAAsB;QAAtB,WAAM,GAAN,MAAM,CAAgB;IAAG,CAAC;IAE9C,KAAK,CAAC,WAAW,CAAC,IAAc;QAC9B,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC;YAC3D,OAAO,EAAE,IAAI,CAAC,MAAM;YACpB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,EAAE;YACzB,UAAU,EAAE,IAAI,CAAC,SAAS;YAC1B,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI;SAChC,CAAC,CAAC;QACH,IAAI,KAAK;YAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"supabase-store.js","sourceRoot":"","sources":["../../../src/server/stores/supabase-store.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "digital-boardgame-framework",
|
|
3
|
-
"version": "0.8.
|
|
3
|
+
"version": "0.8.2",
|
|
4
4
|
"description": "Foundation library for turn-based digital boardgames: deterministic engine plumbing, async multiplayer, agent-friendly bug triage.",
|
|
5
5
|
"keywords": ["boardgame", "board-game", "multiplayer", "async-multiplayer", "turn-based", "game-framework", "supabase", "cloudflare-pages"],
|
|
6
6
|
"author": "John Champaign",
|
package/supabase/schema.sql
CHANGED
|
@@ -59,9 +59,16 @@ create index if not exists dbf_reports_category on dbf_reports(category);
|
|
|
59
59
|
create index if not exists dbf_reports_unresolved on dbf_reports(report_id) where resolution is null;
|
|
60
60
|
create index if not exists dbf_reports_game on dbf_reports(game_id);
|
|
61
61
|
|
|
62
|
-
-- Row-level security
|
|
63
|
-
--
|
|
64
|
-
--
|
|
65
|
-
--
|
|
66
|
-
--
|
|
67
|
-
--
|
|
62
|
+
-- Row-level security — REQUIRED, not optional.
|
|
63
|
+
-- These tables hold secrets (dbf_games.tokens), unredacted game state
|
|
64
|
+
-- (dbf_snapshots.state — hidden hands!), and chat. All access goes through your
|
|
65
|
+
-- server endpoints using the SERVICE-ROLE key, which BYPASSES RLS. Enabling RLS
|
|
66
|
+
-- with NO policies therefore denies the public anon key everything (which is
|
|
67
|
+
-- now in client bundles for Realtime) while the server keeps full access.
|
|
68
|
+
-- Realtime *broadcast* doesn't touch these tables, so it's unaffected.
|
|
69
|
+
-- WITHOUT this, anyone with the project URL + anon key can read tokens and
|
|
70
|
+
-- everyone's hidden state. (Supabase flags it as rls_disabled_in_public.)
|
|
71
|
+
alter table dbf_games enable row level security;
|
|
72
|
+
alter table dbf_snapshots enable row level security;
|
|
73
|
+
alter table dbf_messages enable row level security;
|
|
74
|
+
alter table dbf_reports enable row level security;
|