Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
114 changes: 86 additions & 28 deletions drizzle/0000_jazzy_exodus.sql → drizzle/0000_modern_valkyrie.sql
Original file line number Diff line number Diff line change
@@ -1,8 +1,24 @@
CREATE TYPE "public"."context_type_enum" AS ENUM('global', 'committee', 'project');--> statement-breakpoint
CREATE TYPE "public"."event_host_type_enum" AS ENUM('club', 'committee', 'project', 'member');--> statement-breakpoint
CREATE TYPE "public"."gender_enum" AS ENUM('M', 'F', 'NB', 'O', 'PNTS');--> statement-breakpoint
CREATE TYPE "public"."officer_role_enum" AS ENUM('executive_chair', 'executive_vice_chair', 'executive_secretary', 'executive_treasurer', 'committee_lead');--> statement-breakpoint
CREATE TYPE "public"."officer_role_enum" AS ENUM('Executive Chair', 'Vice Chair', 'Treasurer', 'Secretary', 'Project Chair', 'Workshop Chair', 'Conference Chair', 'Outreach Chair', 'Service Chair', 'Social Chair', 'Professional Development Chair', 'Marketing Chair', 'Software Chair');--> statement-breakpoint
CREATE TYPE "public"."permission_enum" AS ENUM('scan_attendance', 'view_statistics', 'manage_context');--> statement-breakpoint
CREATE TYPE "public"."sponsorship_tier_enum" AS ENUM('bronze', 'silver', 'gold');--> statement-breakpoint
CREATE TYPE "public"."sponsorship_tier_enum" AS ENUM('Bronze', 'Silver', 'Gold');--> statement-breakpoint
CREATE TABLE "accounts" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"user_id" uuid NOT NULL,
"type" varchar(255) NOT NULL,
"provider" varchar(255) NOT NULL,
"provider_account_id" varchar(255) NOT NULL,
"refresh_token" text,
"access_token" text,
"expires_at" integer,
"token_type" varchar(255),
"scope" varchar(255),
"id_token" text,
"session_state" varchar(255)
);
--> statement-breakpoint
CREATE TABLE "committee_members" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"committee_id" uuid NOT NULL,
Expand All @@ -16,7 +32,6 @@ CREATE TABLE "committees" (
"title" varchar(255) NOT NULL,
"slug" varchar(64),
"about" text NOT NULL,
"chair_id" uuid NOT NULL,
"discord_role_id" varchar(64),
"active" boolean DEFAULT true NOT NULL,
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
Expand All @@ -36,28 +51,27 @@ CREATE TABLE "events" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"title" varchar(255) NOT NULL,
"location" varchar(255) NOT NULL,
"host_type" "event_host_type_enum" NOT NULL,
"host_type" "event_host_type_enum" DEFAULT 'committee' NOT NULL,
"host_id" uuid,
"slug" varchar(64),
"start_time" timestamp with time zone NOT NULL,
"end_time" timestamp with time zone,
"requires_dues" boolean DEFAULT false NOT NULL,
"active" boolean DEFAULT true NOT NULL,
"description" text NOT NULL,
"flyer_url" varchar(500),
"rsvp_link" varchar(500),
"photo_urls" text,
"duration" integer,
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
"updated_at" timestamp with time zone DEFAULT now() NOT NULL,
"slug" varchar(64),
"start_time" timestamp with time zone NOT NULL,
"end_time" timestamp with time zone,
"requires_dues" boolean DEFAULT false NOT NULL,
"active" boolean DEFAULT true NOT NULL,
CONSTRAINT "events_slug_unique" UNIQUE("slug")
);
--> statement-breakpoint
CREATE TABLE "member_permissions" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"member_id" uuid NOT NULL,
"granted_by_id" uuid,
"context_type" varchar(32) NOT NULL,
"context_type" "context_type_enum" NOT NULL,
"context_id" uuid,
"permission" "permission_enum" NOT NULL,
"active" boolean DEFAULT true NOT NULL,
Expand All @@ -68,16 +82,19 @@ CREATE TABLE "member_permissions" (
--> statement-breakpoint
CREATE TABLE "members" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"user_id" uuid NOT NULL,
"first_name" varchar(255) NOT NULL,
"middle_name" varchar(255),
"last_name" varchar(255) NOT NULL,
"officer_role" "officer_role_enum",
"administrator" boolean DEFAULT false NOT NULL,
"officer_status" boolean DEFAULT false NOT NULL,
"biography" text,
"dues_paid" boolean DEFAULT false NOT NULL,
"discord_id" varchar(64) NOT NULL,
"discordID" varchar(64),
"date_of_birth" date NOT NULL,
"email" varchar(255) NOT NULL,
"personal_email" varchar(255) NOT NULL,
"ucf_email" varchar(255) NOT NULL,
"phone_number" varchar(20),
"major" varchar(255) NOT NULL,
"gender" "gender_enum" NOT NULL,
Expand All @@ -90,8 +107,10 @@ CREATE TABLE "members" (
"active" boolean DEFAULT true NOT NULL,
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
"updated_at" timestamp with time zone DEFAULT now() NOT NULL,
CONSTRAINT "members_discord_id_unique" UNIQUE("discord_id"),
CONSTRAINT "members_email_unique" UNIQUE("email")
CONSTRAINT "members_user_id_unique" UNIQUE("user_id"),
CONSTRAINT "members_discordID_unique" UNIQUE("discordID"),
CONSTRAINT "members_personal_email_unique" UNIQUE("personal_email"),
CONSTRAINT "members_ucf_email_unique" UNIQUE("ucf_email")
);
--> statement-breakpoint
CREATE TABLE "project_members" (
Expand All @@ -118,6 +137,21 @@ CREATE TABLE "projects" (
CONSTRAINT "projects_slug_unique" UNIQUE("slug")
);
--> statement-breakpoint
CREATE TABLE "scanning_sessions" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"event_id" uuid NOT NULL,
"scanner_id" uuid,
"scanned_member_id" uuid NOT NULL,
"method" varchar(32) DEFAULT 'qr' NOT NULL,
"timestamp" timestamp with time zone DEFAULT now() NOT NULL
);
--> statement-breakpoint
CREATE TABLE "sessions" (
"session_token" varchar(255) PRIMARY KEY NOT NULL,
"user_id" uuid NOT NULL,
"expires" timestamp with time zone NOT NULL
);
--> statement-breakpoint
CREATE TABLE "sponsorships" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"company_name" varchar(255) NOT NULL,
Expand All @@ -132,41 +166,59 @@ CREATE TABLE "sponsorships" (
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
);
--> statement-breakpoint
CREATE TABLE "users" (
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
"name" text,
"email" varchar(255) NOT NULL,
"email_verified" timestamp with time zone,
"image" text,
"discordID" varchar(64),
CONSTRAINT "users_email_unique" UNIQUE("email"),
CONSTRAINT "users_discordID_unique" UNIQUE("discordID")
);
--> statement-breakpoint
ALTER TABLE "accounts" ADD CONSTRAINT "accounts_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "committee_members" ADD CONSTRAINT "committee_members_committee_id_committees_id_fk" FOREIGN KEY ("committee_id") REFERENCES "public"."committees"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "committee_members" ADD CONSTRAINT "committee_members_member_id_members_id_fk" FOREIGN KEY ("member_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "committees" ADD CONSTRAINT "committees_chair_id_members_id_fk" FOREIGN KEY ("chair_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "event_attendees" ADD CONSTRAINT "event_attendees_event_id_events_id_fk" FOREIGN KEY ("event_id") REFERENCES "public"."events"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "event_attendees" ADD CONSTRAINT "event_attendees_member_id_members_id_fk" FOREIGN KEY ("member_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "member_permissions" ADD CONSTRAINT "member_permissions_member_id_members_id_fk" FOREIGN KEY ("member_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "member_permissions" ADD CONSTRAINT "member_permissions_granted_by_id_members_id_fk" FOREIGN KEY ("granted_by_id") REFERENCES "public"."members"("id") ON DELETE set null ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "members" ADD CONSTRAINT "members_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "project_members" ADD CONSTRAINT "project_members_project_id_projects_id_fk" FOREIGN KEY ("project_id") REFERENCES "public"."projects"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "project_members" ADD CONSTRAINT "project_members_member_id_members_id_fk" FOREIGN KEY ("member_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "scanning_sessions" ADD CONSTRAINT "scanning_sessions_event_id_events_id_fk" FOREIGN KEY ("event_id") REFERENCES "public"."events"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "scanning_sessions" ADD CONSTRAINT "scanning_sessions_scanner_id_members_id_fk" FOREIGN KEY ("scanner_id") REFERENCES "public"."members"("id") ON DELETE set null ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "scanning_sessions" ADD CONSTRAINT "scanning_sessions_scanned_member_id_members_id_fk" FOREIGN KEY ("scanned_member_id") REFERENCES "public"."members"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
ALTER TABLE "sessions" ADD CONSTRAINT "sessions_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
CREATE INDEX "committee_members_idx_id" ON "committee_members" USING btree ("id");--> statement-breakpoint
CREATE INDEX "committee_members_idx_committee_id" ON "committee_members" USING btree ("committee_id");--> statement-breakpoint
CREATE INDEX "committee_members_idx_member_id" ON "committee_members" USING btree ("member_id");--> statement-breakpoint
CREATE INDEX "committee_members_idx_is_chair" ON "committee_members" USING btree ("is_chair");--> statement-breakpoint
CREATE INDEX "committees_idx_id" ON "committees" USING btree ("id");--> statement-breakpoint
CREATE INDEX "committees_idx_title" ON "committees" USING btree ("title");--> statement-breakpoint
CREATE INDEX "committees_idx_slug" ON "committees" USING btree ("slug");--> statement-breakpoint
CREATE INDEX "committees_idx_chair_id" ON "committees" USING btree ("chair_id");--> statement-breakpoint
CREATE INDEX "committees_idx_created_at" ON "committees" USING btree ("created_at");--> statement-breakpoint
CREATE INDEX "committees_idx_updated_at" ON "committees" USING btree ("updated_at");--> statement-breakpoint
CREATE INDEX "event_attendees_idx_id" ON "event_attendees" USING btree ("id");--> statement-breakpoint
CREATE INDEX "event_attendees_idx_event_id" ON "event_attendees" USING btree ("event_id");--> statement-breakpoint
CREATE INDEX "event_attendees_idx_member_id" ON "event_attendees" USING btree ("member_id");--> statement-breakpoint
CREATE INDEX "events_idx_id" ON "events" USING btree ("id");--> statement-breakpoint
CREATE INDEX "events_idx_host" ON "events" USING btree ("host_type","host_id");--> statement-breakpoint
CREATE INDEX "events_idx_start_time" ON "events" USING btree ("start_time");--> statement-breakpoint
CREATE INDEX "events_idx_time_desc" ON "events" USING btree (start_time DESC);--> statement-breakpoint
CREATE INDEX "events_idx_title" ON "events" USING btree ("title");--> statement-breakpoint
CREATE INDEX "events_idx_location" ON "events" USING btree ("location");--> statement-breakpoint
CREATE INDEX "events_idx_created_at" ON "events" USING btree ("created_at");--> statement-breakpoint
CREATE INDEX "events_idx_updated_at" ON "events" USING btree ("updated_at");--> statement-breakpoint
CREATE INDEX "events_idx_host" ON "events" USING btree ("host_type","host_id" uuid_ops);--> statement-breakpoint
CREATE INDEX "events_idx_created_at" ON "events" USING btree ("created_at" timestamptz_ops);--> statement-breakpoint
CREATE INDEX "events_idx_id" ON "events" USING btree ("id" uuid_ops);--> statement-breakpoint
CREATE INDEX "events_idx_location" ON "events" USING btree ("location" text_ops);--> statement-breakpoint
CREATE INDEX "events_idx_start_time" ON "events" USING btree ("start_time" timestamptz_ops);--> statement-breakpoint
CREATE INDEX "events_idx_time_desc" ON "events" USING btree ("start_time" timestamptz_ops);--> statement-breakpoint
CREATE INDEX "events_idx_title" ON "events" USING btree ("title" text_ops);--> statement-breakpoint
CREATE INDEX "events_idx_updated_at" ON "events" USING btree ("updated_at" timestamptz_ops);--> statement-breakpoint
CREATE INDEX "member_permissions_idx_member" ON "member_permissions" USING btree ("member_id");--> statement-breakpoint
CREATE INDEX "member_permissions_idx_context" ON "member_permissions" USING btree ("context_type","context_id");--> statement-breakpoint
CREATE INDEX "members_idx_id" ON "members" USING btree ("id");--> statement-breakpoint
CREATE INDEX "members_idx_discord_id" ON "members" USING btree ("discord_id");--> statement-breakpoint
CREATE INDEX "members_idx_email" ON "members" USING btree ("email");--> statement-breakpoint
CREATE INDEX "members_idx_user_id" ON "members" USING btree ("user_id");--> statement-breakpoint
CREATE INDEX "members_idx_discordID" ON "members" USING btree ("discordID");--> statement-breakpoint
CREATE INDEX "members_idx_personal_email" ON "members" USING btree ("personal_email");--> statement-breakpoint
CREATE INDEX "members_idx_ucf_email" ON "members" USING btree ("ucf_email");--> statement-breakpoint
CREATE INDEX "members_idx_officer_status" ON "members" USING btree ("officer_status");--> statement-breakpoint
CREATE INDEX "members_idx_officer_role" ON "members" USING btree ("officer_role");--> statement-breakpoint
CREATE INDEX "members_idx_administrator" ON "members" USING btree ("administrator");--> statement-breakpoint
CREATE INDEX "members_idx_dues_paid" ON "members" USING btree ("dues_paid");--> statement-breakpoint
Expand All @@ -185,8 +237,14 @@ CREATE INDEX "projects_idx_title" ON "projects" USING btree ("title");--> statem
CREATE INDEX "projects_idx_slug" ON "projects" USING btree ("slug");--> statement-breakpoint
CREATE INDEX "projects_idx_created_at" ON "projects" USING btree ("created_at");--> statement-breakpoint
CREATE INDEX "projects_idx_updated_at" ON "projects" USING btree ("updated_at");--> statement-breakpoint
CREATE INDEX "scanning_sessions_idx_event" ON "scanning_sessions" USING btree ("event_id");--> statement-breakpoint
CREATE INDEX "scanning_sessions_idx_scanner" ON "scanning_sessions" USING btree ("scanner_id");--> statement-breakpoint
CREATE INDEX "scanning_sessions_idx_scanned_member" ON "scanning_sessions" USING btree ("scanned_member_id");--> statement-breakpoint
CREATE INDEX "scanning_sessions_idx_timestamp" ON "scanning_sessions" USING btree ("timestamp");--> statement-breakpoint
CREATE INDEX "sponsorships_idx_id" ON "sponsorships" USING btree ("id");--> statement-breakpoint
CREATE INDEX "sponsorships_idx_company_name" ON "sponsorships" USING btree ("company_name");--> statement-breakpoint
CREATE INDEX "sponsorships_idx_tier" ON "sponsorships" USING btree ("tier");--> statement-breakpoint
CREATE INDEX "sponsorships_idx_created_at" ON "sponsorships" USING btree ("created_at");--> statement-breakpoint
CREATE INDEX "sponsorships_idx_updated_at" ON "sponsorships" USING btree ("updated_at");
CREATE INDEX "sponsorships_idx_updated_at" ON "sponsorships" USING btree ("updated_at");--> statement-breakpoint
CREATE INDEX "users_idx_id" ON "users" USING btree ("id");--> statement-breakpoint
CREATE INDEX "users_idx_discord_id" ON "users" USING btree ("discordID");
Loading