const fs = require('node:fs/promises'); const crypto = require('crypto'); const path = require('path'); // Функция хеширования паролей как в системе function hashPassword(password) { // Шаг 1: MD5 от пароля const firstHash = crypto.createHash('md5').update(password).digest('hex'); // Шаг 2: MD5 от (первый_хэш + "pult2024") const finalHash = crypto.createHash('md5').update(firstHash + "pult2024").digest('hex'); return finalHash; } async function addTestUser() { try { // Читаем текущий файл пользователей const avtPath = path.join(__dirname, 'data/avt.ini'); const avtData = await fs.readFile(avtPath, 'utf8'); const avt = JSON.parse(avtData); console.log('Текущие пользователи:', Object.keys(avt)); // Добавляем тестового пользователя const testPhone = '79999999999'; const testPassword = '12345'; avt[testPhone] = { "_id": 999, "cdata": Date.now() / 1000, "pass": hashPassword(testPassword), "tel": parseInt(testPhone), "group": 3, "color": "#00ff00", "fio": "Тестовый Пользователь", "groupz": { "_id": 3, "name": "Программист", "access": { "fullaccess": {}, "user": {}, "admin": { "egroup": [40, 50, 60, 70] } }, "color": "5235bb" }, "access": { "fullaccess": {}, "user": {}, "admin": { "egroup": [40, 50, 60, 70] } }, "taccess": "operators" }; // Сохраняем обновленный файл await fs.writeFile(avtPath, JSON.stringify(avt, null, 2)); console.log('✅ Тестовый пользователь добавлен:'); console.log('Телефон:', testPhone); console.log('Пароль:', testPassword); console.log('Хеш пароля:', hashPassword(testPassword)); } catch (error) { console.error('Ошибка:', error); } } addTestUser();