Files
portfolio/scripts/setup-database.js
denshooter f7e0172111
Some checks failed
CI/CD Pipeline / test (push) Successful in 10m54s
Security Scan / security (push) Failing after 5m21s
CI/CD Pipeline / security (push) Successful in 5m25s
CI/CD Pipeline / build (push) Failing after 2m27s
CI/CD Pipeline / deploy (push) Has been skipped
Refactor security scanning and database setup
- Update security scan workflow to utilize a dedicated script for checking secrets, improving detection accuracy.
- Modify database connection setup in multiple scripts to use an environment variable fallback for DATABASE_URL, enhancing flexibility in different environments.
2025-09-11 11:17:35 +02:00

53 lines
1.5 KiB
JavaScript

#!/usr/bin/env node
/* eslint-disable @typescript-eslint/no-require-imports */
const { exec } = require('child_process');
console.log('🗄️ Setting up database...');
// Set environment variables for development
process.env.DATABASE_URL = process.env.DATABASE_URL || 'postgresql://portfolio_user:portfolio_dev_pass@localhost:5432/portfolio_dev?schema=public';
// Function to run command and return promise
function runCommand(command) {
return new Promise((resolve, reject) => {
console.log(`Running: ${command}`);
exec(command, (error, stdout, stderr) => {
if (error) {
console.error(`Error: ${error.message}`);
reject(error);
return;
}
if (stderr) {
console.log(`Stderr: ${stderr}`);
}
console.log(`Output: ${stdout}`);
resolve(stdout);
});
});
}
async function setupDatabase() {
try {
console.log('📦 Generating Prisma client...');
await runCommand('npx prisma generate');
console.log('🔄 Pushing database schema...');
await runCommand('npx prisma db push');
console.log('🌱 Seeding database...');
await runCommand('npx prisma db seed');
console.log('✅ Database setup complete!');
console.log('🚀 You can now run: npm run dev');
} catch (error) {
console.error('❌ Database setup failed:', error.message);
console.log('💡 Make sure PostgreSQL is running on localhost:5432');
console.log('💡 Try: docker-compose -f docker-compose.dev.minimal.yml up -d');
process.exit(1);
}
}
setupDatabase();