embedder/app/types/db.ts
2022-12-07 16:30:39 +00:00

37 lines
No EOL
754 B
TypeScript

import sqlite3 from "sqlite3";
import mkdirp from "mkdirp";
import crypto from "crypto";
mkdirp.sync("./uploads");
mkdirp.sync("./var/db");
export const db = new sqlite3.Database("./var/db/media.db");
export function createUser(username: string, password: string) {
var salt = crypto.randomBytes(16);
db.run("INSERT OR IGNORE INTO users (username, hashed_password, salt) VALUES (?, ?, ?)", [
username,
crypto.pbkdf2Sync(password, salt, 310000, 32, "sha256"),
salt
]);
}
export interface MediaRow {
id? : Number,
path: String,
expire: Date,
username?: String
}
export type MediaParams = [
path: String,
expire: Date,
username?: String
]
export interface UserRow {
id? : Number,
username: String,
hashed_password: any,
salt: any
}