106 lines
2.5 KiB
PHP
Raw Normal View History

2024-08-29 12:17:57 +01:00
<?php
require "vendor/autoload.php";
use Darkterminal\TursoHttp\LibSQL;
use Dumbo\Dumbo;
$dsn = "...";
$client = new LibSQL($dsn);
$client->execute("
CREATE TABLE IF NOT EXISTS users (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL,
email TEXT NOT NULL UNIQUE
)
");
$app = new Dumbo();
2024-08-29 16:09:38 +01:00
$app->get("/users", function ($context) use ($client) {
2024-08-29 12:17:57 +01:00
$result = $client->execute("SELECT * FROM users");
2024-08-29 16:09:38 +01:00
return $context->json($result);
2024-08-29 12:17:57 +01:00
});
2024-08-29 16:09:38 +01:00
$app->get("/users/:id", function ($context) use ($client) {
$id = $context->req->param("id");
2024-08-29 12:17:57 +01:00
$result = $client->execute("SELECT * FROM users WHERE id = ?", [$id]);
if (empty($result)) {
2024-08-29 16:09:38 +01:00
return $context->json(["error" => "User not found"], 404);
2024-08-29 12:17:57 +01:00
}
2024-08-29 16:09:38 +01:00
return $context->json($result[0]);
2024-08-29 12:17:57 +01:00
});
2024-08-29 16:09:38 +01:00
$app->post("/users", function ($context) use ($client) {
$body = $context->req->body();
2024-08-29 12:17:57 +01:00
if (!isset($body["name"]) || !isset($body["email"])) {
2024-08-29 16:09:38 +01:00
return $context->json(["error" => "Name and email are required"], 400);
2024-08-29 12:17:57 +01:00
}
$result = $client->execute(
"INSERT INTO users (name, email) VALUES (?, ?) RETURNING id",
[$body["name"], $body["email"]]
);
2024-08-29 16:09:38 +01:00
return $context->json(["id" => $result[0]["id"]], 201);
2024-08-29 12:17:57 +01:00
});
2024-08-29 16:09:38 +01:00
$app->put("/users/:id", function ($context) use ($client) {
$id = $context->req->param("id");
$body = $context->req->body();
2024-08-29 12:17:57 +01:00
if (!isset($body["name"]) && !isset($body["email"])) {
2024-08-29 16:09:38 +01:00
return $context->json(["error" => "Name or email is required"], 400);
2024-08-29 12:17:57 +01:00
}
$setClause = [];
$params = [];
if (isset($body["name"])) {
$setClause[] = "name = ?";
$params[] = $body["name"];
}
if (isset($body["email"])) {
$setClause[] = "email = ?";
$params[] = $body["email"];
}
$params[] = $id;
$result = $client->execute(
"UPDATE users SET " .
implode(", ", $setClause) .
" WHERE id = ? RETURNING *",
$params
);
if (empty($result)) {
2024-08-29 16:09:38 +01:00
return $context->json(["error" => "User not found"], 404);
2024-08-29 12:17:57 +01:00
}
2024-08-29 16:09:38 +01:00
return $context->json($result[0]);
2024-08-29 12:17:57 +01:00
});
2024-08-29 16:09:38 +01:00
$app->delete("/users/:id", function ($context) use ($client) {
$id = $context->req->param("id");
2024-08-29 12:17:57 +01:00
$result = $client->execute("DELETE FROM users WHERE id = ? RETURNING id", [
$id,
]);
if (empty($result)) {
2024-08-29 16:09:38 +01:00
return $context->json(["error" => "User not found"], 404);
2024-08-29 12:17:57 +01:00
}
2024-08-29 16:09:38 +01:00
return $context->json(["message" => "User deleted successfully"]);
2024-08-29 12:17:57 +01:00
});
$app->run();