@sync-in/server
Version:
The secure, open-source platform for file storage, sharing, collaboration, and sync
46 lines (45 loc) • 1.59 kB
JavaScript
/*
* Copyright (C) 2012-2025 Johan Legrand <johan.legrand@sync-in.com>
* This file is part of Sync-in | The open source file sync and share solution
* See the LICENSE file for licensing details
*/ "use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "usersGuests", {
enumerable: true,
get: function() {
return usersGuests;
}
});
const _drizzleorm = require("drizzle-orm");
const _mysqlcore = require("drizzle-orm/mysql-core");
const _usersschema = require("./users.schema");
const usersGuests = (0, _mysqlcore.mysqlTable)('users_guests', {
userId: (0, _mysqlcore.bigint)('userId', {
mode: 'number',
unsigned: true
}).references(()=>_usersschema.users.id, {
onDelete: 'cascade'
}).notNull(),
guestId: (0, _mysqlcore.bigint)('guestId', {
mode: 'number',
unsigned: true
}).references(()=>_usersschema.users.id, {
onDelete: 'cascade'
}).notNull(),
createdAt: (0, _mysqlcore.datetime)('createdAt', {
mode: 'date'
}).default((0, _drizzleorm.sql)`CURRENT_TIMESTAMP`).notNull()
}, (table)=>[
(0, _mysqlcore.primaryKey)({
columns: [
table.userId,
table.guestId
]
}),
(0, _mysqlcore.index)('user_idx').on(table.userId),
(0, _mysqlcore.index)('guest_id').on(table.guestId),
(0, _mysqlcore.check)('user_guest_check', (0, _drizzleorm.sql)`${table.userId} <> ${table.guestId}`)
]);
//# sourceMappingURL=users-guests.schema.js.map