mirror of https://github.com/wg-easy/wg-easy
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.8 KiB
54 lines
1.8 KiB
import { sql, relations } from 'drizzle-orm';
|
|
import { int, sqliteTable, text } from 'drizzle-orm/sqlite-core';
|
|
|
|
import { oneTimeLink, user } from '../../schema';
|
|
|
|
/** null means use value from userConfig */
|
|
|
|
export const client = sqliteTable('clients_table', {
|
|
id: int().primaryKey({ autoIncrement: true }),
|
|
userId: int('user_id')
|
|
.notNull()
|
|
.references(() => user.id, {
|
|
onDelete: 'restrict',
|
|
onUpdate: 'cascade',
|
|
}),
|
|
name: text().notNull(),
|
|
ipv4Address: text('ipv4_address').notNull().unique(),
|
|
ipv6Address: text('ipv6_address').notNull().unique(),
|
|
preUp: text('pre_up').default('').notNull(),
|
|
postUp: text('post_up').default('').notNull(),
|
|
preDown: text('pre_down').default('').notNull(),
|
|
postDown: text('post_down').default('').notNull(),
|
|
privateKey: text('private_key').notNull(),
|
|
publicKey: text('public_key').notNull(),
|
|
preSharedKey: text('pre_shared_key').notNull(),
|
|
expiresAt: text('expires_at'),
|
|
allowedIps: text('allowed_ips', { mode: 'json' }).$type<string[]>(),
|
|
serverAllowedIps: text('server_allowed_ips', { mode: 'json' })
|
|
.$type<string[]>()
|
|
.notNull(),
|
|
persistentKeepalive: int('persistent_keepalive').notNull(),
|
|
mtu: int().notNull(),
|
|
dns: text({ mode: 'json' }).$type<string[]>(),
|
|
serverEndpoint: text('server_endpoint'),
|
|
enabled: int({ mode: 'boolean' }).notNull(),
|
|
createdAt: text('created_at')
|
|
.notNull()
|
|
.default(sql`(CURRENT_TIMESTAMP)`),
|
|
updatedAt: text('updated_at')
|
|
.notNull()
|
|
.default(sql`(CURRENT_TIMESTAMP)`)
|
|
.$onUpdate(() => sql`(CURRENT_TIMESTAMP)`),
|
|
});
|
|
|
|
export const clientsRelations = relations(client, ({ one }) => ({
|
|
oneTimeLink: one(oneTimeLink, {
|
|
fields: [client.id],
|
|
references: [oneTimeLink.id],
|
|
}),
|
|
user: one(user, {
|
|
fields: [client.userId],
|
|
references: [user.id],
|
|
}),
|
|
}));
|
|
|