summaryrefslogtreecommitdiff
path: root/packages/backend/src/models/UserSecurityKey.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-09-20 11:33:36 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-09-20 11:33:36 +0900
commit053da10e94c2412f58215116a958c0922261a610 (patch)
treed608ce6350d5b209178390c3ab56c1fd0d30c438 /packages/backend/src/models/UserSecurityKey.ts
parentfix (diff)
downloadsharkey-053da10e94c2412f58215116a958c0922261a610.tar.gz
sharkey-053da10e94c2412f58215116a958c0922261a610.tar.bz2
sharkey-053da10e94c2412f58215116a958c0922261a610.zip
refactor(backend): update directory structure for models
Diffstat (limited to 'packages/backend/src/models/UserSecurityKey.ts')
-rw-r--r--packages/backend/src/models/UserSecurityKey.ts76
1 files changed, 76 insertions, 0 deletions
diff --git a/packages/backend/src/models/UserSecurityKey.ts b/packages/backend/src/models/UserSecurityKey.ts
new file mode 100644
index 0000000000..02c29bfbb5
--- /dev/null
+++ b/packages/backend/src/models/UserSecurityKey.ts
@@ -0,0 +1,76 @@
+/*
+ * SPDX-FileCopyrightText: syuilo and other misskey contributors
+ * SPDX-License-Identifier: AGPL-3.0-only
+ */
+
+import { PrimaryColumn, Entity, JoinColumn, Column, ManyToOne, Index } from 'typeorm';
+import { id } from './util/id.js';
+import { MiUser } from './User.js';
+
+@Entity('user_security_key')
+export class MiUserSecurityKey {
+ @PrimaryColumn('varchar', {
+ comment: 'Variable-length id given to navigator.credentials.get()',
+ })
+ public id: string;
+
+ @Index()
+ @Column(id())
+ public userId: MiUser['id'];
+
+ @ManyToOne(type => MiUser, {
+ onDelete: 'CASCADE',
+ })
+ @JoinColumn()
+ public user: MiUser | null;
+
+ @Column('varchar', {
+ comment: 'User-defined name for this key',
+ length: 30,
+ })
+ public name: string;
+
+ @Index()
+ @Column('varchar', {
+ comment: 'The public key of the UserSecurityKey, hex-encoded.',
+ })
+ public publicKey: string;
+
+ @Column('bigint', {
+ comment: 'The number of times the UserSecurityKey was validated.',
+ default: 0,
+ })
+ public counter: number;
+
+ @Column('timestamp with time zone', {
+ comment: 'Timestamp of the last time the UserSecurityKey was used.',
+ default: () => 'now()',
+ })
+ public lastUsed: Date;
+
+ @Column('varchar', {
+ comment: 'The type of Backup Eligibility in authenticator data',
+ length: 32, nullable: true,
+ })
+ public credentialDeviceType: string | null;
+
+ @Column('boolean', {
+ comment: 'Whether or not the credential has been backed up',
+ nullable: true,
+ })
+ public credentialBackedUp: boolean | null;
+
+ @Column('varchar', {
+ comment: 'The type of the credential returned by the browser',
+ length: 32, array: true, nullable: true,
+ })
+ public transports: string[] | null;
+
+ constructor(data: Partial<MiUserSecurityKey>) {
+ if (data == null) return;
+
+ for (const [k, v] of Object.entries(data)) {
+ (this as any)[k] = v;
+ }
+ }
+}