@sync-in/server
Version:
The secure, open-source platform for file storage, sharing, collaboration, and sync
49 lines (48 loc) • 1.63 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, "usersGroups", {
enumerable: true,
get: function() {
return usersGroups;
}
});
const _drizzleorm = require("drizzle-orm");
const _mysqlcore = require("drizzle-orm/mysql-core");
const _groupsschema = require("./groups.schema");
const _usersschema = require("./users.schema");
const usersGroups = (0, _mysqlcore.mysqlTable)('users_groups', {
userId: (0, _mysqlcore.bigint)('userId', {
mode: 'number',
unsigned: true
}).references(()=>_usersschema.users.id, {
onDelete: 'cascade'
}).notNull(),
groupId: (0, _mysqlcore.bigint)('groupId', {
mode: 'number',
unsigned: true
}).references(()=>_groupsschema.groups.id, {
onDelete: 'cascade'
}).notNull(),
role: (0, _mysqlcore.tinyint)('role', {
unsigned: true
}).default(0).notNull(),
createdAt: (0, _mysqlcore.datetime)('createdAt', {
mode: 'date'
}).default((0, _drizzleorm.sql)`CURRENT_TIMESTAMP`).notNull()
}, (table)=>[
(0, _mysqlcore.primaryKey)({
columns: [
table.userId,
table.groupId
]
}),
(0, _mysqlcore.index)('user_idx').on(table.userId),
(0, _mysqlcore.index)('group_idx').on(table.groupId)
]);
//# sourceMappingURL=users-groups.schema.js.map