-- CreateEnum CREATE TYPE "CampaignModerationStatus" AS ENUM ('PENDING_REVIEW', 'APPROVED', 'REJECTED', 'CHANGES_REQUESTED'); -- CreateEnum CREATE TYPE "BuildingType" AS ENUM ('SINGLE_FAMILY', 'MULTI_UNIT', 'MIXED_USE', 'COMMERCIAL'); -- CreateEnum CREATE TYPE "LocationHistoryAction" AS ENUM ('CREATED', 'UPDATED', 'GEOCODED', 'BULK_GEOCODED', 'MOVED_ON_MAP', 'IMPORTED_CSV', 'IMPORTED_NAR'); -- CreateEnum CREATE TYPE "RecurrenceFrequency" AS ENUM ('DAILY', 'WEEKLY', 'MONTHLY'); -- CreateEnum CREATE TYPE "EmailTemplateCategory" AS ENUM ('INFLUENCE', 'MAP', 'SYSTEM', 'PAYMENT'); -- CreateEnum CREATE TYPE "EmailTemplateVariableType" AS ENUM ('TEXT', 'VIDEO'); -- CreateEnum CREATE TYPE "DirectoryType" AS ENUM ('studios', 'gifs', 'private', 'inbox', 'curated', 'playback', 'compilations', 'videos', 'highlights'); -- CreateEnum CREATE TYPE "ResourceCategory" AS ENUM ('gpu_ai', 'gpu_encode', 'cpu'); -- CreateEnum CREATE TYPE "JobStatus" AS ENUM ('pending', 'queued', 'running', 'completed', 'failed', 'cancelled'); -- CreateEnum CREATE TYPE "ReactionType" AS ENUM ('like', 'love', 'laugh', 'wow', 'sad', 'angry'); -- CreateEnum CREATE TYPE "WordFilterLevel" AS ENUM ('low', 'medium', 'high', 'custom'); -- CreateEnum CREATE TYPE "ReportType" AS ENUM ('inappropriate', 'spam', 'copyright', 'illegal', 'false_info', 'other'); -- CreateEnum CREATE TYPE "ReportStatus" AS ENUM ('pending', 'reviewed', 'actioned', 'dismissed'); -- CreateEnum CREATE TYPE "FriendshipStatus" AS ENUM ('pending', 'accepted', 'declined'); -- CreateEnum CREATE TYPE "SocialPlatform" AS ENUM ('twitter', 'instagram', 'onlyfans', 'fansly', 'reddit', 'discord', 'tiktok', 'youtube', 'twitch', 'snapchat', 'linktree', 'custom'); -- CreateEnum CREATE TYPE "UserUploadStatus" AS ENUM ('pending', 'approved', 'rejected'); -- CreateEnum CREATE TYPE "UploadInviteStatus" AS ENUM ('active', 'inactive', 'expired'); -- CreateEnum CREATE TYPE "DigestStatus" AS ENUM ('pending', 'scene_detection', 'extracting', 'analyzing', 'face_detection', 'transcribing', 'segmenting', 'synthesizing', 'completed', 'failed', 'cancelled'); -- CreateEnum CREATE TYPE "ClipType" AS ENUM ('hook', 'intro', 'action', 'climax', 'highlight'); -- CreateEnum CREATE TYPE "ClipStatus" AS ENUM ('pending', 'processing', 'completed', 'failed'); -- CreateEnum CREATE TYPE "ClipSource" AS ENUM ('machine', 'manual'); -- CreateEnum CREATE TYPE "CaptionPosition" AS ENUM ('bottom', 'top'); -- CreateEnum CREATE TYPE "CaptionSize" AS ENUM ('small', 'medium', 'large'); -- CreateEnum CREATE TYPE "SegmentType" AS ENUM ('scene', 'tag_change', 'vocal', 'fixed_interval'); -- CreateEnum CREATE TYPE "VocalCategory" AS ENUM ('dialogue', 'dirty_talk', 'climax', 'interview', 'moan'); -- CreateEnum CREATE TYPE "SuggestedTagStatus" AS ENUM ('pending', 'approved', 'rejected', 'mapped'); -- CreateEnum CREATE TYPE "WatchPartyStatus" AS ENUM ('active', 'completed', 'cancelled'); -- CreateEnum CREATE TYPE "PipelineStatus" AS ENUM ('draft', 'active', 'paused', 'completed', 'failed'); -- CreateEnum CREATE TYPE "PipelineStepStatus" AS ENUM ('pending', 'running', 'completed', 'failed', 'skipped'); -- CreateEnum CREATE TYPE "SubscriptionStatus" AS ENUM ('none', 'active', 'grace_period', 'delinquent', 'lifetime', 'cancelled'); -- CreateEnum CREATE TYPE "InvoiceStatus" AS ENUM ('pending', 'paid', 'failed', 'refunded'); -- CreateEnum CREATE TYPE "PaymentStatus" AS ENUM ('pending', 'succeeded', 'failed', 'refunded'); -- CreateEnum CREATE TYPE "PaymentMethod" AS ENUM ('card', 'bank_transfer', 'crypto', 'stripe'); -- CreateEnum CREATE TYPE "ProductType" AS ENUM ('DIGITAL', 'EVENT', 'DONATION'); -- CreateEnum CREATE TYPE "OrderStatus" AS ENUM ('PENDING', 'COMPLETED', 'FAILED', 'REFUNDED'); -- CreateEnum CREATE TYPE "NotificationType" AS ENUM ('friend_request', 'friend_accepted', 'poke', 'comment', 'upload_approved', 'upload_rejected', 'achievement', 'system'); -- CreateEnum CREATE TYPE "DonationPageStatus" AS ENUM ('DRAFT', 'ACTIVE', 'PAUSED', 'ARCHIVED'); -- CreateEnum CREATE TYPE "DocsCommentStatus" AS ENUM ('PENDING', 'APPROVED', 'REJECTED'); -- CreateEnum CREATE TYPE "SmsContactListStatus" AS ENUM ('ACTIVE', 'ARCHIVED'); -- CreateEnum CREATE TYPE "SmsCampaignStatus" AS ENUM ('DRAFT', 'RUNNING', 'PAUSED', 'COMPLETED', 'FAILED'); -- CreateEnum CREATE TYPE "SmsMessageDirection" AS ENUM ('OUTBOUND', 'INBOUND'); -- CreateEnum CREATE TYPE "SmsMessageStatus" AS ENUM ('PENDING', 'SENT', 'FAILED', 'DELIVERED'); -- CreateEnum CREATE TYPE "SmsResponseType" AS ENUM ('POSITIVE', 'NEGATIVE', 'QUESTION', 'OPT_OUT', 'NEUTRAL'); -- CreateEnum CREATE TYPE "SmsConversationStatus" AS ENUM ('ACTIVE', 'OPTED_OUT', 'CLOSED'); -- CreateEnum CREATE TYPE "ContactSource" AS ENUM ('USER', 'ADDRESS_OCCUPANT', 'CAMPAIGN_SENDER', 'SHIFT_SIGNUP', 'SMS_CONTACT', 'DONATION', 'MANUAL'); -- CreateEnum CREATE TYPE "ConnectionType" AS ENUM ('HOUSEHOLD', 'FAMILY', 'COLLEAGUE', 'REFERRED_BY', 'CUSTOM'); -- CreateEnum CREATE TYPE "ContactActivityType" AS ENUM ('EMAIL_SENT', 'RESPONSE_SUBMITTED', 'SHIFT_SIGNUP', 'CANVASS_VISIT', 'DONATION', 'PURCHASE', 'SMS_SENT', 'SMS_RECEIVED', 'VIDEO_VIEW', 'NOTE_ADDED', 'CONTACT_MERGED', 'PROFILE_SELF_EDIT', 'PROFILE_PHOTO_UPDATED', 'USER_LOGIN'); -- AlterEnum ALTER TYPE "UserCreatedVia" ADD VALUE 'SELF_REGISTRATION'; -- AlterEnum -- This migration adds more than one value to an enum. -- With PostgreSQL versions 11 and earlier, this is not possible -- in a single migration. This can be worked around by creating -- multiple migrations, each migration adding only one value to -- the enum. ALTER TYPE "UserStatus" ADD VALUE 'PENDING_VERIFICATION'; ALTER TYPE "UserStatus" ADD VALUE 'PENDING_APPROVAL'; -- DropForeignKey ALTER TABLE "canvass_visits" DROP CONSTRAINT "canvass_visits_locationId_fkey"; -- DropIndex DROP INDEX "canvass_visits_locationId_idx"; -- AlterTable ALTER TABLE "campaigns" ADD COLUMN "coverVideoId" INTEGER, ADD COLUMN "isUserGenerated" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "moderationNotes" TEXT, ADD COLUMN "moderationStatus" "CampaignModerationStatus", ADD COLUMN "rejectionReason" TEXT, ADD COLUMN "reviewedAt" TIMESTAMP(3), ADD COLUMN "reviewedByUserId" TEXT; -- AlterTable ALTER TABLE "canvass_visits" DROP COLUMN "locationId", ADD COLUMN "addressId" TEXT NOT NULL; -- AlterTable ALTER TABLE "landing_pages" ADD COLUMN "mkdocsSkipExport" BOOLEAN NOT NULL DEFAULT false; -- AlterTable ALTER TABLE "locations" DROP COLUMN "email", DROP COLUMN "firstName", DROP COLUMN "lastName", DROP COLUMN "notes", DROP COLUMN "phone", DROP COLUMN "sign", DROP COLUMN "signSize", DROP COLUMN "supportLevel", DROP COLUMN "unitNumber", ADD COLUMN "buildingNotes" TEXT, ADD COLUMN "buildingType" "BuildingType" NOT NULL DEFAULT 'SINGLE_FAMILY', ADD COLUMN "locGuid" TEXT, ADD COLUMN "totalUnits" INTEGER NOT NULL DEFAULT 1, ALTER COLUMN "latitude" SET NOT NULL, ALTER COLUMN "longitude" SET NOT NULL, ALTER COLUMN "address" SET NOT NULL; -- AlterTable ALTER TABLE "map_settings" ADD COLUMN "publicMapEnabled" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowAddresses" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowCuts" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowEvents" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowLocations" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowSignInfo" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "publicShowSupportLevels" BOOLEAN NOT NULL DEFAULT true; -- AlterTable ALTER TABLE "shifts" ADD COLUMN "isException" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "seriesId" TEXT; -- AlterTable ALTER TABLE "site_settings" ADD COLUMN "autoApproveVerifiedUsers" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "auto_sync_people_to_map" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enableEmailVerification" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "enablePayments" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enablePublicRegistration" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "enable_chat" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enable_docs_comments" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enable_gallery_ads" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enable_media_features" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "enable_people" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enable_sms" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "enable_user_provisioning" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "giteaApiToken" TEXT NOT NULL DEFAULT '', ADD COLUMN "giteaCommentsRepoName" TEXT NOT NULL DEFAULT 'docs-comments', ADD COLUMN "giteaCommentsRepoOwner" TEXT NOT NULL DEFAULT '', ADD COLUMN "giteaOauthClientId" TEXT NOT NULL DEFAULT '', ADD COLUMN "giteaOauthClientSecret" TEXT NOT NULL DEFAULT '', ADD COLUMN "nav_config" JSONB, ADD COLUMN "notifyAdminResponseSubmitted" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "notifyAdminShiftSignup" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "notifyAdminSignRequested" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "notifyVolunteerCancellation" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "notifyVolunteerSessionSummary" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "notifyVolunteerShiftReminder" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "provision_gitea" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "provision_gitea_timing" TEXT NOT NULL DEFAULT 'lazy', ADD COLUMN "provision_listmonk" BOOLEAN NOT NULL DEFAULT true, ADD COLUMN "provision_listmonk_timing" TEXT NOT NULL DEFAULT 'eager', ADD COLUMN "provision_vaultwarden" BOOLEAN NOT NULL DEFAULT false, ADD COLUMN "provision_vaultwarden_timing" TEXT NOT NULL DEFAULT 'lazy', ADD COLUMN "sms_tailscale_api_key" TEXT NOT NULL DEFAULT '', ADD COLUMN "sms_tailscale_device_id" TEXT NOT NULL DEFAULT '', ADD COLUMN "sms_tailscale_device_name" TEXT NOT NULL DEFAULT '', ADD COLUMN "sms_tailscale_tailnet" TEXT NOT NULL DEFAULT '', ADD COLUMN "sms_termux_api_key" TEXT NOT NULL DEFAULT '', ADD COLUMN "sms_termux_api_url" TEXT NOT NULL DEFAULT '', ADD COLUMN "smtpActiveProvider" TEXT NOT NULL DEFAULT 'mailhog'; -- AlterTable ALTER TABLE "users" ADD COLUMN "roles" JSONB NOT NULL DEFAULT '[]'; -- CreateTable CREATE TABLE "addresses" ( "id" TEXT NOT NULL, "locationId" TEXT NOT NULL, "unitNumber" TEXT, "addrGuid" TEXT, "firstName" TEXT, "lastName" TEXT, "email" TEXT, "phone" TEXT, "supportLevel" "SupportLevel", "sign" BOOLEAN NOT NULL DEFAULT false, "signSize" TEXT, "notes" TEXT, "createdByUserId" TEXT, "updatedByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "addresses_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "location_history" ( "id" TEXT NOT NULL, "locationId" TEXT NOT NULL, "userId" TEXT, "action" "LocationHistoryAction" NOT NULL, "field" TEXT, "oldValue" TEXT, "newValue" TEXT, "metadata" JSONB, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "location_history_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "shift_series" ( "id" TEXT NOT NULL, "title" TEXT NOT NULL, "description" TEXT, "startTime" TEXT NOT NULL, "endTime" TEXT NOT NULL, "location" TEXT, "maxVolunteers" INTEGER NOT NULL, "isPublic" BOOLEAN NOT NULL DEFAULT false, "cutId" TEXT, "frequency" "RecurrenceFrequency" NOT NULL, "daysOfWeek" JSONB, "startDate" DATE NOT NULL, "endDate" DATE, "createdBy" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "shift_series_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_templates" ( "id" TEXT NOT NULL, "key" TEXT NOT NULL, "name" TEXT NOT NULL, "description" TEXT, "category" "EmailTemplateCategory" NOT NULL, "subjectLine" TEXT NOT NULL, "htmlContent" TEXT NOT NULL, "textContent" TEXT NOT NULL, "isSystem" BOOLEAN NOT NULL DEFAULT false, "isActive" BOOLEAN NOT NULL DEFAULT true, "createdByUserId" TEXT NOT NULL, "updatedByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "email_templates_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_template_variables" ( "id" TEXT NOT NULL, "templateId" TEXT NOT NULL, "key" TEXT NOT NULL, "label" TEXT NOT NULL, "description" TEXT, "type" "EmailTemplateVariableType" NOT NULL DEFAULT 'TEXT', "videoId" INTEGER, "isRequired" BOOLEAN NOT NULL DEFAULT true, "isConditional" BOOLEAN NOT NULL DEFAULT false, "sampleValue" TEXT, "sortOrder" INTEGER NOT NULL DEFAULT 0, CONSTRAINT "email_template_variables_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_template_versions" ( "id" TEXT NOT NULL, "templateId" TEXT NOT NULL, "versionNumber" INTEGER NOT NULL, "subjectLine" TEXT NOT NULL, "htmlContent" TEXT NOT NULL, "textContent" TEXT NOT NULL, "changeNotes" TEXT, "createdByUserId" TEXT NOT NULL, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "email_template_versions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_template_test_logs" ( "id" TEXT NOT NULL, "templateId" TEXT NOT NULL, "recipientEmail" TEXT NOT NULL, "testData" JSONB NOT NULL, "success" BOOLEAN NOT NULL, "errorMessage" TEXT, "messageId" TEXT, "sentByUserId" TEXT NOT NULL, "sentAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "email_template_test_logs_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "videos" ( "id" SERIAL NOT NULL, "path" TEXT NOT NULL, "filename" TEXT NOT NULL, "producer" TEXT, "creator" TEXT, "title" TEXT, "duration_seconds" INTEGER, "quality" TEXT, "orientation" TEXT, "has_audio" BOOLEAN DEFAULT true, "file_size" BIGINT, "file_hash" TEXT, "width" INTEGER, "height" INTEGER, "last_validated" TIMESTAMP(3), "is_valid" BOOLEAN DEFAULT true, "thumbnail_path" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "tags" JSONB, "directory_type" "DirectoryType", "public_view_count" INTEGER, "public_upvote_count" INTEGER, "public_comment_count" INTEGER, "public_completion_count" INTEGER, "public_total_watch_time" INTEGER, "moved_from_public_at" TIMESTAMP(3), "original_filename" TEXT, "original_path" TEXT, "standardized_at" TIMESTAMP(3), "is_published" BOOLEAN NOT NULL DEFAULT false, "published_at" TIMESTAMP(3), "category" TEXT, "is_short" BOOLEAN NOT NULL DEFAULT false, "is_locked" BOOLEAN NOT NULL DEFAULT false, "locked_at" TIMESTAMP(3), "locked_by_id" TEXT, "view_count" INTEGER NOT NULL DEFAULT 0, "upvote_count" INTEGER NOT NULL DEFAULT 0, "comment_count" INTEGER NOT NULL DEFAULT 0, "finish_count" INTEGER NOT NULL DEFAULT 0, "total_watch_time" INTEGER NOT NULL DEFAULT 0, "scheduled_publish_at" TIMESTAMP(3), "scheduled_unpublish_at" TIMESTAMP(3), "unique_viewers" INTEGER NOT NULL DEFAULT 0, "total_watch_time_seconds" INTEGER NOT NULL DEFAULT 0, "average_watch_time_seconds" DECIMAL(10,2) NOT NULL DEFAULT 0, "completion_rate" DECIMAL(5,2) NOT NULL DEFAULT 0, "access_level" TEXT NOT NULL DEFAULT 'free', "position" INTEGER DEFAULT 0, "uploader_id" TEXT, CONSTRAINT "videos_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "compilations" ( "id" SERIAL NOT NULL, "filename" TEXT NOT NULL, "path" TEXT, "duration_seconds" INTEGER, "video_ids" JSONB, "settings" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "compilations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "jobs" ( "id" SERIAL NOT NULL, "type" TEXT NOT NULL, "status" "JobStatus" DEFAULT 'pending', "progress" INTEGER DEFAULT 0, "log" TEXT, "params" JSONB, "started_at" TIMESTAMP(3), "completed_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "resource_category" "ResourceCategory" DEFAULT 'cpu', "vram_required" INTEGER DEFAULT 0, "queue_position" INTEGER, "waiting_reason" TEXT, "priority" INTEGER DEFAULT 5, "pipeline_id" INTEGER, "pipeline_step_id" INTEGER, CONSTRAINT "jobs_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sessions" ( "id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "last_seen_at" TIMESTAMP(3), "ip_address" TEXT, "user_agent" TEXT, "device_type" TEXT, "browser" TEXT, "os" TEXT, "country" TEXT, "country_name" TEXT, "region" TEXT, "city" TEXT, "timezone" TEXT, "latitude" REAL, "longitude" REAL, "user_id" TEXT, "first_seen_at" TIMESTAMP(3), "visit_count" INTEGER DEFAULT 1, CONSTRAINT "sessions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "upvotes" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "upvotes_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "comments" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "user_id" TEXT, "content" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "safety_status" TEXT DEFAULT 'pending', "safety_checked_at" TIMESTAMP(3), "safety_categories" JSONB, "safety_reasoning" TEXT, "is_hidden" BOOLEAN DEFAULT false, "hidden_at" TIMESTAMP(3), "hidden_reason" TEXT, "moderation_notes" TEXT, CONSTRAINT "comments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "views" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "watch_time_seconds" INTEGER DEFAULT 0, "last_updated" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "views_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "auth_tokens" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "token" TEXT NOT NULL, "type" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "auth_tokens_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "session_bans" ( "id" SERIAL NOT NULL, "session_id" TEXT NOT NULL, "reason" TEXT, "banned_by" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "expires_at" TIMESTAMP(3), CONSTRAINT "session_bans_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "comment_moderation" ( "id" SERIAL NOT NULL, "comment_id" INTEGER NOT NULL, "status" TEXT NOT NULL DEFAULT 'pending', "moderated_by" TEXT, "moderated_at" TIMESTAMP(3), "reason" TEXT, CONSTRAINT "comment_moderation_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_verification_tokens" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "token" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "email_verification_tokens_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "password_reset_tokens" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "token" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "used_at" TIMESTAMP(3), CONSTRAINT "password_reset_tokens_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "email_change_tokens" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "new_email" TEXT NOT NULL, "token" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "email_change_tokens_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_achievements" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "achievement_id" TEXT NOT NULL, "unlocked_at" TIMESTAMP(3) NOT NULL, "progress" INTEGER DEFAULT 0, "notified" BOOLEAN DEFAULT false, CONSTRAINT "user_achievements_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_stats" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "total_watch_time_seconds" INTEGER DEFAULT 0, "total_videos_watched" INTEGER DEFAULT 0, "total_upvotes_given" INTEGER DEFAULT 0, "total_comments_made" INTEGER DEFAULT 0, "total_finishes" INTEGER DEFAULT 0, "current_day_streak" INTEGER DEFAULT 0, "longest_day_streak" INTEGER DEFAULT 0, "last_active_date" TEXT, "longest_single_session" INTEGER DEFAULT 0, "categories_completed" JSONB, "night_owl_count" INTEGER DEFAULT 0, "early_bird_count" INTEGER DEFAULT 0, "updated_at" TIMESTAMP(3), CONSTRAINT "user_stats_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_finishes" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "media_id" INTEGER, "session_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "user_finishes_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_reactions" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "media_id" INTEGER NOT NULL, "reaction_type" "ReactionType" NOT NULL, "video_timestamp" INTEGER NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_reactions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "highlight_cooldowns" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "last_generated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "highlight_cooldowns_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_daily_activity" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "activity_date" TEXT NOT NULL, "watch_time_seconds" INTEGER DEFAULT 0, "videos_watched" INTEGER DEFAULT 0, "first_activity_hour" INTEGER, "created_at" TIMESTAMP(3), CONSTRAINT "user_daily_activity_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "chat_thread_read_status" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "media_id" INTEGER NOT NULL, "last_seen_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "chat_thread_read_status_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "app_settings" ( "key" TEXT NOT NULL, "value" TEXT NOT NULL, "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "app_settings_pkey" PRIMARY KEY ("key") ); -- CreateTable CREATE TABLE "rate_limits" ( "id" SERIAL NOT NULL, "key" TEXT NOT NULL, "count" INTEGER NOT NULL DEFAULT 1, "reset_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "rate_limits_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "moderation_word_lists" ( "id" SERIAL NOT NULL, "level" "WordFilterLevel" NOT NULL, "word" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "created_by" TEXT, CONSTRAINT "moderation_word_lists_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "content_reports" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "session_id" TEXT, "user_id" TEXT, "report_type" "ReportType" NOT NULL, "description" TEXT, "status" "ReportStatus" NOT NULL DEFAULT 'pending', "resolved_by" TEXT, "resolved_at" TIMESTAMP(3), "resolution_notes" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "content_reports_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "playlists" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "name" TEXT NOT NULL, "description" TEXT, "is_public" BOOLEAN DEFAULT false, "share_token" TEXT, "thumbnail_media_id" INTEGER, "video_count" INTEGER DEFAULT 0, "total_duration_seconds" INTEGER DEFAULT 0, "view_count" INTEGER DEFAULT 0, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "playlists_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "playlist_videos" ( "id" SERIAL NOT NULL, "playlist_id" INTEGER NOT NULL, "media_id" INTEGER NOT NULL, "position" INTEGER NOT NULL DEFAULT 0, "added_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "playlist_videos_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "featured_playlists" ( "id" SERIAL NOT NULL, "playlist_id" INTEGER NOT NULL, "position" INTEGER NOT NULL DEFAULT 0, "featured_by" TEXT, "featured_at" TIMESTAMP(3), CONSTRAINT "featured_playlists_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "playlist_views" ( "id" SERIAL NOT NULL, "playlist_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "playlist_views_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "ads" ( "id" SERIAL NOT NULL, "type" TEXT NOT NULL, "variant" TEXT, "image_path" TEXT, "link_url" TEXT, "title" TEXT, "subtitle" TEXT, "cta_text" TEXT, "cta_style" TEXT DEFAULT 'primary', "bg_color" TEXT, "icon_emoji" TEXT, "is_system_ad" BOOLEAN NOT NULL DEFAULT false, "frequency" INTEGER NOT NULL DEFAULT 6, "visibility" TEXT NOT NULL DEFAULT 'everyone', "is_active" BOOLEAN DEFAULT true, "position" INTEGER DEFAULT 0, "impression_count" INTEGER DEFAULT 0, "click_count" INTEGER DEFAULT 0, "start_date" TIMESTAMP(3), "end_date" TIMESTAMP(3), "product_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "ads_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "ad_impressions" ( "id" SERIAL NOT NULL, "ad_id" INTEGER NOT NULL, "session_id" TEXT, "user_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "ad_impressions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "ad_clicks" ( "id" SERIAL NOT NULL, "ad_id" INTEGER NOT NULL, "session_id" TEXT, "user_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "ad_clicks_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "friendships" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "friend_id" TEXT NOT NULL, "status" "FriendshipStatus" NOT NULL DEFAULT 'pending', "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "accepted_at" TIMESTAMP(3), CONSTRAINT "friendships_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_blocks" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "blocked_user_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_blocks_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "pokes" ( "id" SERIAL NOT NULL, "from_user_id" TEXT NOT NULL, "to_user_id" TEXT NOT NULL, "is_read" BOOLEAN DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "pokes_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_recommendations" ( "id" SERIAL NOT NULL, "from_user_id" TEXT NOT NULL, "to_user_id" TEXT NOT NULL, "media_id" INTEGER NOT NULL, "message" TEXT, "is_read" BOOLEAN DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_recommendations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_presence" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "is_online" BOOLEAN DEFAULT false, "current_media_id" INTEGER, "last_activity_at" TIMESTAMP(3), "last_video_change_at" TIMESTAMP(3), CONSTRAINT "user_presence_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_gallery_images" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "filename" TEXT NOT NULL, "original_filename" TEXT, "position" INTEGER NOT NULL DEFAULT 0, "uploaded_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_gallery_images_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_social_links" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "platform" "SocialPlatform" NOT NULL, "url" TEXT NOT NULL, "display_name" TEXT, "position" INTEGER NOT NULL DEFAULT 0, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_social_links_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "privacy_settings" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "show_online_status" BOOLEAN DEFAULT true, "show_currently_watching" BOOLEAN DEFAULT true, "show_in_friend_activity" BOOLEAN DEFAULT true, "anonymize_public_comments" BOOLEAN DEFAULT false, "hide_public_reactions" BOOLEAN DEFAULT false, "hide_public_finishes" BOOLEAN DEFAULT false, "allow_friend_requests" BOOLEAN DEFAULT true, "close_friends_only_watching" BOOLEAN DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "privacy_settings_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "close_friends" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "close_friend_id" TEXT NOT NULL, "added_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "close_friends_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_uploads" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "filename" TEXT NOT NULL, "original_filename" TEXT, "path" TEXT NOT NULL, "duration_seconds" INTEGER, "quality" TEXT, "orientation" TEXT, "file_size" BIGINT, "thumbnail_path" TEXT, "status" "UserUploadStatus" NOT NULL DEFAULT 'pending', "reviewed_by" TEXT, "reviewed_at" TIMESTAMP(3), "review_notes" TEXT, "public_media_id" INTEGER, "upload_invite_id" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_uploads_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "upload_invites" ( "id" SERIAL NOT NULL, "code" TEXT NOT NULL, "label" TEXT, "created_by" TEXT NOT NULL, "status" "UploadInviteStatus" NOT NULL DEFAULT 'active', "max_uploads" INTEGER, "upload_count" INTEGER NOT NULL DEFAULT 0, "expires_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "upload_invites_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "tag_categories" ( "id" SERIAL NOT NULL, "name" TEXT NOT NULL, "display_order" INTEGER NOT NULL DEFAULT 0, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "tag_categories_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "tags" ( "id" SERIAL NOT NULL, "category_id" INTEGER NOT NULL, "name" TEXT NOT NULL, "display_order" INTEGER NOT NULL DEFAULT 0, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "public_media_tags" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "tag_id" INTEGER NOT NULL, "added_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "public_media_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_upload_suggested_tags" ( "id" SERIAL NOT NULL, "upload_id" INTEGER NOT NULL, "tag_id" INTEGER NOT NULL, "suggested_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_upload_suggested_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_tag_preferences" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "tag_id" INTEGER NOT NULL, "saved_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_tag_preferences_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "public_media_performers" ( "id" SERIAL NOT NULL, "media_id" INTEGER NOT NULL, "performer_id" INTEGER NOT NULL, "added_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "public_media_performers_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_digests" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "job_id" INTEGER, "status" "DigestStatus" NOT NULL DEFAULT 'pending', "progress" INTEGER DEFAULT 0, "frame_count" INTEGER, "config" JSONB, "frame_analyses" JSONB, "transcript" JSONB, "tags" JSONB, "suggested_clips" JSONB, "ad_cut_spec" JSONB, "stage_results" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "started_at" TIMESTAMP(3), "completed_at" TIMESTAMP(3), "error" TEXT, CONSTRAINT "video_digests_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_video_tags" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "category" TEXT NOT NULL, "value" TEXT NOT NULL, "confidence" INTEGER, "source" TEXT DEFAULT 'digest', "evidence" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "digest_video_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_selected_clips" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "clip_type" "ClipType" NOT NULL, "start_time" INTEGER NOT NULL, "end_time" INTEGER NOT NULL, "duration" INTEGER NOT NULL, "reason" TEXT, "interest_score" INTEGER, "position" TEXT, "transcript_hint" TEXT, "tags" JSONB, "source" "ClipSource" NOT NULL DEFAULT 'machine', "is_included" INTEGER NOT NULL DEFAULT 1, "is_hook" INTEGER NOT NULL DEFAULT 0, "sequence_order" INTEGER NOT NULL DEFAULT 0, "hook_source_clip_id" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "digest_selected_clips_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_generated_clips" ( "id" SERIAL NOT NULL, "selected_clip_id" INTEGER NOT NULL, "digest_id" INTEGER NOT NULL, "folder_id" INTEGER, "clip_path" TEXT, "gif_path" TEXT, "status" "ClipStatus" NOT NULL DEFAULT 'pending', "error" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "completed_at" TIMESTAMP(3), "published_to_public_media_id" INTEGER, "published_at" TIMESTAMP(3), CONSTRAINT "digest_generated_clips_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_compilations" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "folder_id" INTEGER, "filename" TEXT NOT NULL, "name" TEXT, "path" TEXT NOT NULL, "duration_seconds" INTEGER, "orientation" TEXT, "status" TEXT NOT NULL DEFAULT 'pending', "error" TEXT, "has_captions" INTEGER NOT NULL DEFAULT 0, "caption_style" JSONB, "closing_ad_path" TEXT, "closing_ad_duration" INTEGER, "tags" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "completed_at" TIMESTAMP(3), CONSTRAINT "digest_compilations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_output_folders" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "folder_path" TEXT NOT NULL, "folder_name" TEXT NOT NULL, "folder_type" TEXT NOT NULL DEFAULT 'clips', "clip_count" INTEGER DEFAULT 0, "compilation_count" INTEGER DEFAULT 0, "total_size" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "digest_output_folders_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_generated_scenes" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "folder_id" INTEGER, "scene_number" INTEGER NOT NULL, "scene_path" TEXT, "start_time" REAL NOT NULL, "end_time" REAL NOT NULL, "duration" REAL NOT NULL, "tags" JSONB, "dominant_position" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "published_to_public_media_id" INTEGER, "published_at" TIMESTAMP(3), CONSTRAINT "digest_generated_scenes_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_scene_cuts" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "cuts" JSONB NOT NULL, "scene_count" INTEGER NOT NULL, "duration" REAL NOT NULL, "detector" TEXT NOT NULL DEFAULT 'content', "threshold" REAL NOT NULL DEFAULT 27.0, "transnet_cuts" JSONB, "pyscenedetect_cuts" JSONB, "clip_cuts" JSONB, "merged_cuts" JSONB, "analysis_metadata" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_scene_cuts_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_tag_timeline" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "category" TEXT NOT NULL, "value" TEXT NOT NULL, "start_time" REAL NOT NULL, "end_time" REAL NOT NULL, "confidence" INTEGER, "source" TEXT DEFAULT 'digest', "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_tag_timeline_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_segments" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "segment_type" "SegmentType" NOT NULL, "start_time" REAL NOT NULL, "end_time" REAL NOT NULL, "duration" REAL NOT NULL, "tags" JSONB, "vocal_category" "VocalCategory", "transcript" TEXT, "dominant_position" TEXT, "interest_score" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_segments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_tags" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "category" TEXT NOT NULL, "value" TEXT NOT NULL, "confidence" INTEGER, "source" TEXT DEFAULT 'digest', "evidence" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_suggested_tags" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "category" TEXT NOT NULL, "value" TEXT NOT NULL, "confidence" INTEGER, "evidence" JSONB, "status" "SuggestedTagStatus" NOT NULL DEFAULT 'pending', "mapped_tag_id" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "reviewed_at" TIMESTAMP(3), CONSTRAINT "digest_suggested_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "digest_clip_tags" ( "id" SERIAL NOT NULL, "digest_id" INTEGER NOT NULL, "clip_id" INTEGER NOT NULL, "video_id" INTEGER NOT NULL, "category" TEXT NOT NULL, "value" TEXT NOT NULL, "confidence" INTEGER, "source" TEXT DEFAULT 'clip_analysis', "evidence" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "digest_clip_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "watch_party_sessions" ( "id" SERIAL NOT NULL, "host_user_id" TEXT NOT NULL, "media_id" INTEGER NOT NULL, "status" "WatchPartyStatus" NOT NULL DEFAULT 'active', "invite_code" TEXT NOT NULL, "current_time" INTEGER NOT NULL DEFAULT 0, "is_playing" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "ended_at" TIMESTAMP(3), CONSTRAINT "watch_party_sessions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "watch_party_participants" ( "id" SERIAL NOT NULL, "session_id" INTEGER NOT NULL, "user_id" TEXT NOT NULL, "joined_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "left_at" TIMESTAMP(3), CONSTRAINT "watch_party_participants_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "watch_party_chat_messages" ( "id" SERIAL NOT NULL, "session_id" INTEGER NOT NULL, "user_id" TEXT NOT NULL, "comment_id" INTEGER NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "watch_party_chat_messages_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "watch_party_reactions" ( "id" SERIAL NOT NULL, "session_id" INTEGER NOT NULL, "user_id" TEXT NOT NULL, "reaction_type" "ReactionType" NOT NULL, "video_timestamp" INTEGER NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "watch_party_reactions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "watch_party_invites" ( "id" SERIAL NOT NULL, "session_id" INTEGER NOT NULL, "user_id" TEXT NOT NULL, "invited_by" TEXT NOT NULL, "status" TEXT NOT NULL DEFAULT 'pending', "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "accepted_at" TIMESTAMP(3), CONSTRAINT "watch_party_invites_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "tag_generation_jobs" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "job_id" INTEGER, "status" TEXT NOT NULL DEFAULT 'pending', "progress" INTEGER DEFAULT 0, "generated_tags" JSONB, "raw_response" TEXT, "error" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "started_at" TIMESTAMP(3), "completed_at" TIMESTAMP(3), CONSTRAINT "tag_generation_jobs_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "creators" ( "id" SERIAL NOT NULL, "name" TEXT NOT NULL, "stage_name" TEXT, "performer_gender" TEXT, "face_embedding" JSONB, "reference_image_path" TEXT, "performer_category" TEXT, "status" TEXT NOT NULL DEFAULT 'active', "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "creators_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "performer_faces" ( "id" SERIAL NOT NULL, "performer_id" INTEGER NOT NULL, "source_path" TEXT NOT NULL, "frame_timestamp" REAL, "bbox" JSONB NOT NULL, "embedding" JSONB NOT NULL, "gender" INTEGER NOT NULL, "age" INTEGER NOT NULL, "det_score" REAL NOT NULL, "verified_by_user" BOOLEAN NOT NULL DEFAULT false, "confidence" REAL, "is_reference_image" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "performer_faces_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "performer_discrepancies" ( "id" SERIAL NOT NULL, "video_path" TEXT NOT NULL, "frame_timestamp" REAL NOT NULL, "assigned_performer_id" INTEGER NOT NULL, "detected_performer_id" INTEGER, "similarity" REAL NOT NULL, "face_data" JSONB NOT NULL, "resolution_status" TEXT NOT NULL DEFAULT 'pending', "resolution_action" TEXT, "resolution_notes" TEXT, "resolved_by" TEXT, "resolved_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "performer_discrepancies_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "pipelines" ( "id" SERIAL NOT NULL, "name" TEXT NOT NULL, "description" TEXT, "status" "PipelineStatus" NOT NULL DEFAULT 'draft', "config" JSONB, "template_id" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "started_at" TIMESTAMP(3), "completed_at" TIMESTAMP(3), "error" TEXT, CONSTRAINT "pipelines_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "pipeline_steps" ( "id" SERIAL NOT NULL, "pipeline_id" INTEGER NOT NULL, "step_name" TEXT NOT NULL, "step_type" TEXT NOT NULL, "sequence_order" INTEGER NOT NULL, "status" "PipelineStepStatus" NOT NULL DEFAULT 'pending', "config" JSONB, "inputs" JSONB, "outputs" JSONB, "depends_on" JSONB, "error" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "started_at" TIMESTAMP(3), "completed_at" TIMESTAMP(3), CONSTRAINT "pipeline_steps_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "pipeline_step_events" ( "id" SERIAL NOT NULL, "step_id" INTEGER NOT NULL, "event_type" TEXT NOT NULL, "message" TEXT, "data" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "pipeline_step_events_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "resource_snapshots" ( "id" SERIAL NOT NULL, "timestamp" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "cpu_percent" REAL, "memory_mb" INTEGER, "gpu_percent" REAL, "vram_mb" INTEGER, "disk_usage_mb" INTEGER, "active_jobs" INTEGER, "queued_jobs" INTEGER, "metadata" JSONB, CONSTRAINT "resource_snapshots_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "pipeline_templates" ( "id" SERIAL NOT NULL, "name" TEXT NOT NULL, "description" TEXT, "category" TEXT, "default_config" JSONB, "step_definitions" JSONB NOT NULL, "is_public" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "pipeline_templates_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "subscription_plans" ( "id" SERIAL NOT NULL, "name" TEXT NOT NULL, "price_cad" INTEGER NOT NULL, "duration_days" INTEGER NOT NULL, "features" JSONB, "is_active" BOOLEAN NOT NULL DEFAULT true, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "stripe_product_id" TEXT, "stripe_price_id" TEXT, "stripe_yearly_price_id" TEXT, "yearly_price_cad" INTEGER, "description" TEXT, "tier" INTEGER NOT NULL DEFAULT 0, "display_order" INTEGER NOT NULL DEFAULT 0, "slug" TEXT, "cover_photo" TEXT, "cover_video_id" INTEGER, "rich_description" TEXT, "cta_text" TEXT, "cta_subtext" TEXT, "highlight_plan" BOOLEAN NOT NULL DEFAULT false, CONSTRAINT "subscription_plans_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_subscriptions" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "plan_id" INTEGER NOT NULL, "status" "SubscriptionStatus" NOT NULL DEFAULT 'active', "start_date" TIMESTAMP(3) NOT NULL, "end_date" TIMESTAMP(3) NOT NULL, "cancelled_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "stripe_subscription_id" TEXT, "stripe_customer_id" TEXT, "current_period_end" TIMESTAMP(3), "cancel_at_period_end" BOOLEAN NOT NULL DEFAULT false, CONSTRAINT "user_subscriptions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "invoices" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "subscription_id" INTEGER, "amount_cad" INTEGER NOT NULL, "status" "InvoiceStatus" NOT NULL DEFAULT 'pending', "issued_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "paid_at" TIMESTAMP(3), "due_date" TIMESTAMP(3) NOT NULL, "description" TEXT, "metadata" JSONB, "stripe_invoice_id" TEXT, "invoice_type" TEXT NOT NULL DEFAULT 'subscription', CONSTRAINT "invoices_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "payments" ( "id" SERIAL NOT NULL, "invoice_id" INTEGER NOT NULL, "user_id" TEXT NOT NULL, "amount_cad" INTEGER NOT NULL, "method" "PaymentMethod" NOT NULL, "status" "PaymentStatus" NOT NULL DEFAULT 'pending', "external_id" TEXT, "metadata" JSONB, "processed_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "stripe_payment_intent_id" TEXT, "stripe_checkout_session_id" TEXT, CONSTRAINT "payments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "payment_audit_log" ( "id" SERIAL NOT NULL, "payment_id" INTEGER NOT NULL, "action" TEXT NOT NULL, "old_status" TEXT, "new_status" TEXT, "user_id" TEXT, "metadata" JSONB, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "payment_audit_log_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "products" ( "id" TEXT NOT NULL, "slug" TEXT NOT NULL, "title" TEXT NOT NULL, "description" TEXT, "price_cad" INTEGER NOT NULL, "type" "ProductType" NOT NULL, "stripe_product_id" TEXT, "stripe_price_id" TEXT, "is_active" BOOLEAN NOT NULL DEFAULT true, "image_url" TEXT, "photo_id" INTEGER, "video_id" INTEGER, "gallery_photo_ids" JSONB, "download_url" TEXT, "metadata" JSONB, "max_purchases" INTEGER, "purchase_count" INTEGER NOT NULL DEFAULT 0, "created_by_user_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "products_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "orders" ( "id" TEXT NOT NULL, "user_id" TEXT, "product_id" TEXT, "amount_cad" INTEGER NOT NULL, "status" "OrderStatus" NOT NULL DEFAULT 'PENDING', "stripe_checkout_session_id" TEXT, "stripe_payment_intent_id" TEXT, "order_type" TEXT NOT NULL DEFAULT 'product', "buyer_email" TEXT NOT NULL, "buyer_name" TEXT, "donor_message" TEXT, "is_anonymous" BOOLEAN NOT NULL DEFAULT false, "completed_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, "donation_page_id" TEXT, CONSTRAINT "orders_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "donation_pages" ( "id" TEXT NOT NULL, "slug" TEXT NOT NULL, "title" TEXT NOT NULL, "description" TEXT, "status" "DonationPageStatus" NOT NULL DEFAULT 'DRAFT', "suggestedAmounts" JSONB NOT NULL DEFAULT '[1000, 2500, 5000, 10000]', "minimum_amount" INTEGER NOT NULL DEFAULT 500, "thank_you_message" TEXT NOT NULL DEFAULT 'Thank you for your support!', "cover_photo" TEXT, "cover_video_id" INTEGER, "highlight_page" BOOLEAN NOT NULL DEFAULT false, "show_donor_count" BOOLEAN NOT NULL DEFAULT true, "show_total_raised" BOOLEAN NOT NULL DEFAULT false, "goal_amount" INTEGER, "created_by_user_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "donation_pages_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "payment_settings" ( "id" TEXT NOT NULL, "stripe_secret_key" TEXT NOT NULL DEFAULT '', "stripe_publishable_key" TEXT NOT NULL DEFAULT '', "stripe_webhook_secret" TEXT NOT NULL DEFAULT '', "default_currency" TEXT NOT NULL DEFAULT 'cad', "enable_donations" BOOLEAN NOT NULL DEFAULT true, "donation_suggested_amounts" JSONB NOT NULL DEFAULT '[1000, 2500, 5000, 10000]', "donation_minimum" INTEGER NOT NULL DEFAULT 500, "donation_page_title" TEXT NOT NULL DEFAULT 'Support Our Work', "donation_page_description" TEXT, "thank_you_message" TEXT NOT NULL DEFAULT 'Thank you for your support!', "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "payment_settings_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "notifications" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "type" "NotificationType" NOT NULL, "title" TEXT NOT NULL, "message" TEXT NOT NULL, "metadata" JSONB, "is_read" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "read_at" TIMESTAMP(3), CONSTRAINT "notifications_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "notification_preferences" ( "id" SERIAL NOT NULL, "user_id" TEXT NOT NULL, "enable_friend_requests" BOOLEAN NOT NULL DEFAULT true, "enable_comments" BOOLEAN NOT NULL DEFAULT true, "enable_upload_approvals" BOOLEAN NOT NULL DEFAULT true, "enable_achievements" BOOLEAN NOT NULL DEFAULT true, "enable_system_updates" BOOLEAN NOT NULL DEFAULT true, "email_notifications" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "notification_preferences_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "geo_blocking_rules" ( "id" SERIAL NOT NULL, "country_code" TEXT NOT NULL, "action" TEXT NOT NULL, "reason" TEXT, "is_active" BOOLEAN NOT NULL DEFAULT true, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "geo_blocking_rules_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "published_inbox_files" ( "id" SERIAL NOT NULL, "original_inbox_path" TEXT NOT NULL, "published_to_public_media_id" INTEGER NOT NULL, "published_at" TIMESTAMP(3) NOT NULL, "moved_to_path" TEXT, "metadata_snapshot" JSONB, CONSTRAINT "published_inbox_files_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_ocr_results" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "full_text" TEXT NOT NULL, "structured_data" JSONB, "confidence" REAL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_ocr_results_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_views" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "user_id" TEXT, "ip_address_hash" VARCHAR(64), "user_agent_hash" VARCHAR(64), "referer" TEXT, "watch_time_seconds" INTEGER NOT NULL DEFAULT 0, "completed" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "video_views_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_events" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "view_id" INTEGER, "event_type" VARCHAR(50) NOT NULL, "timestamp" DECIMAL(10,2) NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_events_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "video_schedule_history" ( "id" SERIAL NOT NULL, "video_id" INTEGER NOT NULL, "action" VARCHAR(20) NOT NULL, "scheduled_for" TIMESTAMP(3) NOT NULL, "executed_at" TIMESTAMP(3), "status" VARCHAR(20) NOT NULL, "error" TEXT, "scheduled_by_user_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "video_schedule_history_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "docs_page_views" ( "id" TEXT NOT NULL, "path" TEXT NOT NULL, "referrer" TEXT, "sessionHash" TEXT, "userAgent" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "docs_page_views_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photos" ( "id" SERIAL NOT NULL, "path" TEXT NOT NULL, "filename" TEXT NOT NULL, "original_filename" TEXT, "title" TEXT, "description" TEXT, "producer" TEXT, "creator" TEXT, "tags" JSONB, "width" INTEGER, "height" INTEGER, "orientation" TEXT, "file_size" BIGINT, "format" TEXT, "color_space" TEXT, "has_alpha" BOOLEAN DEFAULT false, "dpi" INTEGER, "camera_make" TEXT, "camera_model" TEXT, "focal_length" TEXT, "aperture" TEXT, "shutter_speed" TEXT, "iso" INTEGER, "taken_at" TIMESTAMP(3), "gps_latitude" REAL, "gps_longitude" REAL, "thumbnail_path" TEXT, "medium_path" TEXT, "large_path" TEXT, "webp_path" TEXT, "is_published" BOOLEAN NOT NULL DEFAULT false, "published_at" TIMESTAMP(3), "category" TEXT, "access_level" TEXT NOT NULL DEFAULT 'free', "position" INTEGER DEFAULT 0, "is_locked" BOOLEAN NOT NULL DEFAULT false, "scheduled_publish_at" TIMESTAMP(3), "scheduled_unpublish_at" TIMESTAMP(3), "view_count" INTEGER NOT NULL DEFAULT 0, "upvote_count" INTEGER NOT NULL DEFAULT 0, "comment_count" INTEGER NOT NULL DEFAULT 0, "album_id" INTEGER, "album_position" INTEGER DEFAULT 0, "uploader_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "photos_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photo_albums" ( "id" SERIAL NOT NULL, "title" TEXT NOT NULL, "description" TEXT, "cover_photo_id" INTEGER, "is_published" BOOLEAN NOT NULL DEFAULT false, "published_at" TIMESTAMP(3), "category" TEXT, "access_level" TEXT NOT NULL DEFAULT 'free', "position" INTEGER DEFAULT 0, "is_locked" BOOLEAN NOT NULL DEFAULT false, "view_count" INTEGER NOT NULL DEFAULT 0, "upvote_count" INTEGER NOT NULL DEFAULT 0, "photo_count" INTEGER NOT NULL DEFAULT 0, "scheduled_publish_at" TIMESTAMP(3), "scheduled_unpublish_at" TIMESTAMP(3), "creator_id" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "photo_albums_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photo_upvotes" ( "id" SERIAL NOT NULL, "photo_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "photo_upvotes_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photo_comments" ( "id" SERIAL NOT NULL, "photo_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "user_id" TEXT, "content" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "safety_status" TEXT NOT NULL DEFAULT 'approved', "is_hidden" BOOLEAN NOT NULL DEFAULT false, CONSTRAINT "photo_comments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photo_views" ( "id" SERIAL NOT NULL, "photo_id" INTEGER NOT NULL, "session_id" TEXT, "user_id" TEXT, "ip_address_hash" TEXT, "viewed_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "photo_views_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "photo_reactions" ( "id" SERIAL NOT NULL, "photo_id" INTEGER NOT NULL, "session_id" TEXT NOT NULL, "reaction_type" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "photo_reactions_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "docs_comments" ( "id" TEXT NOT NULL, "pagePath" TEXT NOT NULL, "giteaIssueNumber" INTEGER NOT NULL, "giteaCommentId" BIGINT NOT NULL, "authorName" TEXT NOT NULL, "authorEmail" TEXT, "status" "DocsCommentStatus" NOT NULL DEFAULT 'PENDING', "reviewedAt" TIMESTAMP(3), "reviewedBy" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "docs_comments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_contact_lists" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "originalFilename" TEXT, "totalContacts" INTEGER NOT NULL DEFAULT 0, "status" "SmsContactListStatus" NOT NULL DEFAULT 'ACTIVE', "createdByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "sms_contact_lists_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_contact_list_entries" ( "id" TEXT NOT NULL, "listId" TEXT NOT NULL, "phone" TEXT NOT NULL, "name" TEXT, "email" TEXT, "customFields" JSONB, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "sms_contact_list_entries_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_campaigns" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "messageTemplate" TEXT NOT NULL, "status" "SmsCampaignStatus" NOT NULL DEFAULT 'DRAFT', "totalRecipients" INTEGER NOT NULL DEFAULT 0, "totalSent" INTEGER NOT NULL DEFAULT 0, "totalFailed" INTEGER NOT NULL DEFAULT 0, "totalResponded" INTEGER NOT NULL DEFAULT 0, "delayBetweenMs" INTEGER NOT NULL DEFAULT 3000, "startedAt" TIMESTAMP(3), "completedAt" TIMESTAMP(3), "contactListId" TEXT NOT NULL, "advocacyCampaignId" TEXT, "createdByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "sms_campaigns_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_campaign_recipients" ( "id" TEXT NOT NULL, "campaignId" TEXT NOT NULL, "phone" TEXT NOT NULL, "name" TEXT, "status" "SmsMessageStatus" NOT NULL DEFAULT 'PENDING', "sentAt" TIMESTAMP(3), "errorMessage" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "sms_campaign_recipients_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_messages" ( "id" TEXT NOT NULL, "phone" TEXT NOT NULL, "message" TEXT NOT NULL, "direction" "SmsMessageDirection" NOT NULL, "status" "SmsMessageStatus" NOT NULL DEFAULT 'PENDING', "connectionType" TEXT, "campaignId" TEXT, "conversationId" TEXT, "responseType" "SmsResponseType", "isRead" BOOLEAN NOT NULL DEFAULT false, "sentAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "sms_messages_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_conversations" ( "id" TEXT NOT NULL, "phone" TEXT NOT NULL, "contactName" TEXT, "campaignId" TEXT, "status" "SmsConversationStatus" NOT NULL DEFAULT 'ACTIVE', "totalMessages" INTEGER NOT NULL DEFAULT 0, "totalResponses" INTEGER NOT NULL DEFAULT 0, "unreadCount" INTEGER NOT NULL DEFAULT 0, "lastMessageAt" TIMESTAMP(3), "lastResponseAt" TIMESTAMP(3), "notes" TEXT, "tags" JSONB, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "sms_conversations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_message_templates" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "template" TEXT NOT NULL, "description" TEXT, "category" TEXT, "isFavorite" BOOLEAN NOT NULL DEFAULT false, "usageCount" INTEGER NOT NULL DEFAULT 0, "createdByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "sms_message_templates_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "sms_device_status" ( "id" TEXT NOT NULL, "isConnected" BOOLEAN NOT NULL DEFAULT false, "connectionType" TEXT, "batteryLevel" INTEGER, "batteryStatus" TEXT, "totalSent" INTEGER NOT NULL DEFAULT 0, "lastCheckedAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "sms_device_status_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contacts" ( "id" TEXT NOT NULL, "displayName" TEXT NOT NULL, "firstName" TEXT, "lastName" TEXT, "email" TEXT, "phone" TEXT, "tags" JSONB NOT NULL DEFAULT '[]', "notes" TEXT, "supportLevel" "SupportLevel", "signRequested" BOOLEAN NOT NULL DEFAULT false, "emailOptOut" BOOLEAN NOT NULL DEFAULT false, "smsOptOut" BOOLEAN NOT NULL DEFAULT false, "doNotContact" BOOLEAN NOT NULL DEFAULT false, "profileToken" TEXT, "profileTokenExpiresAt" TIMESTAMP(3), "profilePasswordHash" TEXT, "coverPhotoPath" TEXT, "lastSelfEditAt" TIMESTAMP(3), "primarySource" "ContactSource" NOT NULL DEFAULT 'MANUAL', "userId" TEXT, "mergedIntoId" TEXT, "createdByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "contacts_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "crm_tags" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "slug" TEXT NOT NULL, "description" TEXT, "color" TEXT, "listmonkListId" INTEGER, "contactCount" INTEGER NOT NULL DEFAULT 0, "createdByUserId" TEXT, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updatedAt" TIMESTAMP(3) NOT NULL, CONSTRAINT "crm_tags_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contact_addresses" ( "id" TEXT NOT NULL, "contactId" TEXT NOT NULL, "addressId" TEXT NOT NULL, "isPrimary" BOOLEAN NOT NULL DEFAULT false, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "contact_addresses_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contact_emails" ( "id" TEXT NOT NULL, "contactId" TEXT NOT NULL, "email" TEXT NOT NULL, "label" TEXT, "isPrimary" BOOLEAN NOT NULL DEFAULT false, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "contact_emails_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contact_phones" ( "id" TEXT NOT NULL, "contactId" TEXT NOT NULL, "phone" TEXT NOT NULL, "label" TEXT, "isPrimary" BOOLEAN NOT NULL DEFAULT false, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "contact_phones_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contact_connections" ( "id" TEXT NOT NULL, "fromContactId" TEXT NOT NULL, "toContactId" TEXT NOT NULL, "type" "ConnectionType" NOT NULL, "label" TEXT, "notes" TEXT, "isBidirectional" BOOLEAN NOT NULL DEFAULT true, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "contact_connections_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "contact_activities" ( "id" TEXT NOT NULL, "contactId" TEXT NOT NULL, "type" "ContactActivityType" NOT NULL, "title" TEXT NOT NULL, "description" TEXT, "metadata" JSONB, "occurredAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "contact_activities_pkey" PRIMARY KEY ("id") ); -- CreateIndex CREATE UNIQUE INDEX "addresses_addrGuid_key" ON "addresses"("addrGuid"); -- CreateIndex CREATE INDEX "addresses_locationId_idx" ON "addresses"("locationId"); -- CreateIndex CREATE INDEX "addresses_locationId_id_idx" ON "addresses"("locationId", "id"); -- CreateIndex CREATE INDEX "addresses_locationId_unitNumber_idx" ON "addresses"("locationId", "unitNumber"); -- CreateIndex CREATE INDEX "location_history_locationId_idx" ON "location_history"("locationId"); -- CreateIndex CREATE INDEX "location_history_userId_idx" ON "location_history"("userId"); -- CreateIndex CREATE INDEX "location_history_createdAt_idx" ON "location_history"("createdAt"); -- CreateIndex CREATE INDEX "shift_series_cutId_idx" ON "shift_series"("cutId"); -- CreateIndex CREATE UNIQUE INDEX "email_templates_key_key" ON "email_templates"("key"); -- CreateIndex CREATE INDEX "email_templates_category_idx" ON "email_templates"("category"); -- CreateIndex CREATE INDEX "email_templates_isActive_idx" ON "email_templates"("isActive"); -- CreateIndex CREATE INDEX "email_template_variables_templateId_idx" ON "email_template_variables"("templateId"); -- CreateIndex CREATE INDEX "email_template_variables_type_idx" ON "email_template_variables"("type"); -- CreateIndex CREATE UNIQUE INDEX "email_template_variables_templateId_key_key" ON "email_template_variables"("templateId", "key"); -- CreateIndex CREATE INDEX "email_template_versions_templateId_createdAt_idx" ON "email_template_versions"("templateId", "createdAt" DESC); -- CreateIndex CREATE UNIQUE INDEX "email_template_versions_templateId_versionNumber_key" ON "email_template_versions"("templateId", "versionNumber"); -- CreateIndex CREATE INDEX "email_template_test_logs_templateId_sentAt_idx" ON "email_template_test_logs"("templateId", "sentAt" DESC); -- CreateIndex CREATE UNIQUE INDEX "videos_path_key" ON "videos"("path"); -- CreateIndex CREATE INDEX "idx_orientation" ON "videos"("orientation"); -- CreateIndex CREATE INDEX "idx_producer" ON "videos"("producer"); -- CreateIndex CREATE INDEX "idx_is_valid" ON "videos"("is_valid"); -- CreateIndex CREATE INDEX "idx_directory_type" ON "videos"("directory_type"); -- CreateIndex CREATE INDEX "idx_videos_fingerprint" ON "videos"("duration_seconds", "file_size", "width", "height"); -- CreateIndex CREATE INDEX "idx_videos_directory_valid_orientation" ON "videos"("directory_type", "is_valid", "orientation"); -- CreateIndex CREATE INDEX "idx_videos_published_locked" ON "videos"("is_published", "is_locked"); -- CreateIndex CREATE INDEX "idx_videos_category_published" ON "videos"("category", "is_published"); -- CreateIndex CREATE INDEX "idx_videos_short_published" ON "videos"("is_short", "is_published", "is_locked"); -- CreateIndex CREATE INDEX "idx_videos_uploader" ON "videos"("uploader_id"); -- CreateIndex CREATE INDEX "idx_jobs_queue" ON "jobs"("status", "priority", "created_at"); -- CreateIndex CREATE INDEX "idx_jobs_resource" ON "jobs"("resource_category", "status"); -- CreateIndex CREATE INDEX "idx_jobs_pipeline" ON "jobs"("pipeline_id"); -- CreateIndex CREATE INDEX "idx_sessions_user_id" ON "sessions"("user_id"); -- CreateIndex CREATE INDEX "idx_sessions_country" ON "sessions"("country"); -- CreateIndex CREATE INDEX "idx_upvotes_unique" ON "upvotes"("media_id", "session_id"); -- CreateIndex CREATE INDEX "idx_upvotes_media" ON "upvotes"("media_id"); -- CreateIndex CREATE INDEX "idx_comments_media" ON "comments"("media_id"); -- CreateIndex CREATE INDEX "idx_comments_session" ON "comments"("session_id"); -- CreateIndex CREATE INDEX "idx_comments_user" ON "comments"("user_id"); -- CreateIndex CREATE INDEX "idx_comments_safety_status" ON "comments"("safety_status"); -- CreateIndex CREATE INDEX "idx_comments_is_hidden" ON "comments"("is_hidden"); -- CreateIndex CREATE INDEX "idx_views_unique" ON "views"("media_id", "session_id"); -- CreateIndex CREATE INDEX "idx_views_media" ON "views"("media_id"); -- CreateIndex CREATE UNIQUE INDEX "auth_tokens_token_key" ON "auth_tokens"("token"); -- CreateIndex CREATE INDEX "idx_auth_tokens_token" ON "auth_tokens"("token"); -- CreateIndex CREATE INDEX "idx_auth_tokens_user" ON "auth_tokens"("user_id"); -- CreateIndex CREATE INDEX "idx_session_bans_session" ON "session_bans"("session_id"); -- CreateIndex CREATE UNIQUE INDEX "comment_moderation_comment_id_key" ON "comment_moderation"("comment_id"); -- CreateIndex CREATE INDEX "idx_comment_moderation_comment" ON "comment_moderation"("comment_id"); -- CreateIndex CREATE INDEX "idx_comment_moderation_status" ON "comment_moderation"("status"); -- CreateIndex CREATE UNIQUE INDEX "email_verification_tokens_token_key" ON "email_verification_tokens"("token"); -- CreateIndex CREATE INDEX "idx_email_verification_tokens_token" ON "email_verification_tokens"("token"); -- CreateIndex CREATE INDEX "idx_email_verification_tokens_user" ON "email_verification_tokens"("user_id"); -- CreateIndex CREATE UNIQUE INDEX "password_reset_tokens_token_key" ON "password_reset_tokens"("token"); -- CreateIndex CREATE INDEX "idx_password_reset_tokens_token" ON "password_reset_tokens"("token"); -- CreateIndex CREATE INDEX "idx_password_reset_tokens_user" ON "password_reset_tokens"("user_id"); -- CreateIndex CREATE UNIQUE INDEX "email_change_tokens_token_key" ON "email_change_tokens"("token"); -- CreateIndex CREATE INDEX "idx_email_change_tokens_token" ON "email_change_tokens"("token"); -- CreateIndex CREATE INDEX "idx_email_change_tokens_user" ON "email_change_tokens"("user_id"); -- CreateIndex CREATE INDEX "idx_user_achievements_user" ON "user_achievements"("user_id"); -- CreateIndex CREATE UNIQUE INDEX "idx_user_achievements_unique" ON "user_achievements"("user_id", "achievement_id"); -- CreateIndex CREATE UNIQUE INDEX "user_stats_user_id_key" ON "user_stats"("user_id"); -- CreateIndex CREATE INDEX "idx_user_finishes_user" ON "user_finishes"("user_id"); -- CreateIndex CREATE INDEX "idx_user_finishes_date" ON "user_finishes"("created_at"); -- CreateIndex CREATE INDEX "idx_video_reactions_user_media_type" ON "video_reactions"("user_id", "media_id", "reaction_type"); -- CreateIndex CREATE INDEX "idx_video_reactions_media_timestamp" ON "video_reactions"("media_id", "video_timestamp"); -- CreateIndex CREATE INDEX "idx_video_reactions_media" ON "video_reactions"("media_id"); -- CreateIndex CREATE INDEX "idx_video_reactions_created" ON "video_reactions"("created_at"); -- CreateIndex CREATE INDEX "idx_highlight_cooldowns_user" ON "highlight_cooldowns"("user_id"); -- CreateIndex CREATE INDEX "idx_user_daily_activity_unique" ON "user_daily_activity"("user_id", "activity_date"); -- CreateIndex CREATE INDEX "idx_chat_thread_read_unique" ON "chat_thread_read_status"("user_id", "media_id"); -- CreateIndex CREATE INDEX "idx_chat_thread_read_user" ON "chat_thread_read_status"("user_id"); -- CreateIndex CREATE UNIQUE INDEX "rate_limits_key_key" ON "rate_limits"("key"); -- CreateIndex CREATE INDEX "idx_rate_limits_reset_at" ON "rate_limits"("reset_at"); -- CreateIndex CREATE UNIQUE INDEX "idx_rate_limits_key" ON "rate_limits"("key"); -- CreateIndex CREATE INDEX "idx_moderation_word_lists_level" ON "moderation_word_lists"("level"); -- CreateIndex CREATE INDEX "idx_moderation_word_lists_word" ON "moderation_word_lists"("word"); -- CreateIndex CREATE INDEX "idx_content_reports_media" ON "content_reports"("media_id"); -- CreateIndex CREATE INDEX "idx_content_reports_status" ON "content_reports"("status"); -- CreateIndex CREATE INDEX "idx_content_reports_session" ON "content_reports"("session_id"); -- CreateIndex CREATE INDEX "idx_content_reports_created" ON "content_reports"("created_at"); -- CreateIndex CREATE UNIQUE INDEX "playlists_share_token_key" ON "playlists"("share_token"); -- CreateIndex CREATE INDEX "idx_playlists_user" ON "playlists"("user_id"); -- CreateIndex CREATE INDEX "idx_playlists_public" ON "playlists"("is_public"); -- CreateIndex CREATE INDEX "idx_playlists_share_token" ON "playlists"("share_token"); -- CreateIndex CREATE UNIQUE INDEX "idx_playlists_user_name" ON "playlists"("user_id", "name"); -- CreateIndex CREATE INDEX "idx_playlist_videos_playlist" ON "playlist_videos"("playlist_id"); -- CreateIndex CREATE INDEX "idx_playlist_videos_media" ON "playlist_videos"("media_id"); -- CreateIndex CREATE INDEX "idx_playlist_videos_unique" ON "playlist_videos"("playlist_id", "media_id"); -- CreateIndex CREATE UNIQUE INDEX "featured_playlists_playlist_id_key" ON "featured_playlists"("playlist_id"); -- CreateIndex CREATE INDEX "idx_featured_playlists_position" ON "featured_playlists"("position"); -- CreateIndex CREATE INDEX "idx_playlist_views_playlist" ON "playlist_views"("playlist_id"); -- CreateIndex CREATE INDEX "idx_playlist_views_unique" ON "playlist_views"("playlist_id", "session_id"); -- CreateIndex CREATE UNIQUE INDEX "ads_product_id_key" ON "ads"("product_id"); -- CreateIndex CREATE INDEX "idx_ads_type" ON "ads"("type"); -- CreateIndex CREATE INDEX "idx_ads_is_active" ON "ads"("is_active"); -- CreateIndex CREATE INDEX "idx_ads_visibility" ON "ads"("visibility"); -- CreateIndex CREATE INDEX "idx_ad_impressions_ad" ON "ad_impressions"("ad_id"); -- CreateIndex CREATE INDEX "idx_ad_impressions_session" ON "ad_impressions"("session_id"); -- CreateIndex CREATE INDEX "idx_ad_impressions_date" ON "ad_impressions"("created_at"); -- CreateIndex CREATE INDEX "idx_ad_clicks_ad" ON "ad_clicks"("ad_id"); -- CreateIndex CREATE INDEX "idx_ad_clicks_session" ON "ad_clicks"("session_id"); -- CreateIndex CREATE INDEX "idx_ad_clicks_date" ON "ad_clicks"("created_at"); -- CreateIndex CREATE INDEX "idx_friendships_user_friend" ON "friendships"("user_id", "friend_id"); -- CreateIndex CREATE INDEX "idx_friendships_user" ON "friendships"("user_id"); -- CreateIndex CREATE INDEX "idx_friendships_friend" ON "friendships"("friend_id"); -- CreateIndex CREATE INDEX "idx_friendships_status" ON "friendships"("status"); -- CreateIndex CREATE INDEX "idx_user_blocks_unique" ON "user_blocks"("user_id", "blocked_user_id"); -- CreateIndex CREATE INDEX "idx_user_blocks_user" ON "user_blocks"("user_id"); -- CreateIndex CREATE INDEX "idx_pokes_to_user" ON "pokes"("to_user_id"); -- CreateIndex CREATE INDEX "idx_pokes_from_user" ON "pokes"("from_user_id"); -- CreateIndex CREATE INDEX "idx_video_recommendations_to_user" ON "video_recommendations"("to_user_id"); -- CreateIndex CREATE INDEX "idx_video_recommendations_from_user" ON "video_recommendations"("from_user_id"); -- CreateIndex CREATE INDEX "idx_video_recommendations_media" ON "video_recommendations"("media_id"); -- CreateIndex CREATE UNIQUE INDEX "user_presence_user_id_key" ON "user_presence"("user_id"); -- CreateIndex CREATE INDEX "idx_user_presence_online" ON "user_presence"("is_online"); -- CreateIndex CREATE INDEX "idx_user_presence_user" ON "user_presence"("user_id"); -- CreateIndex CREATE INDEX "idx_user_gallery_user" ON "user_gallery_images"("user_id"); -- CreateIndex CREATE INDEX "idx_user_gallery_position" ON "user_gallery_images"("user_id", "position"); -- CreateIndex CREATE INDEX "idx_user_social_links_user" ON "user_social_links"("user_id"); -- CreateIndex CREATE INDEX "idx_user_social_links_position" ON "user_social_links"("user_id", "position"); -- CreateIndex CREATE UNIQUE INDEX "privacy_settings_user_id_key" ON "privacy_settings"("user_id"); -- CreateIndex CREATE INDEX "idx_privacy_settings_user" ON "privacy_settings"("user_id"); -- CreateIndex CREATE INDEX "idx_close_friends_user" ON "close_friends"("user_id"); -- CreateIndex CREATE UNIQUE INDEX "idx_close_friends_unique" ON "close_friends"("user_id", "close_friend_id"); -- CreateIndex CREATE INDEX "idx_user_uploads_user" ON "user_uploads"("user_id"); -- CreateIndex CREATE INDEX "idx_user_uploads_status" ON "user_uploads"("status"); -- CreateIndex CREATE INDEX "idx_user_uploads_created" ON "user_uploads"("created_at"); -- CreateIndex CREATE INDEX "idx_user_uploads_invite" ON "user_uploads"("upload_invite_id"); -- CreateIndex CREATE UNIQUE INDEX "upload_invites_code_key" ON "upload_invites"("code"); -- CreateIndex CREATE INDEX "idx_upload_invites_code" ON "upload_invites"("code"); -- CreateIndex CREATE INDEX "idx_upload_invites_status" ON "upload_invites"("status"); -- CreateIndex CREATE INDEX "idx_upload_invites_created_by" ON "upload_invites"("created_by"); -- CreateIndex CREATE UNIQUE INDEX "tag_categories_name_key" ON "tag_categories"("name"); -- CreateIndex CREATE INDEX "idx_tag_categories_display_order" ON "tag_categories"("display_order"); -- CreateIndex CREATE INDEX "idx_tags_category" ON "tags"("category_id"); -- CreateIndex CREATE INDEX "idx_tags_display_order" ON "tags"("display_order"); -- CreateIndex CREATE INDEX "idx_tags_unique_name" ON "tags"("category_id", "name"); -- CreateIndex CREATE INDEX "idx_public_media_tags_media" ON "public_media_tags"("media_id"); -- CreateIndex CREATE INDEX "idx_public_media_tags_tag" ON "public_media_tags"("tag_id"); -- CreateIndex CREATE INDEX "idx_public_media_tags_unique" ON "public_media_tags"("media_id", "tag_id"); -- CreateIndex CREATE INDEX "idx_user_upload_suggested_tags_upload" ON "user_upload_suggested_tags"("upload_id"); -- CreateIndex CREATE INDEX "idx_user_upload_suggested_tags_tag" ON "user_upload_suggested_tags"("tag_id"); -- CreateIndex CREATE INDEX "idx_user_upload_suggested_tags_unique" ON "user_upload_suggested_tags"("upload_id", "tag_id"); -- CreateIndex CREATE INDEX "idx_user_tag_preferences_user" ON "user_tag_preferences"("user_id"); -- CreateIndex CREATE INDEX "idx_user_tag_preferences_tag" ON "user_tag_preferences"("tag_id"); -- CreateIndex CREATE INDEX "idx_user_tag_preferences_unique" ON "user_tag_preferences"("user_id", "tag_id"); -- CreateIndex CREATE INDEX "idx_public_media_performers_media" ON "public_media_performers"("media_id"); -- CreateIndex CREATE INDEX "idx_public_media_performers_performer" ON "public_media_performers"("performer_id"); -- CreateIndex CREATE UNIQUE INDEX "idx_public_media_performers_unique" ON "public_media_performers"("media_id", "performer_id"); -- CreateIndex CREATE UNIQUE INDEX "video_digests_job_id_key" ON "video_digests"("job_id"); -- CreateIndex CREATE INDEX "idx_video_digests_video" ON "video_digests"("video_id"); -- CreateIndex CREATE INDEX "idx_video_digests_status" ON "video_digests"("status"); -- CreateIndex CREATE INDEX "idx_video_digests_created" ON "video_digests"("created_at"); -- CreateIndex CREATE INDEX "idx_digest_video_tags_digest" ON "digest_video_tags"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_video_tags_video" ON "digest_video_tags"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_video_tags_category" ON "digest_video_tags"("category"); -- CreateIndex CREATE INDEX "idx_digest_video_tags_value" ON "digest_video_tags"("value"); -- CreateIndex CREATE INDEX "idx_digest_video_tags_cat_val" ON "digest_video_tags"("category", "value"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_digest" ON "digest_selected_clips"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_video" ON "digest_selected_clips"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_type" ON "digest_selected_clips"("clip_type"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_source" ON "digest_selected_clips"("source"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_sequence" ON "digest_selected_clips"("sequence_order"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_is_hook" ON "digest_selected_clips"("is_hook"); -- CreateIndex CREATE INDEX "idx_digest_selected_clips_hook_source" ON "digest_selected_clips"("hook_source_clip_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_clips_selected" ON "digest_generated_clips"("selected_clip_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_clips_digest" ON "digest_generated_clips"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_clips_status" ON "digest_generated_clips"("status"); -- CreateIndex CREATE INDEX "idx_digest_generated_clips_folder" ON "digest_generated_clips"("folder_id"); -- CreateIndex CREATE INDEX "idx_digest_compilations_digest" ON "digest_compilations"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_compilations_video" ON "digest_compilations"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_compilations_status" ON "digest_compilations"("status"); -- CreateIndex CREATE INDEX "idx_digest_compilations_folder" ON "digest_compilations"("folder_id"); -- CreateIndex CREATE INDEX "idx_digest_output_folders_digest" ON "digest_output_folders"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_output_folders_video" ON "digest_output_folders"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_output_folders_path" ON "digest_output_folders"("folder_path"); -- CreateIndex CREATE INDEX "idx_digest_generated_scenes_digest" ON "digest_generated_scenes"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_scenes_video" ON "digest_generated_scenes"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_scenes_folder" ON "digest_generated_scenes"("folder_id"); -- CreateIndex CREATE INDEX "idx_digest_generated_scenes_path" ON "digest_generated_scenes"("scene_path"); -- CreateIndex CREATE INDEX "idx_video_scene_cuts_video" ON "video_scene_cuts"("video_id"); -- CreateIndex CREATE INDEX "idx_video_scene_cuts_detector" ON "video_scene_cuts"("detector"); -- CreateIndex CREATE INDEX "idx_video_tag_timeline_video" ON "video_tag_timeline"("video_id"); -- CreateIndex CREATE INDEX "idx_video_tag_timeline_category" ON "video_tag_timeline"("category"); -- CreateIndex CREATE INDEX "idx_video_tag_timeline_value" ON "video_tag_timeline"("value"); -- CreateIndex CREATE INDEX "idx_video_tag_timeline_cat_val" ON "video_tag_timeline"("category", "value"); -- CreateIndex CREATE INDEX "idx_video_tag_timeline_time" ON "video_tag_timeline"("video_id", "start_time"); -- CreateIndex CREATE INDEX "idx_video_segments_video" ON "video_segments"("video_id"); -- CreateIndex CREATE INDEX "idx_video_segments_type" ON "video_segments"("segment_type"); -- CreateIndex CREATE INDEX "idx_video_segments_vocal_category" ON "video_segments"("vocal_category"); -- CreateIndex CREATE INDEX "idx_video_segments_time" ON "video_segments"("video_id", "start_time"); -- CreateIndex CREATE INDEX "idx_video_tags_video" ON "video_tags"("video_id"); -- CreateIndex CREATE INDEX "idx_video_tags_category" ON "video_tags"("category"); -- CreateIndex CREATE INDEX "idx_video_tags_value" ON "video_tags"("value"); -- CreateIndex CREATE INDEX "idx_video_tags_cat_val" ON "video_tags"("category", "value"); -- CreateIndex CREATE INDEX "idx_digest_suggested_tags_digest" ON "digest_suggested_tags"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_suggested_tags_status" ON "digest_suggested_tags"("status"); -- CreateIndex CREATE INDEX "idx_digest_suggested_tags_category" ON "digest_suggested_tags"("category"); -- CreateIndex CREATE INDEX "idx_digest_suggested_tags_mapped" ON "digest_suggested_tags"("mapped_tag_id"); -- CreateIndex CREATE INDEX "idx_digest_clip_tags_digest" ON "digest_clip_tags"("digest_id"); -- CreateIndex CREATE INDEX "idx_digest_clip_tags_clip" ON "digest_clip_tags"("clip_id"); -- CreateIndex CREATE INDEX "idx_digest_clip_tags_video" ON "digest_clip_tags"("video_id"); -- CreateIndex CREATE INDEX "idx_digest_clip_tags_category" ON "digest_clip_tags"("category"); -- CreateIndex CREATE INDEX "idx_digest_clip_tags_value" ON "digest_clip_tags"("value"); -- CreateIndex CREATE UNIQUE INDEX "watch_party_sessions_invite_code_key" ON "watch_party_sessions"("invite_code"); -- CreateIndex CREATE INDEX "idx_watch_party_sessions_host" ON "watch_party_sessions"("host_user_id"); -- CreateIndex CREATE INDEX "idx_watch_party_sessions_media" ON "watch_party_sessions"("media_id"); -- CreateIndex CREATE INDEX "idx_watch_party_sessions_status" ON "watch_party_sessions"("status"); -- CreateIndex CREATE INDEX "idx_watch_party_sessions_invite" ON "watch_party_sessions"("invite_code"); -- CreateIndex CREATE INDEX "idx_watch_party_participants_session" ON "watch_party_participants"("session_id"); -- CreateIndex CREATE INDEX "idx_watch_party_participants_user" ON "watch_party_participants"("user_id"); -- CreateIndex CREATE INDEX "idx_watch_party_chat_session" ON "watch_party_chat_messages"("session_id"); -- CreateIndex CREATE INDEX "idx_watch_party_chat_user" ON "watch_party_chat_messages"("user_id"); -- CreateIndex CREATE INDEX "idx_watch_party_reactions_session" ON "watch_party_reactions"("session_id"); -- CreateIndex CREATE INDEX "idx_watch_party_reactions_user" ON "watch_party_reactions"("user_id"); -- CreateIndex CREATE INDEX "idx_watch_party_invites_session" ON "watch_party_invites"("session_id"); -- CreateIndex CREATE INDEX "idx_watch_party_invites_user" ON "watch_party_invites"("user_id"); -- CreateIndex CREATE INDEX "idx_tag_generation_jobs_video" ON "tag_generation_jobs"("video_id"); -- CreateIndex CREATE INDEX "idx_tag_generation_jobs_status" ON "tag_generation_jobs"("status"); -- CreateIndex CREATE UNIQUE INDEX "creators_name_key" ON "creators"("name"); -- CreateIndex CREATE INDEX "idx_creators_name" ON "creators"("name"); -- CreateIndex CREATE INDEX "idx_creators_category" ON "creators"("performer_category"); -- CreateIndex CREATE INDEX "idx_performer_faces_performer" ON "performer_faces"("performer_id"); -- CreateIndex CREATE INDEX "idx_performer_faces_source" ON "performer_faces"("source_path"); -- CreateIndex CREATE INDEX "idx_performer_faces_reference" ON "performer_faces"("is_reference_image"); -- CreateIndex CREATE INDEX "idx_performer_discrepancies_assigned" ON "performer_discrepancies"("assigned_performer_id"); -- CreateIndex CREATE INDEX "idx_performer_discrepancies_detected" ON "performer_discrepancies"("detected_performer_id"); -- CreateIndex CREATE INDEX "idx_performer_discrepancies_status" ON "performer_discrepancies"("resolution_status"); -- CreateIndex CREATE INDEX "idx_pipelines_status" ON "pipelines"("status"); -- CreateIndex CREATE INDEX "idx_pipelines_template" ON "pipelines"("template_id"); -- CreateIndex CREATE INDEX "idx_pipeline_steps_pipeline" ON "pipeline_steps"("pipeline_id"); -- CreateIndex CREATE INDEX "idx_pipeline_steps_status" ON "pipeline_steps"("status"); -- CreateIndex CREATE INDEX "idx_pipeline_steps_sequence" ON "pipeline_steps"("sequence_order"); -- CreateIndex CREATE INDEX "idx_pipeline_step_events_step" ON "pipeline_step_events"("step_id"); -- CreateIndex CREATE INDEX "idx_pipeline_step_events_type" ON "pipeline_step_events"("event_type"); -- CreateIndex CREATE INDEX "idx_resource_snapshots_timestamp" ON "resource_snapshots"("timestamp"); -- CreateIndex CREATE INDEX "idx_pipeline_templates_category" ON "pipeline_templates"("category"); -- CreateIndex CREATE INDEX "idx_pipeline_templates_public" ON "pipeline_templates"("is_public"); -- CreateIndex CREATE UNIQUE INDEX "subscription_plans_slug_key" ON "subscription_plans"("slug"); -- CreateIndex CREATE UNIQUE INDEX "user_subscriptions_stripe_subscription_id_key" ON "user_subscriptions"("stripe_subscription_id"); -- CreateIndex CREATE INDEX "idx_user_subscriptions_user" ON "user_subscriptions"("user_id"); -- CreateIndex CREATE INDEX "idx_user_subscriptions_plan" ON "user_subscriptions"("plan_id"); -- CreateIndex CREATE INDEX "idx_user_subscriptions_status" ON "user_subscriptions"("status"); -- CreateIndex CREATE UNIQUE INDEX "invoices_stripe_invoice_id_key" ON "invoices"("stripe_invoice_id"); -- CreateIndex CREATE INDEX "idx_invoices_user" ON "invoices"("user_id"); -- CreateIndex CREATE INDEX "idx_invoices_status" ON "invoices"("status"); -- CreateIndex CREATE INDEX "idx_invoices_issued" ON "invoices"("issued_at"); -- CreateIndex CREATE UNIQUE INDEX "payments_stripe_payment_intent_id_key" ON "payments"("stripe_payment_intent_id"); -- CreateIndex CREATE INDEX "idx_payments_invoice" ON "payments"("invoice_id"); -- CreateIndex CREATE INDEX "idx_payments_user" ON "payments"("user_id"); -- CreateIndex CREATE INDEX "idx_payments_status" ON "payments"("status"); -- CreateIndex CREATE INDEX "idx_payment_audit_log_payment" ON "payment_audit_log"("payment_id"); -- CreateIndex CREATE INDEX "idx_payment_audit_log_action" ON "payment_audit_log"("action"); -- CreateIndex CREATE INDEX "idx_payment_audit_log_created" ON "payment_audit_log"("created_at"); -- CreateIndex CREATE UNIQUE INDEX "products_slug_key" ON "products"("slug"); -- CreateIndex CREATE INDEX "idx_products_type" ON "products"("type"); -- CreateIndex CREATE INDEX "idx_products_active" ON "products"("is_active"); -- CreateIndex CREATE UNIQUE INDEX "orders_stripe_checkout_session_id_key" ON "orders"("stripe_checkout_session_id"); -- CreateIndex CREATE INDEX "idx_orders_user" ON "orders"("user_id"); -- CreateIndex CREATE INDEX "idx_orders_product" ON "orders"("product_id"); -- CreateIndex CREATE INDEX "idx_orders_status" ON "orders"("status"); -- CreateIndex CREATE INDEX "idx_orders_type" ON "orders"("order_type"); -- CreateIndex CREATE INDEX "idx_orders_donation_page" ON "orders"("donation_page_id"); -- CreateIndex CREATE UNIQUE INDEX "donation_pages_slug_key" ON "donation_pages"("slug"); -- CreateIndex CREATE INDEX "donation_pages_status_idx" ON "donation_pages"("status"); -- CreateIndex CREATE INDEX "idx_notifications_user" ON "notifications"("user_id"); -- CreateIndex CREATE INDEX "idx_notifications_read" ON "notifications"("is_read"); -- CreateIndex CREATE INDEX "idx_notifications_type" ON "notifications"("type"); -- CreateIndex CREATE INDEX "idx_notifications_created" ON "notifications"("created_at"); -- CreateIndex CREATE UNIQUE INDEX "notification_preferences_user_id_key" ON "notification_preferences"("user_id"); -- CreateIndex CREATE INDEX "idx_notification_preferences_user" ON "notification_preferences"("user_id"); -- CreateIndex CREATE INDEX "idx_geo_blocking_country" ON "geo_blocking_rules"("country_code"); -- CreateIndex CREATE INDEX "idx_geo_blocking_active" ON "geo_blocking_rules"("is_active"); -- CreateIndex CREATE INDEX "idx_published_inbox_files_inbox_path" ON "published_inbox_files"("original_inbox_path"); -- CreateIndex CREATE INDEX "idx_published_inbox_files_public_media" ON "published_inbox_files"("published_to_public_media_id"); -- CreateIndex CREATE INDEX "idx_video_ocr_results_video" ON "video_ocr_results"("video_id"); -- CreateIndex CREATE INDEX "idx_video_views_video" ON "video_views"("video_id"); -- CreateIndex CREATE INDEX "idx_video_views_user" ON "video_views"("user_id"); -- CreateIndex CREATE INDEX "idx_video_views_created" ON "video_views"("created_at"); -- CreateIndex CREATE INDEX "idx_video_views_video_created" ON "video_views"("video_id", "created_at"); -- CreateIndex CREATE INDEX "idx_video_events_video" ON "video_events"("video_id"); -- CreateIndex CREATE INDEX "idx_video_events_view" ON "video_events"("view_id"); -- CreateIndex CREATE INDEX "idx_video_events_type" ON "video_events"("event_type"); -- CreateIndex CREATE INDEX "idx_video_events_created" ON "video_events"("created_at"); -- CreateIndex CREATE INDEX "idx_video_schedule_history_video" ON "video_schedule_history"("video_id"); -- CreateIndex CREATE INDEX "idx_video_schedule_history_scheduled" ON "video_schedule_history"("scheduled_for"); -- CreateIndex CREATE INDEX "idx_video_schedule_history_status" ON "video_schedule_history"("status"); -- CreateIndex CREATE INDEX "idx_video_schedule_history_user" ON "video_schedule_history"("scheduled_by_user_id"); -- CreateIndex CREATE INDEX "docs_page_views_createdAt_idx" ON "docs_page_views"("createdAt"); -- CreateIndex CREATE INDEX "docs_page_views_path_createdAt_idx" ON "docs_page_views"("path", "createdAt"); -- CreateIndex CREATE UNIQUE INDEX "photos_path_key" ON "photos"("path"); -- CreateIndex CREATE INDEX "idx_photos_orientation" ON "photos"("orientation"); -- CreateIndex CREATE INDEX "idx_photos_producer" ON "photos"("producer"); -- CreateIndex CREATE INDEX "idx_photos_published_locked" ON "photos"("is_published", "is_locked"); -- CreateIndex CREATE INDEX "idx_photos_category_published" ON "photos"("category", "is_published"); -- CreateIndex CREATE INDEX "idx_photos_album_position" ON "photos"("album_id", "album_position"); -- CreateIndex CREATE INDEX "idx_photos_created_at" ON "photos"("created_at"); -- CreateIndex CREATE INDEX "idx_photos_uploader" ON "photos"("uploader_id"); -- CreateIndex CREATE UNIQUE INDEX "photo_albums_cover_photo_id_key" ON "photo_albums"("cover_photo_id"); -- CreateIndex CREATE INDEX "idx_photo_albums_published" ON "photo_albums"("is_published"); -- CreateIndex CREATE INDEX "idx_photo_albums_creator" ON "photo_albums"("creator_id"); -- CreateIndex CREATE INDEX "idx_photo_upvotes_photo" ON "photo_upvotes"("photo_id"); -- CreateIndex CREATE UNIQUE INDEX "idx_photo_upvotes_unique" ON "photo_upvotes"("photo_id", "session_id"); -- CreateIndex CREATE INDEX "idx_photo_comments_photo_date" ON "photo_comments"("photo_id", "created_at"); -- CreateIndex CREATE INDEX "idx_photo_comments_session" ON "photo_comments"("session_id"); -- CreateIndex CREATE INDEX "idx_photo_views_photo_date" ON "photo_views"("photo_id", "viewed_at"); -- CreateIndex CREATE INDEX "idx_photo_views_session" ON "photo_views"("session_id"); -- CreateIndex CREATE INDEX "idx_photo_reactions_photo" ON "photo_reactions"("photo_id"); -- CreateIndex CREATE UNIQUE INDEX "idx_photo_reactions_unique" ON "photo_reactions"("photo_id", "session_id", "reaction_type"); -- CreateIndex CREATE INDEX "docs_comments_pagePath_status_idx" ON "docs_comments"("pagePath", "status"); -- CreateIndex CREATE INDEX "docs_comments_status_createdAt_idx" ON "docs_comments"("status", "createdAt"); -- CreateIndex CREATE INDEX "docs_comments_giteaCommentId_idx" ON "docs_comments"("giteaCommentId"); -- CreateIndex CREATE INDEX "sms_contact_list_entries_listId_idx" ON "sms_contact_list_entries"("listId"); -- CreateIndex CREATE INDEX "sms_contact_list_entries_phone_idx" ON "sms_contact_list_entries"("phone"); -- CreateIndex CREATE UNIQUE INDEX "sms_contact_list_entries_listId_phone_key" ON "sms_contact_list_entries"("listId", "phone"); -- CreateIndex CREATE INDEX "sms_campaigns_status_idx" ON "sms_campaigns"("status"); -- CreateIndex CREATE INDEX "sms_campaigns_contactListId_idx" ON "sms_campaigns"("contactListId"); -- CreateIndex CREATE INDEX "sms_campaigns_advocacyCampaignId_idx" ON "sms_campaigns"("advocacyCampaignId"); -- CreateIndex CREATE INDEX "sms_campaign_recipients_campaignId_status_idx" ON "sms_campaign_recipients"("campaignId", "status"); -- CreateIndex CREATE INDEX "sms_campaign_recipients_phone_idx" ON "sms_campaign_recipients"("phone"); -- CreateIndex CREATE INDEX "sms_messages_phone_idx" ON "sms_messages"("phone"); -- CreateIndex CREATE INDEX "sms_messages_campaignId_idx" ON "sms_messages"("campaignId"); -- CreateIndex CREATE INDEX "sms_messages_conversationId_idx" ON "sms_messages"("conversationId"); -- CreateIndex CREATE INDEX "sms_messages_direction_sentAt_idx" ON "sms_messages"("direction", "sentAt"); -- CreateIndex CREATE INDEX "sms_conversations_status_idx" ON "sms_conversations"("status"); -- CreateIndex CREATE INDEX "sms_conversations_lastMessageAt_idx" ON "sms_conversations"("lastMessageAt"); -- CreateIndex CREATE UNIQUE INDEX "sms_conversations_phone_campaignId_key" ON "sms_conversations"("phone", "campaignId"); -- CreateIndex CREATE UNIQUE INDEX "contacts_profileToken_key" ON "contacts"("profileToken"); -- CreateIndex CREATE UNIQUE INDEX "contacts_userId_key" ON "contacts"("userId"); -- CreateIndex CREATE INDEX "contacts_email_idx" ON "contacts"("email"); -- CreateIndex CREATE INDEX "contacts_phone_idx" ON "contacts"("phone"); -- CreateIndex CREATE INDEX "contacts_displayName_idx" ON "contacts"("displayName"); -- CreateIndex CREATE INDEX "contacts_primarySource_idx" ON "contacts"("primarySource"); -- CreateIndex CREATE INDEX "contacts_mergedIntoId_idx" ON "contacts"("mergedIntoId"); -- CreateIndex CREATE UNIQUE INDEX "crm_tags_name_key" ON "crm_tags"("name"); -- CreateIndex CREATE UNIQUE INDEX "crm_tags_slug_key" ON "crm_tags"("slug"); -- CreateIndex CREATE INDEX "crm_tags_name_idx" ON "crm_tags"("name"); -- CreateIndex CREATE INDEX "contact_addresses_addressId_idx" ON "contact_addresses"("addressId"); -- CreateIndex CREATE UNIQUE INDEX "contact_addresses_contactId_addressId_key" ON "contact_addresses"("contactId", "addressId"); -- CreateIndex CREATE INDEX "contact_emails_email_idx" ON "contact_emails"("email"); -- CreateIndex CREATE INDEX "contact_emails_contactId_idx" ON "contact_emails"("contactId"); -- CreateIndex CREATE UNIQUE INDEX "contact_emails_contactId_email_key" ON "contact_emails"("contactId", "email"); -- CreateIndex CREATE INDEX "contact_phones_phone_idx" ON "contact_phones"("phone"); -- CreateIndex CREATE INDEX "contact_phones_contactId_idx" ON "contact_phones"("contactId"); -- CreateIndex CREATE UNIQUE INDEX "contact_phones_contactId_phone_key" ON "contact_phones"("contactId", "phone"); -- CreateIndex CREATE INDEX "contact_connections_toContactId_idx" ON "contact_connections"("toContactId"); -- CreateIndex CREATE UNIQUE INDEX "contact_connections_fromContactId_toContactId_type_key" ON "contact_connections"("fromContactId", "toContactId", "type"); -- CreateIndex CREATE INDEX "contact_activities_contactId_occurredAt_idx" ON "contact_activities"("contactId", "occurredAt" DESC); -- CreateIndex CREATE INDEX "campaign_emails_userPostalCode_idx" ON "campaign_emails"("userPostalCode"); -- CreateIndex CREATE INDEX "campaign_emails_sentAt_idx" ON "campaign_emails"("sentAt"); -- CreateIndex CREATE INDEX "campaigns_moderationStatus_idx" ON "campaigns"("moderationStatus"); -- CreateIndex CREATE INDEX "campaigns_isUserGenerated_idx" ON "campaigns"("isUserGenerated"); -- CreateIndex CREATE INDEX "canvass_visits_addressId_idx" ON "canvass_visits"("addressId"); -- CreateIndex CREATE INDEX "canvass_visits_addressId_visitedAt_idx" ON "canvass_visits"("addressId", "visitedAt" DESC); -- CreateIndex CREATE UNIQUE INDEX "locations_locGuid_key" ON "locations"("locGuid"); -- CreateIndex CREATE INDEX "locations_latitude_longitude_idx" ON "locations"("latitude", "longitude"); -- CreateIndex CREATE INDEX "locations_latitude_idx" ON "locations"("latitude"); -- CreateIndex CREATE INDEX "locations_longitude_idx" ON "locations"("longitude"); -- CreateIndex CREATE INDEX "locations_postalCode_idx" ON "locations"("postalCode"); -- CreateIndex CREATE INDEX "representative_responses_representativeName_idx" ON "representative_responses"("representativeName"); -- CreateIndex CREATE INDEX "shifts_seriesId_idx" ON "shifts"("seriesId"); -- AddForeignKey ALTER TABLE "campaigns" ADD CONSTRAINT "campaigns_reviewedByUserId_fkey" FOREIGN KEY ("reviewedByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "addresses" ADD CONSTRAINT "addresses_locationId_fkey" FOREIGN KEY ("locationId") REFERENCES "locations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "addresses" ADD CONSTRAINT "addresses_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "addresses" ADD CONSTRAINT "addresses_updatedByUserId_fkey" FOREIGN KEY ("updatedByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "location_history" ADD CONSTRAINT "location_history_locationId_fkey" FOREIGN KEY ("locationId") REFERENCES "locations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "location_history" ADD CONSTRAINT "location_history_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "shifts" ADD CONSTRAINT "shifts_seriesId_fkey" FOREIGN KEY ("seriesId") REFERENCES "shift_series"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "shift_series" ADD CONSTRAINT "shift_series_cutId_fkey" FOREIGN KEY ("cutId") REFERENCES "cuts"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_templates" ADD CONSTRAINT "email_templates_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_templates" ADD CONSTRAINT "email_templates_updatedByUserId_fkey" FOREIGN KEY ("updatedByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_template_variables" ADD CONSTRAINT "email_template_variables_templateId_fkey" FOREIGN KEY ("templateId") REFERENCES "email_templates"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_template_versions" ADD CONSTRAINT "email_template_versions_templateId_fkey" FOREIGN KEY ("templateId") REFERENCES "email_templates"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_template_versions" ADD CONSTRAINT "email_template_versions_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_template_test_logs" ADD CONSTRAINT "email_template_test_logs_templateId_fkey" FOREIGN KEY ("templateId") REFERENCES "email_templates"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_template_test_logs" ADD CONSTRAINT "email_template_test_logs_sentByUserId_fkey" FOREIGN KEY ("sentByUserId") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "canvass_visits" ADD CONSTRAINT "canvass_visits_addressId_fkey" FOREIGN KEY ("addressId") REFERENCES "addresses"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "videos" ADD CONSTRAINT "videos_uploader_id_fkey" FOREIGN KEY ("uploader_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "videos" ADD CONSTRAINT "videos_locked_by_id_fkey" FOREIGN KEY ("locked_by_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "jobs" ADD CONSTRAINT "jobs_pipeline_id_fkey" FOREIGN KEY ("pipeline_id") REFERENCES "pipelines"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "jobs" ADD CONSTRAINT "jobs_pipeline_step_id_fkey" FOREIGN KEY ("pipeline_step_id") REFERENCES "pipeline_steps"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sessions" ADD CONSTRAINT "sessions_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "upvotes" ADD CONSTRAINT "upvotes_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "upvotes" ADD CONSTRAINT "upvotes_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "comments" ADD CONSTRAINT "comments_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "comments" ADD CONSTRAINT "comments_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "comments" ADD CONSTRAINT "comments_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "views" ADD CONSTRAINT "views_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "views" ADD CONSTRAINT "views_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "auth_tokens" ADD CONSTRAINT "auth_tokens_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "session_bans" ADD CONSTRAINT "session_bans_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "session_bans" ADD CONSTRAINT "session_bans_banned_by_fkey" FOREIGN KEY ("banned_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "comment_moderation" ADD CONSTRAINT "comment_moderation_comment_id_fkey" FOREIGN KEY ("comment_id") REFERENCES "comments"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "comment_moderation" ADD CONSTRAINT "comment_moderation_moderated_by_fkey" FOREIGN KEY ("moderated_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_verification_tokens" ADD CONSTRAINT "email_verification_tokens_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "password_reset_tokens" ADD CONSTRAINT "password_reset_tokens_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "email_change_tokens" ADD CONSTRAINT "email_change_tokens_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_achievements" ADD CONSTRAINT "user_achievements_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_stats" ADD CONSTRAINT "user_stats_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_finishes" ADD CONSTRAINT "user_finishes_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_finishes" ADD CONSTRAINT "user_finishes_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_finishes" ADD CONSTRAINT "user_finishes_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_reactions" ADD CONSTRAINT "video_reactions_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_reactions" ADD CONSTRAINT "video_reactions_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "highlight_cooldowns" ADD CONSTRAINT "highlight_cooldowns_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_daily_activity" ADD CONSTRAINT "user_daily_activity_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "chat_thread_read_status" ADD CONSTRAINT "chat_thread_read_status_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "moderation_word_lists" ADD CONSTRAINT "moderation_word_lists_created_by_fkey" FOREIGN KEY ("created_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "content_reports" ADD CONSTRAINT "content_reports_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "content_reports" ADD CONSTRAINT "content_reports_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "content_reports" ADD CONSTRAINT "content_reports_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "content_reports" ADD CONSTRAINT "content_reports_resolved_by_fkey" FOREIGN KEY ("resolved_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "playlists" ADD CONSTRAINT "playlists_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "playlist_videos" ADD CONSTRAINT "playlist_videos_playlist_id_fkey" FOREIGN KEY ("playlist_id") REFERENCES "playlists"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "playlist_videos" ADD CONSTRAINT "playlist_videos_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "featured_playlists" ADD CONSTRAINT "featured_playlists_playlist_id_fkey" FOREIGN KEY ("playlist_id") REFERENCES "playlists"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "featured_playlists" ADD CONSTRAINT "featured_playlists_featured_by_fkey" FOREIGN KEY ("featured_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "playlist_views" ADD CONSTRAINT "playlist_views_playlist_id_fkey" FOREIGN KEY ("playlist_id") REFERENCES "playlists"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "playlist_views" ADD CONSTRAINT "playlist_views_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ads" ADD CONSTRAINT "ads_product_id_fkey" FOREIGN KEY ("product_id") REFERENCES "products"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_impressions" ADD CONSTRAINT "ad_impressions_ad_id_fkey" FOREIGN KEY ("ad_id") REFERENCES "ads"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_impressions" ADD CONSTRAINT "ad_impressions_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_impressions" ADD CONSTRAINT "ad_impressions_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_clicks" ADD CONSTRAINT "ad_clicks_ad_id_fkey" FOREIGN KEY ("ad_id") REFERENCES "ads"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_clicks" ADD CONSTRAINT "ad_clicks_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "ad_clicks" ADD CONSTRAINT "ad_clicks_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "friendships" ADD CONSTRAINT "friendships_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "friendships" ADD CONSTRAINT "friendships_friend_id_fkey" FOREIGN KEY ("friend_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_blocks" ADD CONSTRAINT "user_blocks_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_blocks" ADD CONSTRAINT "user_blocks_blocked_user_id_fkey" FOREIGN KEY ("blocked_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "pokes" ADD CONSTRAINT "pokes_from_user_id_fkey" FOREIGN KEY ("from_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "pokes" ADD CONSTRAINT "pokes_to_user_id_fkey" FOREIGN KEY ("to_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_recommendations" ADD CONSTRAINT "video_recommendations_from_user_id_fkey" FOREIGN KEY ("from_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_recommendations" ADD CONSTRAINT "video_recommendations_to_user_id_fkey" FOREIGN KEY ("to_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_recommendations" ADD CONSTRAINT "video_recommendations_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_presence" ADD CONSTRAINT "user_presence_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_gallery_images" ADD CONSTRAINT "user_gallery_images_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_social_links" ADD CONSTRAINT "user_social_links_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "privacy_settings" ADD CONSTRAINT "privacy_settings_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "close_friends" ADD CONSTRAINT "close_friends_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "close_friends" ADD CONSTRAINT "close_friends_close_friend_id_fkey" FOREIGN KEY ("close_friend_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_uploads" ADD CONSTRAINT "user_uploads_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_uploads" ADD CONSTRAINT "user_uploads_reviewed_by_fkey" FOREIGN KEY ("reviewed_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_uploads" ADD CONSTRAINT "user_uploads_upload_invite_id_fkey" FOREIGN KEY ("upload_invite_id") REFERENCES "upload_invites"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "upload_invites" ADD CONSTRAINT "upload_invites_created_by_fkey" FOREIGN KEY ("created_by") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "tags" ADD CONSTRAINT "tags_category_id_fkey" FOREIGN KEY ("category_id") REFERENCES "tag_categories"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "public_media_tags" ADD CONSTRAINT "public_media_tags_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "public_media_tags" ADD CONSTRAINT "public_media_tags_tag_id_fkey" FOREIGN KEY ("tag_id") REFERENCES "tags"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_upload_suggested_tags" ADD CONSTRAINT "user_upload_suggested_tags_upload_id_fkey" FOREIGN KEY ("upload_id") REFERENCES "user_uploads"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_upload_suggested_tags" ADD CONSTRAINT "user_upload_suggested_tags_tag_id_fkey" FOREIGN KEY ("tag_id") REFERENCES "tags"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_tag_preferences" ADD CONSTRAINT "user_tag_preferences_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_tag_preferences" ADD CONSTRAINT "user_tag_preferences_tag_id_fkey" FOREIGN KEY ("tag_id") REFERENCES "tags"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "public_media_performers" ADD CONSTRAINT "public_media_performers_media_id_fkey" FOREIGN KEY ("media_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "public_media_performers" ADD CONSTRAINT "public_media_performers_performer_id_fkey" FOREIGN KEY ("performer_id") REFERENCES "creators"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_digests" ADD CONSTRAINT "video_digests_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_digests" ADD CONSTRAINT "video_digests_job_id_fkey" FOREIGN KEY ("job_id") REFERENCES "jobs"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_video_tags" ADD CONSTRAINT "digest_video_tags_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_video_tags" ADD CONSTRAINT "digest_video_tags_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_selected_clips" ADD CONSTRAINT "digest_selected_clips_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_selected_clips" ADD CONSTRAINT "digest_selected_clips_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_clips" ADD CONSTRAINT "digest_generated_clips_selected_clip_id_fkey" FOREIGN KEY ("selected_clip_id") REFERENCES "digest_selected_clips"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_clips" ADD CONSTRAINT "digest_generated_clips_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_clips" ADD CONSTRAINT "digest_generated_clips_folder_id_fkey" FOREIGN KEY ("folder_id") REFERENCES "digest_output_folders"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_compilations" ADD CONSTRAINT "digest_compilations_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_compilations" ADD CONSTRAINT "digest_compilations_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_compilations" ADD CONSTRAINT "digest_compilations_folder_id_fkey" FOREIGN KEY ("folder_id") REFERENCES "digest_output_folders"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_output_folders" ADD CONSTRAINT "digest_output_folders_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_output_folders" ADD CONSTRAINT "digest_output_folders_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_scenes" ADD CONSTRAINT "digest_generated_scenes_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_scenes" ADD CONSTRAINT "digest_generated_scenes_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_generated_scenes" ADD CONSTRAINT "digest_generated_scenes_folder_id_fkey" FOREIGN KEY ("folder_id") REFERENCES "digest_output_folders"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_scene_cuts" ADD CONSTRAINT "video_scene_cuts_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_tag_timeline" ADD CONSTRAINT "video_tag_timeline_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_segments" ADD CONSTRAINT "video_segments_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_tags" ADD CONSTRAINT "video_tags_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_suggested_tags" ADD CONSTRAINT "digest_suggested_tags_digest_id_fkey" FOREIGN KEY ("digest_id") REFERENCES "video_digests"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "digest_clip_tags" ADD CONSTRAINT "digest_clip_tags_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_sessions" ADD CONSTRAINT "watch_party_sessions_host_user_id_fkey" FOREIGN KEY ("host_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_participants" ADD CONSTRAINT "watch_party_participants_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "watch_party_sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_participants" ADD CONSTRAINT "watch_party_participants_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_chat_messages" ADD CONSTRAINT "watch_party_chat_messages_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "watch_party_sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_chat_messages" ADD CONSTRAINT "watch_party_chat_messages_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_chat_messages" ADD CONSTRAINT "watch_party_chat_messages_comment_id_fkey" FOREIGN KEY ("comment_id") REFERENCES "comments"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_reactions" ADD CONSTRAINT "watch_party_reactions_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "watch_party_sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_reactions" ADD CONSTRAINT "watch_party_reactions_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_invites" ADD CONSTRAINT "watch_party_invites_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "watch_party_sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_invites" ADD CONSTRAINT "watch_party_invites_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "watch_party_invites" ADD CONSTRAINT "watch_party_invites_invited_by_fkey" FOREIGN KEY ("invited_by") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "tag_generation_jobs" ADD CONSTRAINT "tag_generation_jobs_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "tag_generation_jobs" ADD CONSTRAINT "tag_generation_jobs_job_id_fkey" FOREIGN KEY ("job_id") REFERENCES "jobs"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "performer_faces" ADD CONSTRAINT "performer_faces_performer_id_fkey" FOREIGN KEY ("performer_id") REFERENCES "creators"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "performer_discrepancies" ADD CONSTRAINT "performer_discrepancies_assigned_performer_id_fkey" FOREIGN KEY ("assigned_performer_id") REFERENCES "creators"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "performer_discrepancies" ADD CONSTRAINT "performer_discrepancies_resolved_by_fkey" FOREIGN KEY ("resolved_by") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "pipelines" ADD CONSTRAINT "pipelines_template_id_fkey" FOREIGN KEY ("template_id") REFERENCES "pipeline_templates"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "pipeline_steps" ADD CONSTRAINT "pipeline_steps_pipeline_id_fkey" FOREIGN KEY ("pipeline_id") REFERENCES "pipelines"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "pipeline_step_events" ADD CONSTRAINT "pipeline_step_events_step_id_fkey" FOREIGN KEY ("step_id") REFERENCES "pipeline_steps"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_subscriptions" ADD CONSTRAINT "user_subscriptions_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_subscriptions" ADD CONSTRAINT "user_subscriptions_plan_id_fkey" FOREIGN KEY ("plan_id") REFERENCES "subscription_plans"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "invoices" ADD CONSTRAINT "invoices_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "payments" ADD CONSTRAINT "payments_invoice_id_fkey" FOREIGN KEY ("invoice_id") REFERENCES "invoices"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "payments" ADD CONSTRAINT "payments_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "payment_audit_log" ADD CONSTRAINT "payment_audit_log_payment_id_fkey" FOREIGN KEY ("payment_id") REFERENCES "payments"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "payment_audit_log" ADD CONSTRAINT "payment_audit_log_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "orders" ADD CONSTRAINT "orders_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "orders" ADD CONSTRAINT "orders_product_id_fkey" FOREIGN KEY ("product_id") REFERENCES "products"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "orders" ADD CONSTRAINT "orders_donation_page_id_fkey" FOREIGN KEY ("donation_page_id") REFERENCES "donation_pages"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "donation_pages" ADD CONSTRAINT "donation_pages_created_by_user_id_fkey" FOREIGN KEY ("created_by_user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "notifications" ADD CONSTRAINT "notifications_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "notification_preferences" ADD CONSTRAINT "notification_preferences_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_ocr_results" ADD CONSTRAINT "video_ocr_results_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_views" ADD CONSTRAINT "video_views_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_views" ADD CONSTRAINT "video_views_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_events" ADD CONSTRAINT "video_events_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_schedule_history" ADD CONSTRAINT "video_schedule_history_video_id_fkey" FOREIGN KEY ("video_id") REFERENCES "videos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "video_schedule_history" ADD CONSTRAINT "video_schedule_history_scheduled_by_user_id_fkey" FOREIGN KEY ("scheduled_by_user_id") REFERENCES "users"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photos" ADD CONSTRAINT "photos_album_id_fkey" FOREIGN KEY ("album_id") REFERENCES "photo_albums"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photos" ADD CONSTRAINT "photos_uploader_id_fkey" FOREIGN KEY ("uploader_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_albums" ADD CONSTRAINT "photo_albums_cover_photo_id_fkey" FOREIGN KEY ("cover_photo_id") REFERENCES "photos"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_albums" ADD CONSTRAINT "photo_albums_creator_id_fkey" FOREIGN KEY ("creator_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_upvotes" ADD CONSTRAINT "photo_upvotes_photo_id_fkey" FOREIGN KEY ("photo_id") REFERENCES "photos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_upvotes" ADD CONSTRAINT "photo_upvotes_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_comments" ADD CONSTRAINT "photo_comments_photo_id_fkey" FOREIGN KEY ("photo_id") REFERENCES "photos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_comments" ADD CONSTRAINT "photo_comments_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_comments" ADD CONSTRAINT "photo_comments_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_views" ADD CONSTRAINT "photo_views_photo_id_fkey" FOREIGN KEY ("photo_id") REFERENCES "photos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_reactions" ADD CONSTRAINT "photo_reactions_photo_id_fkey" FOREIGN KEY ("photo_id") REFERENCES "photos"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "photo_reactions" ADD CONSTRAINT "photo_reactions_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "sessions"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_contact_lists" ADD CONSTRAINT "sms_contact_lists_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_contact_list_entries" ADD CONSTRAINT "sms_contact_list_entries_listId_fkey" FOREIGN KEY ("listId") REFERENCES "sms_contact_lists"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_campaigns" ADD CONSTRAINT "sms_campaigns_contactListId_fkey" FOREIGN KEY ("contactListId") REFERENCES "sms_contact_lists"("id") ON DELETE RESTRICT ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_campaigns" ADD CONSTRAINT "sms_campaigns_advocacyCampaignId_fkey" FOREIGN KEY ("advocacyCampaignId") REFERENCES "campaigns"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_campaigns" ADD CONSTRAINT "sms_campaigns_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_campaign_recipients" ADD CONSTRAINT "sms_campaign_recipients_campaignId_fkey" FOREIGN KEY ("campaignId") REFERENCES "sms_campaigns"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_messages" ADD CONSTRAINT "sms_messages_campaignId_fkey" FOREIGN KEY ("campaignId") REFERENCES "sms_campaigns"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_messages" ADD CONSTRAINT "sms_messages_conversationId_fkey" FOREIGN KEY ("conversationId") REFERENCES "sms_conversations"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_conversations" ADD CONSTRAINT "sms_conversations_campaignId_fkey" FOREIGN KEY ("campaignId") REFERENCES "sms_campaigns"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "sms_message_templates" ADD CONSTRAINT "sms_message_templates_createdByUserId_fkey" FOREIGN KEY ("createdByUserId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contacts" ADD CONSTRAINT "contacts_userId_fkey" FOREIGN KEY ("userId") REFERENCES "users"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contacts" ADD CONSTRAINT "contacts_mergedIntoId_fkey" FOREIGN KEY ("mergedIntoId") REFERENCES "contacts"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_addresses" ADD CONSTRAINT "contact_addresses_contactId_fkey" FOREIGN KEY ("contactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_addresses" ADD CONSTRAINT "contact_addresses_addressId_fkey" FOREIGN KEY ("addressId") REFERENCES "addresses"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_emails" ADD CONSTRAINT "contact_emails_contactId_fkey" FOREIGN KEY ("contactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_phones" ADD CONSTRAINT "contact_phones_contactId_fkey" FOREIGN KEY ("contactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_connections" ADD CONSTRAINT "contact_connections_fromContactId_fkey" FOREIGN KEY ("fromContactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_connections" ADD CONSTRAINT "contact_connections_toContactId_fkey" FOREIGN KEY ("toContactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "contact_activities" ADD CONSTRAINT "contact_activities_contactId_fkey" FOREIGN KEY ("contactId") REFERENCES "contacts"("id") ON DELETE CASCADE ON UPDATE CASCADE;