UNPKG

@coursebuilder/adapter-drizzle

Version:

Drizzle adapter for Course Builder.

402 lines (362 loc) 15.6 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/lib/mysql/schemas/communication/communication-preferences.ts var communication_preferences_exports = {}; __export(communication_preferences_exports, { getCommunicationPreferencesRelationsSchema: () => getCommunicationPreferencesRelationsSchema, getCommunicationPreferencesSchema: () => getCommunicationPreferencesSchema }); module.exports = __toCommonJS(communication_preferences_exports); var import_drizzle_orm33 = require("drizzle-orm"); var import_mysql_core37 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/users.ts var import_drizzle_orm32 = require("drizzle-orm"); var import_mysql_core34 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/purchase.ts var import_drizzle_orm25 = require("drizzle-orm"); var import_mysql_core27 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/org/organization-memberships.ts var import_drizzle_orm23 = require("drizzle-orm"); var import_mysql_core23 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/org/organization-membership-roles.ts var import_drizzle_orm22 = require("drizzle-orm"); var import_mysql_core22 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/roles.ts var import_drizzle_orm2 = require("drizzle-orm"); var import_mysql_core2 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/user-roles.ts var import_drizzle_orm = require("drizzle-orm"); var import_mysql_core = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/org/organizations.ts var import_drizzle_orm21 = require("drizzle-orm"); var import_mysql_core21 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/subscription.ts var import_drizzle_orm20 = require("drizzle-orm"); var import_mysql_core20 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-subscription.ts var import_drizzle_orm7 = require("drizzle-orm"); var import_mysql_core7 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-charge.ts var import_drizzle_orm6 = require("drizzle-orm"); var import_mysql_core6 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-account.ts var import_drizzle_orm3 = require("drizzle-orm"); var import_mysql_core3 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-customer.ts var import_drizzle_orm4 = require("drizzle-orm"); var import_mysql_core4 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-product.ts var import_drizzle_orm5 = require("drizzle-orm"); var import_mysql_core5 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/product.ts var import_drizzle_orm19 = require("drizzle-orm"); var import_mysql_core19 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-resource-product.ts var import_drizzle_orm16 = require("drizzle-orm"); var import_mysql_core16 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-resource.ts var import_drizzle_orm15 = require("drizzle-orm"); var import_mysql_core15 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-contributions.ts var import_drizzle_orm9 = require("drizzle-orm"); var import_mysql_core9 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/contribution-types.ts var import_drizzle_orm8 = require("drizzle-orm"); var import_mysql_core8 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-resource-resource.ts var import_drizzle_orm10 = require("drizzle-orm"); var import_mysql_core10 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-resource-tag.ts var import_drizzle_orm13 = require("drizzle-orm"); var import_mysql_core13 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/tag.ts var import_drizzle_orm12 = require("drizzle-orm"); var import_mysql_core12 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/tag-tag.ts var import_drizzle_orm11 = require("drizzle-orm"); var import_mysql_core11 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/content/content-resource-version.ts var import_drizzle_orm14 = require("drizzle-orm"); var import_mysql_core14 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/price.ts var import_drizzle_orm18 = require("drizzle-orm"); var import_mysql_core18 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-price.ts var import_drizzle_orm17 = require("drizzle-orm"); var import_mysql_core17 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/org/organization-memberships.ts function getOrganizationMembershipsSchema(mysqlTable) { return mysqlTable("OrganizationMembership", { id: (0, import_mysql_core23.varchar)("id", { length: 255 }).notNull().primaryKey(), organizationId: (0, import_mysql_core23.varchar)("organizationId", { length: 191 }), role: (0, import_mysql_core23.varchar)("role", { length: 191 }).notNull().default("user"), invitedById: (0, import_mysql_core23.varchar)("invitedById", { length: 255 }).notNull(), userId: (0, import_mysql_core23.varchar)("userId", { length: 255 }).notNull(), fields: (0, import_mysql_core23.json)("fields").$type().default({}), createdAt: (0, import_mysql_core23.timestamp)("createdAt", { mode: "date", fsp: 3 }).default(import_drizzle_orm23.sql`CURRENT_TIMESTAMP(3)`) }, (organizationMembership) => ({ roleIdx: (0, import_mysql_core23.index)("role_idx").on(organizationMembership.role), createdAtIdx: (0, import_mysql_core23.index)("created_at_idx").on(organizationMembership.createdAt), organizationIdIdx: (0, import_mysql_core23.index)("organizationId_idx").on(organizationMembership.organizationId) })); } __name(getOrganizationMembershipsSchema, "getOrganizationMembershipsSchema"); // src/lib/mysql/schemas/commerce/coupon.ts var import_drizzle_orm24 = require("drizzle-orm"); var import_mysql_core25 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-coupon.ts var import_mysql_core24 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/commerce/merchant-session.ts var import_mysql_core26 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/communication/comment.ts var import_drizzle_orm26 = require("drizzle-orm"); var import_mysql_core28 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/accounts.ts var import_drizzle_orm27 = require("drizzle-orm"); var import_mysql_core29 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/profiles.ts var import_drizzle_orm28 = require("drizzle-orm"); var import_mysql_core30 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/user-permissions.ts var import_drizzle_orm30 = require("drizzle-orm"); var import_mysql_core32 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/permissions.ts var import_drizzle_orm29 = require("drizzle-orm"); var import_mysql_core31 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/user-prefs.ts var import_drizzle_orm31 = require("drizzle-orm"); var import_mysql_core33 = require("drizzle-orm/mysql-core"); // src/lib/mysql/schemas/auth/users.ts function getUsersSchema(mysqlTable) { return mysqlTable("User", { id: (0, import_mysql_core34.varchar)("id", { length: 255 }).notNull().primaryKey(), name: (0, import_mysql_core34.varchar)("name", { length: 255 }), role: (0, import_mysql_core34.varchar)("role", { length: 191 }).notNull().default("user"), email: (0, import_mysql_core34.varchar)("email", { length: 255 }).notNull().unique(), fields: (0, import_mysql_core34.json)("fields").$type().default({}), emailVerified: (0, import_mysql_core34.timestamp)("emailVerified", { mode: "date", fsp: 3 }), image: (0, import_mysql_core34.varchar)("image", { length: 255 }), createdAt: (0, import_mysql_core34.timestamp)("createdAt", { mode: "date", fsp: 3 }).default(import_drizzle_orm32.sql`CURRENT_TIMESTAMP(3)`) }, (user) => ({ emailIdx: (0, import_mysql_core34.index)("email_idx").on(user.email), roleIdx: (0, import_mysql_core34.index)("role_idx").on(user.role), createdAtIdx: (0, import_mysql_core34.index)("created_at_idx").on(user.createdAt) })); } __name(getUsersSchema, "getUsersSchema"); // src/lib/mysql/schemas/communication/communication-channel.ts var import_mysql_core35 = require("drizzle-orm/mysql-core"); function getCommunicationChannelSchema(mysqlTable) { return mysqlTable("CommunicationChannel", { id: (0, import_mysql_core35.varchar)("id", { length: 255 }).notNull().primaryKey(), organizationId: (0, import_mysql_core35.varchar)("organizationId", { length: 191 }), name: (0, import_mysql_core35.varchar)("name", { length: 255 }).notNull(), description: (0, import_mysql_core35.text)("description"), active: (0, import_mysql_core35.boolean)("active").notNull().default(true), createdAt: (0, import_mysql_core35.timestamp)("createdAt", { mode: "date", fsp: 3 }).defaultNow(), updatedAt: (0, import_mysql_core35.timestamp)("updatedAt", { mode: "date", fsp: 3 }).defaultNow(), deletedAt: (0, import_mysql_core35.timestamp)("deletedAt", { mode: "date", fsp: 3 }) }, (cc) => ({ nameIdx: (0, import_mysql_core35.index)("name_idx").on(cc.name), organizationIdIdx: (0, import_mysql_core35.index)("organizationId_idx").on(cc.organizationId) })); } __name(getCommunicationChannelSchema, "getCommunicationChannelSchema"); // src/lib/mysql/schemas/communication/communication-preference-types.ts var import_mysql_core36 = require("drizzle-orm/mysql-core"); function getCommunicationPreferenceTypesSchema(mysqlTable) { return mysqlTable("CommunicationPreferenceType", { id: (0, import_mysql_core36.varchar)("id", { length: 255 }).notNull().primaryKey(), organizationId: (0, import_mysql_core36.varchar)("organizationId", { length: 191 }), name: (0, import_mysql_core36.varchar)("name", { length: 255 }).notNull(), description: (0, import_mysql_core36.text)("description"), active: (0, import_mysql_core36.boolean)("active").notNull().default(true), createdAt: (0, import_mysql_core36.timestamp)("createdAt", { mode: "date", fsp: 3 }).defaultNow(), updatedAt: (0, import_mysql_core36.timestamp)("updatedAt", { mode: "date", fsp: 3 }), deletedAt: (0, import_mysql_core36.timestamp)("deletedAt", { mode: "date", fsp: 3 }) }); } __name(getCommunicationPreferenceTypesSchema, "getCommunicationPreferenceTypesSchema"); // src/lib/mysql/schemas/communication/communication-preferences.ts function getCommunicationPreferencesSchema(mysqlTable) { return mysqlTable("CommunicationPreference", { id: (0, import_mysql_core37.varchar)("id", { length: 255 }).notNull().primaryKey(), organizationId: (0, import_mysql_core37.varchar)("organizationId", { length: 191 }), userId: (0, import_mysql_core37.varchar)("userId", { length: 255 }).notNull(), organizationMembershipId: (0, import_mysql_core37.varchar)("organizationMembershipId", { length: 255 }), channelId: (0, import_mysql_core37.varchar)("channelId", { length: 255 }).notNull(), preferenceLevel: (0, import_mysql_core37.mysqlEnum)("preferenceLevel", [ "low", "medium", "high" ]).notNull().default("medium"), preferenceTypeId: (0, import_mysql_core37.varchar)("preferenceTypeId", { length: 255 }).notNull(), active: (0, import_mysql_core37.boolean)("active").notNull().default(true), createdAt: (0, import_mysql_core37.timestamp)("createdAt", { mode: "date", fsp: 3 }).defaultNow(), optInAt: (0, import_mysql_core37.timestamp)("optInAt", { mode: "date", fsp: 3 }), optOutAt: (0, import_mysql_core37.timestamp)("optOutAt", { mode: "date", fsp: 3 }), updatedAt: (0, import_mysql_core37.timestamp)("updatedAt", { mode: "date", fsp: 3 }).defaultNow(), deletedAt: (0, import_mysql_core37.timestamp)("deletedAt", { mode: "date", fsp: 3 }) }, (cp) => ({ userIdIdx: (0, import_mysql_core37.index)("userId_idx").on(cp.userId), preferenceTypeIdx: (0, import_mysql_core37.index)("preferenceTypeId_idx").on(cp.preferenceTypeId), channelIdIdx: (0, import_mysql_core37.index)("channelId_idx").on(cp.channelId), organizationMembershipIdIdx: (0, import_mysql_core37.index)("organizationMembershipId_idx").on(cp.organizationMembershipId) })); } __name(getCommunicationPreferencesSchema, "getCommunicationPreferencesSchema"); function getCommunicationPreferencesRelationsSchema(mysqlTable) { const communicationPreferences = getCommunicationPreferencesSchema(mysqlTable); const users = getUsersSchema(mysqlTable); const communicationChannel = getCommunicationChannelSchema(mysqlTable); const communicationPreferenceTypes = getCommunicationPreferenceTypesSchema(mysqlTable); const organizationMemberships = getOrganizationMembershipsSchema(mysqlTable); return (0, import_drizzle_orm33.relations)(communicationPreferences, ({ one }) => ({ user: one(users, { fields: [ communicationPreferences.userId ], references: [ users.id ], relationName: "user" }), organizationMembership: one(organizationMemberships, { fields: [ communicationPreferences.organizationMembershipId ], references: [ organizationMemberships.id ], relationName: "organizationMembership" }), channel: one(communicationChannel, { fields: [ communicationPreferences.channelId ], references: [ communicationChannel.id ], relationName: "channel" }), preferenceType: one(communicationPreferenceTypes, { fields: [ communicationPreferences.preferenceTypeId ], references: [ communicationPreferenceTypes.id ], relationName: "preferenceType" }) })); } __name(getCommunicationPreferencesRelationsSchema, "getCommunicationPreferencesRelationsSchema"); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { getCommunicationPreferencesRelationsSchema, getCommunicationPreferencesSchema }); //# sourceMappingURL=communication-preferences.cjs.map