refactor: Update .gitignore and package.json, and add database functionality
This commit is contained in:
31
src/lib/db.ts
Normal file
31
src/lib/db.ts
Normal file
@@ -0,0 +1,31 @@
|
||||
import { sql } from '@vercel/postgres';
|
||||
import { config } from 'dotenv';
|
||||
|
||||
var hasLoadedEnv = false;
|
||||
function loadEnv() {
|
||||
if (hasLoadedEnv) {
|
||||
return;
|
||||
}
|
||||
config();
|
||||
}
|
||||
|
||||
async function createDownloadsTable() {
|
||||
loadEnv();
|
||||
await sql`
|
||||
CREATE TABLE IF NOT EXISTS downloads (
|
||||
id SERIAL PRIMARY KEY,
|
||||
platform TEXT NOT NULL,
|
||||
count INT NOT NULL
|
||||
);
|
||||
`;
|
||||
}
|
||||
|
||||
export async function addDownload(platform: string) {
|
||||
await createDownloadsTable();
|
||||
await sql`
|
||||
INSERT INTO downloads (platform, count)
|
||||
VALUES (${platform}, 1)
|
||||
ON CONFLICT (platform)
|
||||
DO UPDATE SET count = downloads.count + 1;
|
||||
`;
|
||||
}
|
||||
Reference in New Issue
Block a user