-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathconfig.js
More file actions
53 lines (45 loc) · 1.82 KB
/
config.js
File metadata and controls
53 lines (45 loc) · 1.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
require('dotenv').config();
const path = require('path');
const fs = require('fs').promises;
const fsSync = require('fs');
module.exports = {
// Server Configuration
PORT: process.env.PORT || 3000,
NODE_ENV: process.env.NODE_ENV || 'development',
// Security
ADMIN_PASSWORD: process.env.ADMIN_PASSWORD || 'admin',
SESSION_SECRET: process.env.SESSION_SECRET || 'your-secret-key-change-this-in-production',
MAX_FILE_SIZE: parseInt(process.env.MAX_FILE_SIZE) || 10 * 1024 * 1024, // 10MB
// Paths
DATA_DIR: path.join(__dirname, 'data'),
UPLOADS_DIR: path.join(__dirname, 'uploads'),
ICONS_DIR: path.join(__dirname, 'uploads', 'icons'),
MARKERS_DATA_FILE: path.join(__dirname, 'data', 'markers.json'),
MAP_DATA_FILE: path.join(__dirname, 'data', 'map.json'),
CATEGORIES_DATA_FILE: path.join(__dirname, 'data', 'categories.json'),
ICON_TYPES_FILE: path.join(__dirname, 'data', 'icon-types.json'),
SETTINGS_FILE: path.join(__dirname, 'data', 'settings.json'),
// Cache Configuration
CACHE_TTL: 5000, // 5 seconds
// Rate Limiting
RATE_LIMIT_WINDOW_MS: 15 * 60 * 1000, // 15 minutes
RATE_LIMIT_MAX_REQUESTS: 100, // max 100 requests per window
// Get admin password (async)
// Priority: settings.json > environment variable
async getAdminPassword() {
try {
const settingsPath = path.join(__dirname, 'data', 'settings.json');
if (fsSync.existsSync(settingsPath)) {
const data = await fs.readFile(settingsPath, 'utf8');
const settings = JSON.parse(data);
if (settings.adminPasswordHash) {
return { hash: settings.adminPasswordHash, isHash: true };
}
}
} catch (error) {
console.error('Error reading password from settings:', error);
}
// Fallback to environment variable
return { password: this.ADMIN_PASSWORD, isHash: false };
}
};