mirror of
https://github.com/9technologygroup/patchmon.net.git
synced 2025-11-05 06:23:22 +00:00
style: fmt
This commit is contained in:
@@ -36,7 +36,9 @@ const SortableCardItem = ({ card, onToggle }) => {
|
||||
transform,
|
||||
transition,
|
||||
isDragging,
|
||||
} = useSortable({ id: card.cardId });
|
||||
} = useSortable({
|
||||
id: card.cardId,
|
||||
});
|
||||
|
||||
const style = {
|
||||
transform: CSS.Transform.toString(transform),
|
||||
|
||||
@@ -496,8 +496,9 @@ const DeleteHostGroupModal = ({ group, onClose, onConfirm, isLoading }) => {
|
||||
<div className="mt-3 p-3 bg-warning-50 border border-warning-200 rounded-md">
|
||||
<p className="text-sm text-warning-800">
|
||||
<strong>Warning:</strong> This group contains{" "}
|
||||
{group._count.hosts} host{group._count.hosts !== 1 ? "s" : ""}.
|
||||
You must move or remove these hosts before deleting the group.
|
||||
{group._count.hosts} host
|
||||
{group._count.hosts !== 1 ? "s" : ""}. You must move or remove
|
||||
these hosts before deleting the group.
|
||||
</p>
|
||||
</div>
|
||||
)}
|
||||
|
||||
@@ -292,7 +292,9 @@ const Hosts = () => {
|
||||
newSearchParams.delete("action");
|
||||
navigate(
|
||||
`/hosts${newSearchParams.toString() ? `?${newSearchParams.toString()}` : ""}`,
|
||||
{ replace: true },
|
||||
{
|
||||
replace: true,
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
@@ -306,7 +308,9 @@ const Hosts = () => {
|
||||
newSearchParams.delete("selected");
|
||||
navigate(
|
||||
`/hosts${newSearchParams.toString() ? `?${newSearchParams.toString()}` : ""}`,
|
||||
{ replace: true },
|
||||
{
|
||||
replace: true,
|
||||
},
|
||||
);
|
||||
}
|
||||
}, [searchParams, navigate]);
|
||||
|
||||
@@ -583,8 +583,9 @@ const DeleteHostGroupModal = ({ group, onClose, onConfirm, isLoading }) => {
|
||||
<div className="mt-3 p-3 bg-warning-50 border border-warning-200 rounded-md">
|
||||
<p className="text-sm text-warning-800">
|
||||
<strong>Warning:</strong> This group contains{" "}
|
||||
{group._count.hosts} host{group._count.hosts !== 1 ? "s" : ""}.
|
||||
You must move or remove these hosts before deleting the group.
|
||||
{group._count.hosts} host
|
||||
{group._count.hosts !== 1 ? "s" : ""}. You must move or remove
|
||||
these hosts before deleting the group.
|
||||
</p>
|
||||
</div>
|
||||
)}
|
||||
|
||||
@@ -1,107 +1,119 @@
|
||||
const { PrismaClient } = require('@prisma/client');
|
||||
const bcrypt = require('bcryptjs');
|
||||
const readline = require('readline');
|
||||
const { PrismaClient } = require("@prisma/client");
|
||||
const bcrypt = require("bcryptjs");
|
||||
const readline = require("node:readline");
|
||||
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
const rl = readline.createInterface({
|
||||
input: process.stdin,
|
||||
output: process.stdout
|
||||
output: process.stdout,
|
||||
});
|
||||
|
||||
const question = (query) => new Promise((resolve) => rl.question(query, resolve));
|
||||
const question = (query) =>
|
||||
new Promise((resolve) => rl.question(query, resolve));
|
||||
|
||||
async function setupAdminUser() {
|
||||
try {
|
||||
console.log('🔐 Setting up PatchMon Admin User');
|
||||
console.log('=====================================\n');
|
||||
console.log("🔐 Setting up PatchMon Admin User");
|
||||
console.log("=====================================\n");
|
||||
|
||||
// Check if any users exist
|
||||
const existingUsers = await prisma.users.count();
|
||||
if (existingUsers > 0) {
|
||||
console.log('⚠️ Users already exist in the database.');
|
||||
const overwrite = await question('Do you want to create another admin user? (y/N): ');
|
||||
if (overwrite.toLowerCase() !== 'y' && overwrite.toLowerCase() !== 'yes') {
|
||||
console.log('❌ Setup cancelled.');
|
||||
console.log("⚠️ Users already exist in the database.");
|
||||
const overwrite = await question(
|
||||
"Do you want to create another admin user? (y/N): ",
|
||||
);
|
||||
if (
|
||||
overwrite.toLowerCase() !== "y" &&
|
||||
overwrite.toLowerCase() !== "yes"
|
||||
) {
|
||||
console.log("❌ Setup cancelled.");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
// Get user input
|
||||
const username = await question('Enter admin username: ');
|
||||
const username = await question("Enter admin username: ");
|
||||
if (!username.trim()) {
|
||||
console.log('❌ Username is required.');
|
||||
console.log("❌ Username is required.");
|
||||
return;
|
||||
}
|
||||
|
||||
const email = await question('Enter admin email: ');
|
||||
const email = await question("Enter admin email: ");
|
||||
if (!email.trim()) {
|
||||
console.log('❌ Email is required.');
|
||||
console.log("❌ Email is required.");
|
||||
return;
|
||||
}
|
||||
|
||||
const password = await question('Enter admin password (min 6 characters): ');
|
||||
const password = await question(
|
||||
"Enter admin password (min 6 characters): ",
|
||||
);
|
||||
if (password.length < 6) {
|
||||
console.log('❌ Password must be at least 6 characters.');
|
||||
console.log("❌ Password must be at least 6 characters.");
|
||||
return;
|
||||
}
|
||||
|
||||
// Check if username or email already exists
|
||||
const existingUser = await prisma.users.findFirst({
|
||||
where: {
|
||||
OR: [
|
||||
{ username: username.trim() },
|
||||
{ email: email.trim() }
|
||||
]
|
||||
}
|
||||
OR: [{ username: username.trim() }, { email: email.trim() }],
|
||||
},
|
||||
});
|
||||
|
||||
if (existingUser) {
|
||||
console.log('❌ Username or email already exists.');
|
||||
console.log("❌ Username or email already exists.");
|
||||
return;
|
||||
}
|
||||
|
||||
// Hash password
|
||||
console.log('\n🔄 Creating admin user...');
|
||||
console.log("\n🔄 Creating admin user...");
|
||||
const passwordHash = await bcrypt.hash(password, 12);
|
||||
|
||||
// Create admin user
|
||||
const user = await prisma.users.create({
|
||||
data: {
|
||||
id: require('crypto').randomUUID(),
|
||||
id: require("node:crypto").randomUUID(),
|
||||
username: username.trim(),
|
||||
email: email.trim(),
|
||||
password_hash: passwordHash,
|
||||
role: 'admin',
|
||||
role: "admin",
|
||||
is_active: true,
|
||||
created_at: new Date(),
|
||||
updated_at: new Date()
|
||||
updated_at: new Date(),
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
email: true,
|
||||
role: true,
|
||||
created_at: true
|
||||
}
|
||||
created_at: true,
|
||||
},
|
||||
});
|
||||
|
||||
console.log('✅ Admin user created successfully!');
|
||||
console.log('\n📋 User Details:');
|
||||
console.log("✅ Admin user created successfully!");
|
||||
console.log("\n📋 User Details:");
|
||||
console.log(` Username: ${user.username}`);
|
||||
console.log(` Email: ${user.email}`);
|
||||
console.log(` Role: ${user.role}`);
|
||||
console.log(` Created: ${user.created_at.toISOString()}`);
|
||||
|
||||
console.log('\n🎉 Setup complete!');
|
||||
console.log('\nNext steps:');
|
||||
console.log('1. The backend server is already running as a systemd service');
|
||||
console.log('2. The frontend is already built and served by Nginx');
|
||||
console.log('3. Visit https://' + process.env.FQDN + ' and login with your credentials');
|
||||
console.log('4. Use the management script: ./manage.sh {status|restart|logs|update|backup|credentials|reset-admin}');
|
||||
|
||||
console.log("\n🎉 Setup complete!");
|
||||
console.log("\nNext steps:");
|
||||
console.log(
|
||||
"1. The backend server is already running as a systemd service",
|
||||
);
|
||||
console.log("2. The frontend is already built and served by Nginx");
|
||||
console.log(
|
||||
"3. Visit https://" +
|
||||
process.env.FQDN +
|
||||
" and login with your credentials",
|
||||
);
|
||||
console.log(
|
||||
"4. Use the management script: ./manage.sh {status|restart|logs|update|backup|credentials|reset-admin}",
|
||||
);
|
||||
} catch (error) {
|
||||
console.error('❌ Error setting up admin user:', error);
|
||||
console.error("❌ Error setting up admin user:", error);
|
||||
} finally {
|
||||
rl.close();
|
||||
await prisma.$disconnect();
|
||||
|
||||
Reference in New Issue
Block a user