@commonpub/schema 0.10.0 → 0.12.0
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.
- package/dist/contest.d.ts +17 -0
- package/dist/contest.d.ts.map +1 -1
- package/dist/contest.js +2 -1
- package/dist/contest.js.map +1 -1
- package/dist/enums.d.ts +5 -1
- package/dist/enums.d.ts.map +1 -1
- package/dist/enums.js +7 -0
- package/dist/enums.js.map +1 -1
- package/dist/events.d.ts +465 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +59 -0
- package/dist/events.js.map +1 -0
- package/dist/hub.d.ts +17 -0
- package/dist/hub.d.ts.map +1 -1
- package/dist/hub.js +1 -0
- package/dist/hub.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/dist/social.d.ts +2 -2
- package/dist/voting.d.ts +379 -0
- package/dist/voting.d.ts.map +1 -0
- package/dist/voting.js +85 -0
- package/dist/voting.js.map +1 -0
- package/package.json +1 -1
package/dist/voting.js
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { pgTable, uuid, varchar, integer, timestamp, unique, index } from 'drizzle-orm/pg-core';
|
|
2
|
+
import { relations } from 'drizzle-orm';
|
|
3
|
+
import { users } from './auth.js';
|
|
4
|
+
import { hubPosts } from './hub.js';
|
|
5
|
+
import { contestEntries } from './contest.js';
|
|
6
|
+
import { voteDirectionEnum } from './enums.js';
|
|
7
|
+
// --- Hub Post Votes (upvote/downvote) ---
|
|
8
|
+
export const hubPostVotes = pgTable('hub_post_votes', {
|
|
9
|
+
id: uuid('id').defaultRandom().primaryKey(),
|
|
10
|
+
postId: uuid('post_id')
|
|
11
|
+
.notNull()
|
|
12
|
+
.references(() => hubPosts.id, { onDelete: 'cascade' }),
|
|
13
|
+
userId: uuid('user_id')
|
|
14
|
+
.notNull()
|
|
15
|
+
.references(() => users.id, { onDelete: 'cascade' }),
|
|
16
|
+
direction: voteDirectionEnum('direction').notNull(),
|
|
17
|
+
createdAt: timestamp('created_at', { withTimezone: true }).defaultNow().notNull(),
|
|
18
|
+
}, (t) => [
|
|
19
|
+
unique('uq_hub_post_votes_post_user').on(t.postId, t.userId),
|
|
20
|
+
index('idx_hub_post_votes_post_id').on(t.postId),
|
|
21
|
+
index('idx_hub_post_votes_user_id').on(t.userId),
|
|
22
|
+
]);
|
|
23
|
+
// --- Polls ---
|
|
24
|
+
export const pollOptions = pgTable('poll_options', {
|
|
25
|
+
id: uuid('id').defaultRandom().primaryKey(),
|
|
26
|
+
postId: uuid('post_id')
|
|
27
|
+
.notNull()
|
|
28
|
+
.references(() => hubPosts.id, { onDelete: 'cascade' }),
|
|
29
|
+
label: varchar('label', { length: 255 }).notNull(),
|
|
30
|
+
voteCount: integer('vote_count').default(0).notNull(),
|
|
31
|
+
order: integer('order').default(0).notNull(),
|
|
32
|
+
}, (t) => [
|
|
33
|
+
index('idx_poll_options_post_id').on(t.postId),
|
|
34
|
+
]);
|
|
35
|
+
export const pollVotes = pgTable('poll_votes', {
|
|
36
|
+
id: uuid('id').defaultRandom().primaryKey(),
|
|
37
|
+
optionId: uuid('option_id')
|
|
38
|
+
.notNull()
|
|
39
|
+
.references(() => pollOptions.id, { onDelete: 'cascade' }),
|
|
40
|
+
userId: uuid('user_id')
|
|
41
|
+
.notNull()
|
|
42
|
+
.references(() => users.id, { onDelete: 'cascade' }),
|
|
43
|
+
postId: uuid('post_id')
|
|
44
|
+
.notNull()
|
|
45
|
+
.references(() => hubPosts.id, { onDelete: 'cascade' }),
|
|
46
|
+
createdAt: timestamp('created_at', { withTimezone: true }).defaultNow().notNull(),
|
|
47
|
+
}, (t) => [
|
|
48
|
+
unique('uq_poll_votes_post_user').on(t.postId, t.userId),
|
|
49
|
+
index('idx_poll_votes_option_id').on(t.optionId),
|
|
50
|
+
index('idx_poll_votes_user_id').on(t.userId),
|
|
51
|
+
]);
|
|
52
|
+
// --- Contest Entry Votes ---
|
|
53
|
+
export const contestEntryVotes = pgTable('contest_entry_votes', {
|
|
54
|
+
id: uuid('id').defaultRandom().primaryKey(),
|
|
55
|
+
entryId: uuid('entry_id')
|
|
56
|
+
.notNull()
|
|
57
|
+
.references(() => contestEntries.id, { onDelete: 'cascade' }),
|
|
58
|
+
userId: uuid('user_id')
|
|
59
|
+
.notNull()
|
|
60
|
+
.references(() => users.id, { onDelete: 'cascade' }),
|
|
61
|
+
createdAt: timestamp('created_at', { withTimezone: true }).defaultNow().notNull(),
|
|
62
|
+
}, (t) => [
|
|
63
|
+
unique('uq_contest_entry_votes_entry_user').on(t.entryId, t.userId),
|
|
64
|
+
index('idx_contest_entry_votes_entry_id').on(t.entryId),
|
|
65
|
+
index('idx_contest_entry_votes_user_id').on(t.userId),
|
|
66
|
+
]);
|
|
67
|
+
// --- Relations ---
|
|
68
|
+
export const hubPostVotesRelations = relations(hubPostVotes, ({ one }) => ({
|
|
69
|
+
post: one(hubPosts, { fields: [hubPostVotes.postId], references: [hubPosts.id] }),
|
|
70
|
+
user: one(users, { fields: [hubPostVotes.userId], references: [users.id] }),
|
|
71
|
+
}));
|
|
72
|
+
export const pollOptionsRelations = relations(pollOptions, ({ one, many }) => ({
|
|
73
|
+
post: one(hubPosts, { fields: [pollOptions.postId], references: [hubPosts.id] }),
|
|
74
|
+
votes: many(pollVotes),
|
|
75
|
+
}));
|
|
76
|
+
export const pollVotesRelations = relations(pollVotes, ({ one }) => ({
|
|
77
|
+
option: one(pollOptions, { fields: [pollVotes.optionId], references: [pollOptions.id] }),
|
|
78
|
+
user: one(users, { fields: [pollVotes.userId], references: [users.id] }),
|
|
79
|
+
post: one(hubPosts, { fields: [pollVotes.postId], references: [hubPosts.id] }),
|
|
80
|
+
}));
|
|
81
|
+
export const contestEntryVotesRelations = relations(contestEntryVotes, ({ one }) => ({
|
|
82
|
+
entry: one(contestEntries, { fields: [contestEntryVotes.entryId], references: [contestEntries.id] }),
|
|
83
|
+
user: one(users, { fields: [contestEntryVotes.userId], references: [users.id] }),
|
|
84
|
+
}));
|
|
85
|
+
//# sourceMappingURL=voting.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"voting.js","sourceRoot":"","sources":["../src/voting.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAW,MAAM,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACzG,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAY,cAAc,EAAE,MAAM,cAAc,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAE/C,2CAA2C;AAE3C,MAAM,CAAC,MAAM,YAAY,GAAG,OAAO,CAAC,gBAAgB,EAAE;IACpD,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE;IAC3C,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACzD,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACtD,SAAS,EAAE,iBAAiB,CAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IACnD,SAAS,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE;CAClF,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;IACR,MAAM,CAAC,6BAA6B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;IAC5D,KAAK,CAAC,4BAA4B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAChD,KAAK,CAAC,4BAA4B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;CACjD,CAAC,CAAC;AAEH,gBAAgB;AAEhB,MAAM,CAAC,MAAM,WAAW,GAAG,OAAO,CAAC,cAAc,EAAE;IACjD,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE;IAC3C,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACzD,KAAK,EAAE,OAAO,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,OAAO,EAAE;IAClD,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;IACrD,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;CAC7C,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;IACR,KAAK,CAAC,0BAA0B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;CAC/C,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,SAAS,GAAG,OAAO,CAAC,YAAY,EAAE;IAC7C,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE;IAC3C,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;SACxB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAC5D,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACtD,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACzD,SAAS,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE;CAClF,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;IACR,MAAM,CAAC,yBAAyB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;IACxD,KAAK,CAAC,0BAA0B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;IAChD,KAAK,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;CAC7C,CAAC,CAAC;AAEH,8BAA8B;AAE9B,MAAM,CAAC,MAAM,iBAAiB,GAAG,OAAO,CAAC,qBAAqB,EAAE;IAC9D,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE;IAC3C,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC;SACtB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAC/D,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC;SACpB,OAAO,EAAE;SACT,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACtD,SAAS,EAAE,SAAS,CAAC,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE;CAClF,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;IACR,MAAM,CAAC,mCAAmC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC;IACnE,KAAK,CAAC,kCAAkC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;IACvD,KAAK,CAAC,iCAAiC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;CACtD,CAAC,CAAC;AAEH,oBAAoB;AAEpB,MAAM,CAAC,MAAM,qBAAqB,GAAG,SAAS,CAAC,YAAY,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IACzE,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;IACjF,IAAI,EAAE,GAAG,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;CAC5E,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,oBAAoB,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;IAC7E,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;IAChF,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC;CACvB,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,kBAAkB,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IACnE,MAAM,EAAE,GAAG,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,CAAC;IACxF,IAAI,EAAE,GAAG,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;IACxE,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;CAC/E,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,0BAA0B,GAAG,SAAS,CAAC,iBAAiB,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;IACnF,KAAK,EAAE,GAAG,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,UAAU,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC;IACpG,IAAI,EAAE,GAAG,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;CACjF,CAAC,CAAC,CAAC"}
|