@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/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":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@commonpub/schema",
3
- "version": "0.10.0",
3
+ "version": "0.12.0",
4
4
  "type": "module",
5
5
  "description": "Drizzle ORM tables and Zod validators for CommonPub",
6
6
  "license": "AGPL-3.0-or-later",