final 0 , sem clerk
This commit is contained in:
@@ -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' });
|
||||||
|
|||||||
@@ -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);
|
|
||||||
});
|
|
||||||
|
|||||||
Reference in New Issue
Block a user