/*
* Copyright (C) 2026 Fluxer Contributors
*
* This file is part of Fluxer.
*
* Fluxer is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Fluxer is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Fluxer. If not, see .
*/
import type {AttachmentID, ChannelID, GuildID, MemeID, UserID} from '@fluxer/api/src/BrandedTypes';
import {defineTable} from '@fluxer/api/src/database/Cassandra';
import {
ADMIN_ARCHIVE_COLUMNS,
ADMIN_AUDIT_LOG_COLUMNS,
type AdminArchiveRow,
type AdminAuditLogRow,
BANNED_EMAIL_COLUMNS,
BANNED_IP_COLUMNS,
BANNED_PHONE_COLUMNS,
type BannedEmailRow,
type BannedIpRow,
type BannedPhoneRow,
} from '@fluxer/api/src/database/types/AdminArchiveTypes';
import {
ADMIN_API_KEY_BY_CREATOR_COLUMNS,
ADMIN_API_KEY_COLUMNS,
type AdminApiKeyByCreatorRow,
type AdminApiKeyRow,
} from '@fluxer/api/src/database/types/AdminAuthTypes';
import {
AUTH_SESSION_COLUMNS,
AUTHORIZED_IP_COLUMNS,
type AuthorizedIpRow,
type AuthSessionRow,
EMAIL_CHANGE_TICKET_COLUMNS,
EMAIL_CHANGE_TOKEN_COLUMNS,
EMAIL_REVERT_TOKEN_COLUMNS,
EMAIL_VERIFICATION_TOKEN_COLUMNS,
type EmailChangeTicketRow,
type EmailChangeTokenRow,
type EmailRevertTokenRow,
type EmailVerificationTokenRow,
IP_AUTHORIZATION_TOKEN_COLUMNS,
type IpAuthorizationTokenRow,
MFA_BACKUP_CODE_COLUMNS,
type MfaBackupCodeRow,
PASSWORD_CHANGE_TICKET_COLUMNS,
PASSWORD_RESET_TOKEN_COLUMNS,
type PasswordChangeTicketRow,
type PasswordResetTokenRow,
PHONE_TOKEN_COLUMNS,
type PhoneTokenRow,
WEBAUTHN_CREDENTIAL_COLUMNS,
type WebAuthnCredentialRow,
} from '@fluxer/api/src/database/types/AuthTypes';
import {
CHANNEL_COLUMNS,
CHANNELS_BY_GUILD_COLUMNS,
type ChannelRow,
type ChannelsByGuildRow,
DM_STATE_COLUMNS,
type DmStateRow,
INVITE_COLUMNS,
type InviteRow,
PRIVATE_CHANNEL_COLUMNS,
type PrivateChannelRow,
WEBHOOK_COLUMNS,
type WebhookRow,
} from '@fluxer/api/src/database/types/ChannelTypes';
import {USER_CONNECTION_COLUMNS, type UserConnectionRow} from '@fluxer/api/src/database/types/ConnectionTypes';
import {
CSAM_EVIDENCE_EXPIRATION_COLUMNS,
CSAM_EVIDENCE_LEGAL_HOLD_COLUMNS,
CSAM_EVIDENCE_PACKAGE_COLUMNS,
CSAM_SCAN_JOB_COLUMNS,
type CsamEvidenceExpirationRow,
type CsamEvidenceLegalHoldRow,
type CsamEvidencePackageRow,
type CsamScanJobRow,
NCMEC_SUBMISSION_COLUMNS,
type NcmecSubmissionRow,
} from '@fluxer/api/src/database/types/CsamTypes';
import {
GUILD_DISCOVERY_BY_STATUS_COLUMNS,
GUILD_DISCOVERY_COLUMNS,
type GuildDiscoveryByStatusRow,
type GuildDiscoveryRow,
} from '@fluxer/api/src/database/types/GuildDiscoveryTypes';
import {
GUILD_AUDIT_LOG_COLUMNS,
GUILD_BAN_COLUMNS,
GUILD_COLUMNS,
GUILD_EMOJI_BY_EMOJI_ID_COLUMNS,
GUILD_EMOJI_COLUMNS,
GUILD_MEMBER_BY_USER_ID_COLUMNS,
GUILD_MEMBER_COLUMNS,
GUILD_ROLE_COLUMNS,
GUILD_STICKER_BY_STICKER_ID_COLUMNS,
GUILD_STICKER_COLUMNS,
type GuildAuditLogRow,
type GuildBanRow,
type GuildEmojiRow,
type GuildMemberByUserIdRow,
type GuildMemberRow,
type GuildRoleRow,
type GuildRow,
type GuildStickerRow,
} from '@fluxer/api/src/database/types/GuildTypes';
import {
INSTANCE_CONFIGURATION_COLUMNS,
type InstanceConfigurationRow,
} from '@fluxer/api/src/database/types/InstanceConfigTypes';
import {
ATTACHMENT_LOOKUP_COLUMNS,
type AttachmentLookupRow,
CHANNEL_EMPTY_BUCKET_COLUMNS,
CHANNEL_MESSAGE_BUCKET_COLUMNS,
CHANNEL_PIN_COLUMNS,
CHANNEL_STATE_COLUMNS,
type ChannelEmptyBucketRow,
type ChannelMessageBucketRow,
type ChannelPinRow,
type ChannelStateRow,
MESSAGE_BY_AUTHOR_COLUMNS,
MESSAGE_COLUMNS,
MESSAGE_REACTION_COLUMNS,
type MessageByAuthorRow,
type MessageReactionRow,
type MessageRow,
} from '@fluxer/api/src/database/types/MessageTypes';
import {
APPLICATION_COLUMNS,
type ApplicationByOwnerRow,
type ApplicationRow,
OAUTH2_ACCESS_TOKEN_COLUMNS,
OAUTH2_AUTHORIZATION_CODE_COLUMNS,
OAUTH2_REFRESH_TOKEN_COLUMNS,
type OAuth2AccessTokenByUserRow,
type OAuth2AccessTokenRow,
type OAuth2AuthorizationCodeRow,
type OAuth2RefreshTokenByUserRow,
type OAuth2RefreshTokenRow,
} from '@fluxer/api/src/database/types/OAuth2Types';
import {
GIFT_CODE_BY_CREATOR_COLUMNS,
GIFT_CODE_BY_PAYMENT_INTENT_COLUMNS,
GIFT_CODE_BY_REDEEMER_COLUMNS,
GIFT_CODE_COLUMNS,
type GiftCodeByCreatorRow,
type GiftCodeByPaymentIntentRow,
type GiftCodeByRedeemerRow,
type GiftCodeRow,
PAYMENT_BY_PAYMENT_INTENT_COLUMNS,
PAYMENT_BY_SUBSCRIPTION_COLUMNS,
PAYMENT_BY_USER_COLUMNS,
PAYMENT_COLUMNS,
type PaymentByPaymentIntentRow,
type PaymentBySubscriptionRow,
type PaymentByUserRow,
type PaymentRow,
VISIONARY_SLOT_COLUMNS,
type VisionarySlotRow,
} from '@fluxer/api/src/database/types/PaymentTypes';
import {
DSA_REPORT_EMAIL_VERIFICATION_COLUMNS,
DSA_REPORT_TICKET_COLUMNS,
type DSAReportEmailVerificationRow,
type DSAReportTicketRow,
IAR_SUBMISSION_COLUMNS,
type IARSubmissionRow,
} from '@fluxer/api/src/database/types/ReportTypes';
import {SYSTEM_DM_JOB_COLUMNS, type SystemDmJobRow} from '@fluxer/api/src/database/types/SystemDmJobTypes';
import {
EXPRESSION_PACK_COLUMNS,
type ExpressionPackRow,
FAVORITE_MEME_COLUMNS,
type FavoriteMemeRow,
NOTE_COLUMNS,
type NoteRow,
type PackInstallationRow,
PUSH_SUBSCRIPTION_COLUMNS,
type PushSubscriptionRow,
RECENT_MENTION_COLUMNS,
RELATIONSHIP_COLUMNS,
type RecentMentionRow,
type RelationshipRow,
SAVED_MESSAGE_COLUMNS,
type SavedMessageRow,
SCHEDULED_MESSAGE_COLUMNS,
type ScheduledMessageRow,
USER_BY_EMAIL_COLUMNS,
USER_BY_PHONE_COLUMNS,
USER_BY_STRIPE_CUSTOMER_ID_COLUMNS,
USER_BY_STRIPE_SUBSCRIPTION_ID_COLUMNS,
USER_BY_USERNAME_COLUMNS,
USER_COLUMNS,
USER_CONTACT_CHANGE_LOG_COLUMNS,
USER_DM_HISTORY_COLUMNS,
USER_GUILD_SETTINGS_COLUMNS,
USER_HARVEST_COLUMNS,
USER_SETTINGS_COLUMNS,
USERS_PENDING_DELETION_COLUMNS,
type UserByEmailRow,
type UserByPhoneRow,
type UserByStripeCustomerIdRow,
type UserByStripeSubscriptionIdRow,
type UserByUsernameRow,
type UserContactChangeLogRow,
type UserDmHistoryRow,
type UserGuildSettingsRow,
type UserHarvestRow,
type UserRow,
type UserSettingsRow,
type UsersPendingDeletionRow,
} from '@fluxer/api/src/database/types/UserTypes';
import {ATTACHMENT_DECAY_COLUMNS, type AttachmentDecayRow} from '@fluxer/api/src/types/AttachmentDecayTypes';
export const Users = defineTable({
name: 'users',
columns: USER_COLUMNS,
primaryKey: ['user_id'],
});
export const UsersPendingDeletion = defineTable<
UsersPendingDeletionRow,
'deletion_date' | 'pending_deletion_at' | 'user_id'
>({
name: 'users_pending_deletion',
columns: USERS_PENDING_DELETION_COLUMNS,
primaryKey: ['deletion_date', 'pending_deletion_at', 'user_id'],
});
export const SystemDmJobs = defineTable({
name: 'system_dm_jobs',
columns: SYSTEM_DM_JOB_COLUMNS,
primaryKey: ['job_type', 'job_id'],
partitionKey: ['job_type'],
});
export const UserDmHistory = defineTable({
name: 'user_dm_history',
columns: USER_DM_HISTORY_COLUMNS,
primaryKey: ['user_id', 'channel_id'],
});
export const UserByUsername = defineTable({
name: 'users_by_username',
columns: USER_BY_USERNAME_COLUMNS,
primaryKey: ['username', 'discriminator', 'user_id'],
});
export const UserByEmail = defineTable({
name: 'users_by_email',
columns: USER_BY_EMAIL_COLUMNS,
primaryKey: ['email_lower', 'user_id'],
});
export const UserByPhone = defineTable({
name: 'users_by_phone',
columns: USER_BY_PHONE_COLUMNS,
primaryKey: ['phone', 'user_id'],
});
export const UserByStripeCustomerId = defineTable({
name: 'users_by_stripe_customer_id',
columns: USER_BY_STRIPE_CUSTOMER_ID_COLUMNS,
primaryKey: ['stripe_customer_id', 'user_id'],
});
export const UserByStripeSubscriptionId = defineTable<
UserByStripeSubscriptionIdRow,
'stripe_subscription_id' | 'user_id'
>({
name: 'users_by_stripe_subscription_id',
columns: USER_BY_STRIPE_SUBSCRIPTION_ID_COLUMNS,
primaryKey: ['stripe_subscription_id', 'user_id'],
});
export const UserSettings = defineTable({
name: 'user_settings',
columns: USER_SETTINGS_COLUMNS,
primaryKey: ['user_id'],
});
export const UserGuildSettings = defineTable({
name: 'user_guild_settings',
columns: USER_GUILD_SETTINGS_COLUMNS,
primaryKey: ['user_id', 'guild_id'],
});
export const UserContactChangeLogs = defineTable({
name: 'user_contact_change_logs',
columns: USER_CONTACT_CHANGE_LOG_COLUMNS,
primaryKey: ['user_id', 'event_id'],
});
export const UserConnections = defineTable({
name: 'user_connections',
columns: USER_CONNECTION_COLUMNS,
primaryKey: ['user_id', 'connection_type', 'connection_id'],
partitionKey: ['user_id'],
});
export const Notes = defineTable({
name: 'notes',
columns: NOTE_COLUMNS,
primaryKey: ['source_user_id', 'target_user_id'],
});
export const Relationships = defineTable({
name: 'relationships',
columns: RELATIONSHIP_COLUMNS,
primaryKey: ['source_user_id', 'target_user_id', 'type'],
});
export const RelationshipsByTarget = defineTable({
name: 'relationships_by_target',
columns: RELATIONSHIP_COLUMNS,
primaryKey: ['target_user_id', 'source_user_id', 'type'],
});
export const UserHarvests = defineTable({
name: 'user_harvests',
columns: USER_HARVEST_COLUMNS,
primaryKey: ['user_id', 'harvest_id'],
});
export const Guilds = defineTable({
name: 'guilds',
columns: GUILD_COLUMNS,
primaryKey: ['guild_id'],
});
export const GuildDiscovery = defineTable({
name: 'guild_discovery',
columns: GUILD_DISCOVERY_COLUMNS,
primaryKey: ['guild_id'],
});
export const GuildDiscoveryByStatus = defineTable<
GuildDiscoveryByStatusRow,
'status' | 'applied_at' | 'guild_id',
'status'
>({
name: 'guild_discovery_by_status',
columns: GUILD_DISCOVERY_BY_STATUS_COLUMNS,
primaryKey: ['status', 'applied_at', 'guild_id'],
partitionKey: ['status'],
});
export const GuildBans = defineTable({
name: 'guild_bans',
columns: GUILD_BAN_COLUMNS,
primaryKey: ['guild_id', 'user_id'],
});
export const GuildAuditLogs = defineTable({
name: 'guild_audit_logs_v2',
columns: GUILD_AUDIT_LOG_COLUMNS,
primaryKey: ['guild_id', 'log_id'],
});
export const GuildAuditLogsByUser = defineTable({
name: 'guild_audit_logs_v2_by_user',
columns: GUILD_AUDIT_LOG_COLUMNS,
primaryKey: ['guild_id', 'user_id', 'log_id'],
});
export const GuildAuditLogsByAction = defineTable({
name: 'guild_audit_logs_v2_by_action',
columns: GUILD_AUDIT_LOG_COLUMNS,
primaryKey: ['guild_id', 'action_type', 'log_id'],
});
export const GuildAuditLogsByUserAction = defineTable<
GuildAuditLogRow,
'guild_id' | 'user_id' | 'action_type' | 'log_id'
>({
name: 'guild_audit_logs_v2_by_user_action',
columns: GUILD_AUDIT_LOG_COLUMNS,
primaryKey: ['guild_id', 'user_id', 'action_type', 'log_id'],
});
export const GuildMembersByUserId = defineTable({
name: 'guild_members_by_user_id',
columns: GUILD_MEMBER_BY_USER_ID_COLUMNS,
primaryKey: ['user_id', 'guild_id'],
});
export const GuildEmojis = defineTable({
name: 'guild_emojis',
columns: GUILD_EMOJI_COLUMNS,
primaryKey: ['guild_id', 'emoji_id'],
});
export const GuildEmojisByEmojiId = defineTable({
name: 'guild_emojis_by_emoji_id',
columns: GUILD_EMOJI_BY_EMOJI_ID_COLUMNS,
primaryKey: ['emoji_id'],
});
export const GuildStickers = defineTable({
name: 'guild_stickers',
columns: GUILD_STICKER_COLUMNS,
primaryKey: ['guild_id', 'sticker_id'],
});
export const GuildStickersByStickerId = defineTable({
name: 'guild_stickers_by_sticker_id',
columns: GUILD_STICKER_BY_STICKER_ID_COLUMNS,
primaryKey: ['sticker_id'],
});
export const GuildRoles = defineTable({
name: 'guild_roles',
columns: GUILD_ROLE_COLUMNS,
primaryKey: ['guild_id', 'role_id'],
});
export const GuildMembers = defineTable({
name: 'guild_members',
columns: GUILD_MEMBER_COLUMNS,
primaryKey: ['guild_id', 'user_id'],
});
export const Channels = defineTable({
name: 'channels',
columns: CHANNEL_COLUMNS,
primaryKey: ['channel_id', 'soft_deleted'],
});
export const ChannelsByGuild = defineTable({
name: 'channels_by_guild_id',
columns: CHANNELS_BY_GUILD_COLUMNS,
primaryKey: ['guild_id', 'channel_id'],
});
export const ChannelState = defineTable({
name: 'channel_state',
columns: CHANNEL_STATE_COLUMNS,
primaryKey: ['channel_id'],
});
export const ChannelPins = defineTable({
name: 'channel_pins',
columns: CHANNEL_PIN_COLUMNS,
primaryKey: ['channel_id', 'pinned_timestamp', 'message_id'],
});
export const ChannelMessageBuckets = defineTable({
name: 'channel_message_buckets',
columns: CHANNEL_MESSAGE_BUCKET_COLUMNS,
primaryKey: ['channel_id', 'bucket'],
partitionKey: ['channel_id'],
});
export const ChannelEmptyBuckets = defineTable({
name: 'channel_empty_buckets',
columns: CHANNEL_EMPTY_BUCKET_COLUMNS,
primaryKey: ['channel_id', 'bucket'],
partitionKey: ['channel_id'],
});
export const PrivateChannels = defineTable({
name: 'private_channels',
columns: PRIVATE_CHANNEL_COLUMNS,
primaryKey: ['user_id', 'channel_id'],
});
export const DmStates = defineTable({
name: 'dm_states',
columns: DM_STATE_COLUMNS,
primaryKey: ['hi_user_id', 'lo_user_id', 'channel_id'],
});
interface PinnedDmRow {
user_id: bigint;
channel_id: bigint;
sort_order: number;
}
const PINNED_DM_COLUMNS = ['user_id', 'channel_id', 'sort_order'] as const satisfies ReadonlyArray;
export const PinnedDms = defineTable({
name: 'pinned_dms',
columns: PINNED_DM_COLUMNS,
primaryKey: ['user_id', 'channel_id'],
});
interface ReadStateRow {
user_id: bigint;
channel_id: bigint;
}
const READ_STATE_COLUMNS = ['user_id', 'channel_id'] as const satisfies ReadonlyArray;
export const ReadStates = defineTable({
name: 'read_states',
columns: READ_STATE_COLUMNS,
primaryKey: ['user_id', 'channel_id'],
});
export const Messages = defineTable({
name: 'messages',
columns: MESSAGE_COLUMNS,
primaryKey: ['channel_id', 'bucket', 'message_id'],
});
export const MessagesByAuthor = defineTable({
name: 'messages_by_author_id',
columns: MESSAGE_BY_AUTHOR_COLUMNS,
primaryKey: ['author_id', 'channel_id', 'message_id'],
});
export const MessagesByAuthorV2 = defineTable({
name: 'messages_by_author_id_v2',
columns: MESSAGE_BY_AUTHOR_COLUMNS,
primaryKey: ['author_id', 'message_id'],
});
export const MessageReactions = defineTable<
MessageReactionRow,
'channel_id' | 'bucket' | 'message_id' | 'emoji_id' | 'emoji_name' | 'user_id',
'channel_id' | 'bucket'
>({
name: 'message_reactions',
columns: MESSAGE_REACTION_COLUMNS,
primaryKey: ['channel_id', 'bucket', 'message_id', 'emoji_id', 'emoji_name', 'user_id'],
partitionKey: ['channel_id', 'bucket'],
});
export const AttachmentLookup = defineTable({
name: 'attachment_lookup',
columns: ATTACHMENT_LOOKUP_COLUMNS,
primaryKey: ['channel_id', 'attachment_id', 'filename'],
});
export const RecentMentions = defineTable({
name: 'recent_mentions',
columns: RECENT_MENTION_COLUMNS,
primaryKey: ['user_id', 'message_id'],
});
interface RecentMentionsByGuildRow {
user_id: bigint;
guild_id: bigint;
message_id: bigint;
channel_id: bigint;
is_everyone: boolean;
is_role: boolean;
}
const RECENT_MENTIONS_BY_GUILD_COLUMNS = [
'user_id',
'guild_id',
'message_id',
'channel_id',
'is_everyone',
'is_role',
] as const satisfies ReadonlyArray;
export const RecentMentionsByGuild = defineTable({
name: 'recent_mentions_by_guild',
columns: RECENT_MENTIONS_BY_GUILD_COLUMNS,
primaryKey: ['user_id', 'guild_id', 'message_id'],
});
export const SavedMessages = defineTable({
name: 'saved_messages',
columns: SAVED_MESSAGE_COLUMNS,
primaryKey: ['user_id', 'message_id'],
});
export const ScheduledMessages = defineTable({
name: 'scheduled_messages',
columns: SCHEDULED_MESSAGE_COLUMNS,
primaryKey: ['user_id', 'scheduled_message_id'],
});
export const PushSubscriptions = defineTable({
name: 'push_subscriptions',
columns: PUSH_SUBSCRIPTION_COLUMNS,
primaryKey: ['user_id', 'subscription_id'],
});
export const Payments = defineTable({
name: 'payments',
columns: PAYMENT_COLUMNS,
primaryKey: ['checkout_session_id'],
});
export const PaymentsByPaymentIntent = defineTable({
name: 'payments_by_payment_intent',
columns: PAYMENT_BY_PAYMENT_INTENT_COLUMNS,
primaryKey: ['payment_intent_id'],
});
export const PaymentsBySubscription = defineTable({
name: 'payments_by_subscription',
columns: PAYMENT_BY_SUBSCRIPTION_COLUMNS,
primaryKey: ['subscription_id'],
});
export const PaymentsByUser = defineTable({
name: 'payments_by_user',
columns: PAYMENT_BY_USER_COLUMNS,
primaryKey: ['user_id', 'created_at'],
});
export const VisionarySlots = defineTable({
name: 'visionary_slots',
columns: VISIONARY_SLOT_COLUMNS,
primaryKey: ['slot_index'],
});
export const GiftCodes = defineTable({
name: 'gift_codes',
columns: GIFT_CODE_COLUMNS,
primaryKey: ['code'],
});
export const GiftCodesByCreator = defineTable({
name: 'gift_codes_by_creator',
columns: GIFT_CODE_BY_CREATOR_COLUMNS,
primaryKey: ['created_by_user_id', 'code'],
});
export const GiftCodesByPaymentIntent = defineTable<
GiftCodeByPaymentIntentRow,
'stripe_payment_intent_id' | 'code',
'stripe_payment_intent_id'
>({
name: 'gift_codes_by_payment_intent',
columns: GIFT_CODE_BY_PAYMENT_INTENT_COLUMNS,
primaryKey: ['stripe_payment_intent_id', 'code'],
partitionKey: ['stripe_payment_intent_id'],
});
export const GiftCodesByRedeemer = defineTable({
name: 'gift_codes_by_redeemer',
columns: GIFT_CODE_BY_REDEEMER_COLUMNS,
primaryKey: ['redeemed_by_user_id', 'code'],
});
export const AdminArchivesBySubject = defineTable({
name: 'admin_archives_by_subject',
columns: ADMIN_ARCHIVE_COLUMNS,
primaryKey: ['subject_type', 'subject_id', 'archive_id'],
});
export const AdminArchivesByRequester = defineTable({
name: 'admin_archives_by_requester',
columns: ADMIN_ARCHIVE_COLUMNS,
primaryKey: ['requested_by', 'archive_id'],
});
export const AdminArchivesByType = defineTable({
name: 'admin_archives_by_type',
columns: ADMIN_ARCHIVE_COLUMNS,
primaryKey: ['subject_type', 'archive_id'],
});
export const AdminAuditLogs = defineTable({
name: 'admin_audit_logs',
columns: ADMIN_AUDIT_LOG_COLUMNS,
primaryKey: ['log_id'],
});
export const AdminApiKeys = defineTable({
name: 'admin_api_keys',
columns: ADMIN_API_KEY_COLUMNS,
primaryKey: ['key_id'],
});
export const AdminApiKeysByCreator = defineTable({
name: 'admin_api_keys_by_creator',
columns: ADMIN_API_KEY_BY_CREATOR_COLUMNS,
primaryKey: ['created_by_user_id', 'key_id'],
partitionKey: ['created_by_user_id'],
});
export const BannedIps = defineTable({
name: 'banned_ips',
columns: BANNED_IP_COLUMNS,
primaryKey: ['ip'],
});
export const BannedEmails = defineTable({
name: 'banned_emails',
columns: BANNED_EMAIL_COLUMNS,
primaryKey: ['email_lower'],
});
export const BannedPhones = defineTable({
name: 'banned_phones',
columns: BANNED_PHONE_COLUMNS,
primaryKey: ['phone'],
});
export const IARSubmissions = defineTable({
name: 'iar_submissions',
columns: IAR_SUBMISSION_COLUMNS,
primaryKey: ['report_id'],
});
export const DSAReportEmailVerifications = defineTable({
name: 'dsa_report_email_verifications',
columns: DSA_REPORT_EMAIL_VERIFICATION_COLUMNS,
primaryKey: ['email_lower'],
});
export const DSAReportTickets = defineTable({
name: 'dsa_report_tickets',
columns: DSA_REPORT_TICKET_COLUMNS,
primaryKey: ['ticket'],
});
export const EmailVerificationTokens = defineTable({
name: 'email_verification_tokens',
columns: EMAIL_VERIFICATION_TOKEN_COLUMNS,
primaryKey: ['token_', 'user_id'],
});
export const PasswordResetTokens = defineTable({
name: 'password_reset_tokens',
columns: PASSWORD_RESET_TOKEN_COLUMNS,
primaryKey: ['token_', 'user_id'],
});
export const EmailRevertTokens = defineTable({
name: 'email_revert_tokens',
columns: EMAIL_REVERT_TOKEN_COLUMNS,
primaryKey: ['token_', 'user_id'],
});
export const PhoneTokens = defineTable({
name: 'phone_tokens',
columns: PHONE_TOKEN_COLUMNS,
primaryKey: ['token_'],
});
export const AuthSessions = defineTable({
name: 'auth_sessions',
columns: AUTH_SESSION_COLUMNS,
primaryKey: ['session_id_hash'],
});
export const AuthSessionsByUserId = defineTable<
{user_id: UserID; session_id_hash: Buffer},
'user_id' | 'session_id_hash'
>({
name: 'auth_sessions_by_user_id',
columns: ['user_id', 'session_id_hash'],
primaryKey: ['user_id', 'session_id_hash'],
});
export const MfaBackupCodes = defineTable({
name: 'mfa_backup_codes',
columns: MFA_BACKUP_CODE_COLUMNS,
primaryKey: ['user_id', 'code'],
});
export const WebAuthnCredentials = defineTable({
name: 'webauthn_credentials',
columns: WEBAUTHN_CREDENTIAL_COLUMNS,
primaryKey: ['user_id', 'credential_id'],
});
export const WebAuthnCredentialLookup = defineTable<{credential_id: string; user_id: UserID}, 'credential_id'>({
name: 'webauthn_credential_lookup',
columns: ['credential_id', 'user_id'],
primaryKey: ['credential_id'],
});
export const IpAuthorizationTokens = defineTable({
name: 'ip_authorization_tokens',
columns: IP_AUTHORIZATION_TOKEN_COLUMNS,
primaryKey: ['token_', 'user_id'],
});
export const AuthorizedIps = defineTable({
name: 'authorized_ips_v2',
columns: AUTHORIZED_IP_COLUMNS,
primaryKey: ['user_id', 'ip'],
});
export const PasswordChangeTickets = defineTable({
name: 'password_change_tickets',
columns: PASSWORD_CHANGE_TICKET_COLUMNS,
primaryKey: ['ticket'],
});
export const EmailChangeTickets = defineTable({
name: 'email_change_tickets',
columns: EMAIL_CHANGE_TICKET_COLUMNS,
primaryKey: ['ticket'],
});
export const EmailChangeTokens = defineTable({
name: 'email_change_tokens',
columns: EMAIL_CHANGE_TOKEN_COLUMNS,
primaryKey: ['token_'],
});
interface AttachmentDecayByExpiryRow {
expiry_bucket: number;
expires_at: Date;
attachment_id: AttachmentID;
channel_id: ChannelID;
message_id: bigint;
}
const ATTACHMENT_DECAY_BY_EXPIRY_COLUMNS = [
'expiry_bucket',
'expires_at',
'attachment_id',
'channel_id',
'message_id',
] as const satisfies ReadonlyArray;
export const AttachmentDecayById = defineTable({
name: 'attachment_decay_by_id',
columns: ATTACHMENT_DECAY_COLUMNS,
primaryKey: ['attachment_id'],
});
export const AttachmentDecayByExpiry = defineTable<
AttachmentDecayByExpiryRow,
'expiry_bucket' | 'expires_at' | 'attachment_id'
>({
name: 'attachment_decay_by_expiry',
columns: ATTACHMENT_DECAY_BY_EXPIRY_COLUMNS,
primaryKey: ['expiry_bucket', 'expires_at', 'attachment_id'],
});
interface FavoriteMemesByMemeIdRow {
meme_id: MemeID;
user_id: UserID;
}
const FAVORITE_MEMES_BY_MEME_ID_COLUMNS = ['meme_id', 'user_id'] as const satisfies ReadonlyArray<
keyof FavoriteMemesByMemeIdRow
>;
export const FavoriteMemes = defineTable({
name: 'favorite_memes',
columns: FAVORITE_MEME_COLUMNS,
primaryKey: ['user_id', 'meme_id'],
});
export const FavoriteMemesByMemeId = defineTable({
name: 'favorite_memes_by_meme_id',
columns: FAVORITE_MEMES_BY_MEME_ID_COLUMNS,
primaryKey: ['meme_id', 'user_id'],
});
export const ExpressionPacks = defineTable({
name: 'expression_packs',
columns: EXPRESSION_PACK_COLUMNS,
primaryKey: ['pack_id'],
});
export const ExpressionPacksByCreator = defineTable({
name: 'expression_packs_by_creator',
columns: EXPRESSION_PACK_COLUMNS,
primaryKey: ['creator_id', 'pack_id'],
partitionKey: ['creator_id'],
});
const PACK_INSTALLATION_COLUMNS = ['user_id', 'pack_id', 'pack_type', 'installed_at'] as const satisfies ReadonlyArray<
keyof PackInstallationRow
>;
export const PackInstallations = defineTable({
name: 'pack_installations',
columns: PACK_INSTALLATION_COLUMNS,
primaryKey: ['user_id', 'pack_id'],
});
interface InvitesByChannelRow {
channel_id: ChannelID;
code: string;
}
interface InvitesByGuildRow {
guild_id: GuildID;
code: string;
}
const INVITES_BY_CHANNEL_COLUMNS = ['channel_id', 'code'] as const satisfies ReadonlyArray;
const INVITES_BY_GUILD_COLUMNS = ['guild_id', 'code'] as const satisfies ReadonlyArray;
export const Invites = defineTable({
name: 'invites',
columns: INVITE_COLUMNS,
primaryKey: ['code'],
});
export const InvitesByChannel = defineTable({
name: 'invites_by_channel_id',
columns: INVITES_BY_CHANNEL_COLUMNS,
primaryKey: ['channel_id', 'code'],
});
export const InvitesByGuild = defineTable({
name: 'invites_by_guild_id',
columns: INVITES_BY_GUILD_COLUMNS,
primaryKey: ['guild_id', 'code'],
});
const APPLICATIONS_BY_OWNER_COLUMNS = ['owner_user_id', 'application_id'] as const satisfies ReadonlyArray<
keyof ApplicationByOwnerRow
>;
export const Applications = defineTable({
name: 'applications',
columns: APPLICATION_COLUMNS,
primaryKey: ['application_id'],
});
export const ApplicationsByOwner = defineTable({
name: 'applications_by_owner',
columns: APPLICATIONS_BY_OWNER_COLUMNS,
primaryKey: ['owner_user_id', 'application_id'],
});
const OAUTH2_ACCESS_TOKENS_BY_USER_COLUMNS = ['user_id', 'token_'] as const satisfies ReadonlyArray<
keyof OAuth2AccessTokenByUserRow
>;
const OAUTH2_REFRESH_TOKENS_BY_USER_COLUMNS = ['user_id', 'token_'] as const satisfies ReadonlyArray<
keyof OAuth2RefreshTokenByUserRow
>;
export const OAuth2AuthorizationCodes = defineTable({
name: 'oauth2_authorization_codes',
columns: OAUTH2_AUTHORIZATION_CODE_COLUMNS,
primaryKey: ['code'],
});
export const OAuth2AccessTokens = defineTable({
name: 'oauth2_access_tokens',
columns: OAUTH2_ACCESS_TOKEN_COLUMNS,
primaryKey: ['token_'],
});
export const OAuth2AccessTokensByUser = defineTable({
name: 'oauth2_access_tokens_by_user',
columns: OAUTH2_ACCESS_TOKENS_BY_USER_COLUMNS,
primaryKey: ['user_id', 'token_'],
});
export const OAuth2RefreshTokens = defineTable({
name: 'oauth2_refresh_tokens',
columns: OAUTH2_REFRESH_TOKEN_COLUMNS,
primaryKey: ['token_'],
});
export const OAuth2RefreshTokensByUser = defineTable({
name: 'oauth2_refresh_tokens_by_user',
columns: OAUTH2_REFRESH_TOKENS_BY_USER_COLUMNS,
primaryKey: ['user_id', 'token_'],
});
interface WebhooksByChannelRow {
channel_id: ChannelID;
webhook_id: bigint;
}
interface WebhooksByGuildRow {
guild_id: GuildID;
webhook_id: bigint;
}
const WEBHOOKS_BY_CHANNEL_COLUMNS = ['channel_id', 'webhook_id'] as const satisfies ReadonlyArray<
keyof WebhooksByChannelRow
>;
const WEBHOOKS_BY_GUILD_COLUMNS = ['guild_id', 'webhook_id'] as const satisfies ReadonlyArray;
export const Webhooks = defineTable({
name: 'webhooks',
columns: WEBHOOK_COLUMNS,
primaryKey: ['webhook_id', 'webhook_token'],
});
export const WebhooksByChannel = defineTable({
name: 'webhooks_by_channel_id',
columns: WEBHOOKS_BY_CHANNEL_COLUMNS,
primaryKey: ['channel_id', 'webhook_id'],
});
export const WebhooksByGuild = defineTable({
name: 'webhooks_by_guild_id',
columns: WEBHOOKS_BY_GUILD_COLUMNS,
primaryKey: ['guild_id', 'webhook_id'],
});
export const InstanceConfiguration = defineTable({
name: 'instance_configuration',
columns: INSTANCE_CONFIGURATION_COLUMNS,
primaryKey: ['key'],
});
export const CsamEvidencePackages = defineTable({
name: 'csam_evidence_packages',
columns: CSAM_EVIDENCE_PACKAGE_COLUMNS,
primaryKey: ['report_id'],
});
export const CsamEvidenceExpirations = defineTable({
name: 'csam_evidence_expirations',
columns: CSAM_EVIDENCE_EXPIRATION_COLUMNS,
primaryKey: ['bucket', 'expires_at', 'report_id'],
partitionKey: ['bucket'],
});
export const CsamScanJobs = defineTable({
name: 'csam_scan_jobs',
columns: CSAM_SCAN_JOB_COLUMNS,
primaryKey: ['job_id'],
});
export const CsamEvidenceLegalHolds = defineTable({
name: 'csam_evidence_legal_holds',
columns: CSAM_EVIDENCE_LEGAL_HOLD_COLUMNS,
primaryKey: ['report_id'],
});
export const NcmecSubmissions = defineTable({
name: 'ncmec_submissions',
columns: NCMEC_SUBMISSION_COLUMNS,
primaryKey: ['report_id'],
});