34729-vm/create_server.php
Flatlogic Bot 9dd9dcbc9d 2
2025-10-06 16:25:16 +00:00

103 lines
3.6 KiB
PHP

<?php
session_start();
require_once 'db/config.php';
require_once 'utils.php';
// If the user is not logged in, redirect to the login page
if (!isset($_SESSION['user_id'])) {
header('Location: login.php');
exit;
}
$user_id = $_SESSION['user_id'];
$error = '';
$success = '';
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$server_name = trim($_POST['server_name']);
if (empty($server_name)) {
$error = 'Server name is required.';
} else {
try {
$pdo = db();
// Start a transaction
$pdo->beginTransaction();
// 1. Insert the new server
$stmt = $pdo->prepare("INSERT INTO servers (name, owner_id) VALUES (:name, :owner_id)");
$stmt->execute(['name' => $server_name, 'owner_id' => $user_id]);
$server_id = $pdo->lastInsertId();
// 2. Add the owner to the server_members table
$stmt = $pdo->prepare("INSERT INTO server_members (server_id, user_id) VALUES (:server_id, :user_id)");
$stmt->execute(['server_id' => $server_id, 'user_id' => $user_id]);
// 3. Create a default 'general' channel for the new server
$stmt = $pdo->prepare("INSERT INTO channels (server_id, name) VALUES (:server_id, :name)");
$stmt->execute(['server_id' => $server_id, 'name' => 'general']);
// Commit the transaction
$pdo->commit();
// Redirect to the main page after creation
header('Location: index.php');
exit;
} catch (PDOException $e) {
// Rollback the transaction if something failed
if ($pdo->inTransaction()) {
$pdo->rollBack();
}
$error = "An error occurred while creating the server: " . $e->getMessage();
}
}
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Create a New Server</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="assets/css/custom.css">
</head>
<body>
<div class="container-fluid">
<div class="row vh-100">
<div class="col-md-6 offset-md-3 d-flex flex-column justify-content-center">
<div class="card">
<div class="card-body p-5">
<h1 class="text-center mb-4">Create Your Server</h1>
<p class="text-center text-muted mb-4">Give your new server a personality with a name. You can always change it later.</p>
<?php if ($error): ?>
<div class="alert alert-danger"><?php echo htmlspecialchars($error); ?></div>
<?php endif; ?>
<form action="create_server.php" method="POST">
<div class="mb-3">
<label for="server_name" class="form-label">SERVER NAME</label>
<input type="text" class="form-control" id="server_name" name="server_name" required>
</div>
<div class="d-grid">
<button type="submit" class="btn btn-primary">Create</button>
</div>
</form>
<div class="text-center mt-3">
<a href="index.php">Back to main page</a>
</div>
</div>
</div>
</div>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
</body>
</html>