|
| 1 | + |
| 2 | +const fs = require('fs'); |
| 3 | +const initSqlJs = require('sql.js'); |
| 4 | +const path = require('path'); |
| 5 | + |
| 6 | +async function main() { |
| 7 | + const SQL = await initSqlJs(); |
| 8 | + const db = new SQL.Database(); |
| 9 | + |
| 10 | + console.log("Creating tables..."); |
| 11 | + db.run(` |
| 12 | + CREATE TABLE IF NOT EXISTS warga ( |
| 13 | + id INTEGER PRIMARY KEY AUTOINCREMENT, |
| 14 | + nama TEXT NOT NULL, |
| 15 | + alamat TEXT, |
| 16 | + status TEXT, |
| 17 | + telepon TEXT |
| 18 | + ); |
| 19 | +
|
| 20 | + CREATE TABLE IF NOT EXISTS security_reports ( |
| 21 | + id INTEGER PRIMARY KEY AUTOINCREMENT, |
| 22 | + jenis_kejadian TEXT, |
| 23 | + lokasi TEXT, |
| 24 | + tanggal_kejadian TEXT, |
| 25 | + status TEXT, |
| 26 | + priority TEXT, |
| 27 | + nama_pelapor TEXT, |
| 28 | + telepon_pelapor TEXT, |
| 29 | + kronologi TEXT |
| 30 | + ); |
| 31 | +
|
| 32 | + CREATE TABLE IF NOT EXISTS users ( |
| 33 | + id INTEGER PRIMARY KEY AUTOINCREMENT, |
| 34 | + email TEXT UNIQUE, |
| 35 | + password TEXT, |
| 36 | + nama TEXT, |
| 37 | + role TEXT, |
| 38 | + no_telepon TEXT |
| 39 | + ); |
| 40 | + `); |
| 41 | + |
| 42 | + console.log("Seeding demo users..."); |
| 43 | + // Demo data based on previous context |
| 44 | + const users = [ |
| 45 | + { email: 'admin@rt0409.local', password: 'password123', nama: 'Admin RT', role: 'admin', phone: '081234567890' }, |
| 46 | + { email: 'warga@rt0409.local', password: 'password123', nama: 'Budi Warga', role: 'warga', phone: '081234567891' }, |
| 47 | + { email: 'pengurus@rt0409.local', password: 'password123', nama: 'Siti Pengurus', role: 'pengurus', phone: '081234567892' } |
| 48 | + ]; |
| 49 | + |
| 50 | + const stmt = db.prepare("INSERT INTO users (email, password, nama, role, no_telepon) VALUES (?, ?, ?, ?, ?)"); |
| 51 | + users.forEach(u => stmt.run([u.email, u.password, u.nama, u.role, u.phone])); |
| 52 | + stmt.free(); |
| 53 | + |
| 54 | + console.log("Seeding 50 random warga..."); |
| 55 | + db.run("BEGIN TRANSACTION"); |
| 56 | + const stmtWarga = db.prepare("INSERT INTO warga (nama, alamat, status, telepon) VALUES (?, ?, ?, ?)"); |
| 57 | + |
| 58 | + const names = ["Andi", "Budi", "Citra", "Dedi", "Eka", "Fani", "Gita", "Hadi", "Indah", "Joko"]; |
| 59 | + const lastNames = ["Santoso", "Wijaya", "Putri", "Kusuma", "Lestari", "Pratama", "Saputra", "Hidayat", "Sari", "Utami"]; |
| 60 | + const streets = ["Mawar", "Melati", "Anggrek", "Kenanga", "Flamboyan", "Dahlia", "Tulip"]; |
| 61 | + |
| 62 | + for (let i = 0; i < 50; i++) { |
| 63 | + const name = `${names[Math.floor(Math.random() * names.length)]} ${lastNames[Math.floor(Math.random() * lastNames.length)]}`; |
| 64 | + const address = `Jl. ${streets[Math.floor(Math.random() * streets.length)]} No. ${Math.floor(Math.random() * 100)}`; |
| 65 | + const status = Math.random() > 0.3 ? "Tetap" : "Kontrak"; |
| 66 | + const phone = `0812${Math.floor(Math.random() * 100000000)}`; |
| 67 | + |
| 68 | + stmtWarga.run([name, address, status, phone]); |
| 69 | + } |
| 70 | + stmtWarga.free(); |
| 71 | + db.run("COMMIT"); |
| 72 | + |
| 73 | + console.log("Saving to prisma_demo.db..."); |
| 74 | + const data = db.export(); |
| 75 | + const buffer = Buffer.from(data); |
| 76 | + fs.writeFileSync(path.join(__dirname, '../prisma_demo.db'), buffer); |
| 77 | + console.log("Done!"); |
| 78 | +} |
| 79 | + |
| 80 | +main().catch(console.error); |
0 commit comments