MaCH repo

This commit is contained in:
2025-07-24 12:46:01 -05:00
committed by Nick Ricketts
commit 1e5eac3c3d
78 changed files with 5232 additions and 0 deletions

60
04_todo/main.c Normal file
View File

@@ -0,0 +1,60 @@
#include <mach.h>
#include <sqlite.h>
#include <session_auth.h>
void mach(){
sqlite_config();
session_auth_config();
sqlite_database(
.name ="todos_db",
.connect = "file:{{user_id}}_todo.db?mode=rwc",
.migrations = {"create_todos_table"}
);
error(m_error, {mustache("5xx")});
error(m_not_found, {mustache("404")});
middleware(session());
resource("home", "/",
.get = {mustache("home")}
);
resource("about", "/about",
.get = {mustache("about")}
);
resource("contact", "/contact",
.get = {mustache("contact")}
);
resource("todos", "/todos",
.all = {logged_in()},
.get = {
sqlite_query({"todos_db", "get_todos", "todos_data"}),
mustache("todos")
},
.post = {
input({"title", m_not_empty}),
sqlite_query({"todos_db", "create_todo"}),
redirect("todos")
}
);
resource("todo", "/todos/:id",
.all = {
logged_in(),
input({"id", m_positive})
},
.patch = {
input({"finished", "1", "must be 1", .optional = true,}),
sqlite_query({"todos_db", "update_todo"}),
redirect("todos")
},
.delete = {
sqlite_query({"todos_db", "delete_todo"}),
redirect("todos")
}
);
}