final 0 , sem clerk

This commit is contained in:
2026-03-14 21:27:32 -03:00
parent 13d18d3fc3
commit 62211c88d9
2 changed files with 51 additions and 45 deletions

View File

@@ -41,7 +41,7 @@ export const GeometrySettings: React.FC = () => {
const handleOpenModal = (item?: GeometryType) => { const handleOpenModal = (item?: GeometryType) => {
if (item) { if (item) {
setEditingItem(item); setEditingItem(item);
setForm({ name: item.name, efficiencyLoss: item.efficiencyLoss.toString() }); setForm({ name: item.name, efficiencyLoss: (item.efficiencyLoss ?? 0).toString() });
} else { } else {
setEditingItem(null); setEditingItem(null);
setForm({ name: '', efficiencyLoss: '20' }); setForm({ name: '', efficiencyLoss: '20' });

View File

@@ -1,11 +1,13 @@
import mongoose from 'mongoose'; import mongoose from 'mongoose';
import bcrypt from 'bcryptjs'; import bcrypt from 'bcryptjs';
import { v4 as uuidv4 } from 'uuid';
const MONGODB_URI = 'mongodb+srv://admtracksteel:29OHAHpKTI8XcCNt@cluster0.a4xiilu.mongodb.net/ts_gpi?retryWrites=true&w=majority&appName=Cluster0'; const MONGODB_URI = 'mongodb+srv://admtracksteel:29OHAHpKTI8XcCNt@cluster0.a4xiilu.mongodb.net/ts_gpi?retryWrites=true&w=majority&appName=Cluster0';
const UserSchema = new mongoose.Schema({ const UserSchema = new mongoose.Schema({
clerkId: { type: String, required: true, unique: true },
email: { type: String, required: true, unique: true }, email: { type: String, required: true, unique: true },
password: { type: String, required: true }, passwordHash: { type: String, required: true },
name: { type: String, required: true }, name: { type: String, required: true },
role: { type: String, enum: ['guest', 'user', 'admin'], default: 'guest' }, role: { type: String, enum: ['guest', 'user', 'admin'], default: 'guest' },
organizationId: String, organizationId: String,
@@ -13,6 +15,7 @@ const UserSchema = new mongoose.Schema({
}, { timestamps: true }); }, { timestamps: true });
async function fixAdmin() { async function fixAdmin() {
try {
await mongoose.connect(MONGODB_URI); await mongoose.connect(MONGODB_URI);
console.log('✅ Conectado ao MongoDB'); console.log('✅ Conectado ao MongoDB');
@@ -22,7 +25,7 @@ async function fixAdmin() {
const password = 'admin'; // Senha padrão temporária const password = 'admin'; // Senha padrão temporária
const hashedPassword = await bcrypt.hash(password, 10); const hashedPassword = await bcrypt.hash(password, 10);
// Tenta encontrar o usuário existente ou criar um novo // Tenta encontrar o usuário existente
let user = await User.findOne({ email }); let user = await User.findOne({ email });
if (user) { if (user) {
@@ -31,36 +34,39 @@ async function fixAdmin() {
{ {
$set: { $set: {
role: 'admin', role: 'admin',
password: hashedPassword, passwordHash: hashedPassword,
name: 'Admin TrackSteel' name: 'Admin TrackSteel'
} }
} }
); );
console.log(`✅ Usuário ${email} atualizado para admin e senha definida.`); console.log(`✅ Usuário ${email} atualizado para admin e senha definida.`);
} else { } else {
const fakeClerkId = `user_${uuidv4().replace(/-/g, '')}`;
await User.create({ await User.create({
clerkId: fakeClerkId,
email, email,
password: hashedPassword, passwordHash: hashedPassword,
name: 'Admin TrackSteel', name: 'Admin TrackSteel',
role: 'admin', role: 'admin',
organizationId: 'default-org' organizationId: 'default-org'
}); });
console.log(`✅ Usuário ${email} criado como admin.`); console.log(`✅ Usuário ${email} criado como admin (ClerkId: ${fakeClerkId}).`);
} }
// Listar todos os usuários // Listar todos os usuários
const users = await User.find({}); const users = await User.find({});
console.log('\n📋 Usuários atuais:'); console.log('\n📋 Usuários atuais:');
users.forEach((u, i) => { users.forEach((u, i) => {
console.log(` ${i + 1}. ${u.email} | role: ${u.role}`); console.log(` ${i + 1}. ${u.email} | role: ${u.role} | hasHash: ${!!u.passwordHash}`);
}); });
} catch (err) {
console.error('❌ Erro durante a execução:', err);
} finally {
await mongoose.disconnect(); await mongoose.disconnect();
console.log('\n✅ Desconectado do MongoDB'); console.log('\n✅ Desconectado do MongoDB');
process.exit(0); process.exit(0);
}
} }
fixAdmin().catch(err => { fixAdmin();
console.error('❌ Erro:', err);
process.exit(1);
});