change paths, add task to db
This commit is contained in:
parent
6a56b03bf6
commit
9e058e4f03
7 changed files with 87 additions and 70 deletions
|
@ -13,6 +13,10 @@ func migrateInitial(orm *gorm.DB) {
|
|||
if err != nil {
|
||||
fmt.Println(fmt.Errorf("failed to migrate User"))
|
||||
}
|
||||
err = orm.AutoMigrate(&Task{})
|
||||
if err != nil {
|
||||
fmt.Println(fmt.Errorf("failed to migrate Task"))
|
||||
}
|
||||
}
|
||||
|
||||
func (db *Database) Initialize() {
|
||||
|
|
|
@ -14,3 +14,9 @@ type User struct {
|
|||
Password string
|
||||
LoggedIn bool
|
||||
}
|
||||
|
||||
type Task struct {
|
||||
ID int `gorm:"primaryKey"`
|
||||
Description string
|
||||
Done bool
|
||||
}
|
||||
|
|
|
@ -22,13 +22,13 @@
|
|||
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
||||
<ul class="ms-auto navbar-nav mb-2 mb-lg-0">
|
||||
<li class="nav-item me-2">
|
||||
<a id="button-tasks" class="btn btn-primary" href="/tasks">Tasks</a>
|
||||
<a hidden id="button-tasks" class="btn btn-primary" href="/view/tasks">Tasks</a>
|
||||
</li>
|
||||
<li class="nav-item me-2">
|
||||
<a id="button-login" class="btn btn-primary" href="/login">Login</a>
|
||||
<a id="button-login" class="btn btn-primary" href="/view/login">Login</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<button id="button-logout" class="btn btn-danger" onclick="logout()">Logout</button>
|
||||
<button hidden id="button-logout" class="btn btn-danger" onclick="logout()">Logout</button>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
@ -96,8 +96,13 @@
|
|||
}
|
||||
|
||||
async function userLoggedIn() {
|
||||
const response = await fetch("/user", {method: 'GET', headers: myHeaders});
|
||||
const response = await fetch("/auth/user", {method: 'GET', headers: myHeaders});
|
||||
const json = await response.json();
|
||||
if (json.logged_in === true) {
|
||||
document.getElementById("button-login").hidden = true;
|
||||
button_logout.hidden = false;
|
||||
document.getElementById("button-tasks").hidden = false;
|
||||
}
|
||||
return json.logged_in
|
||||
}
|
||||
|
||||
|
@ -105,7 +110,7 @@
|
|||
button_logout.disabled = true;
|
||||
let data = new FormData();
|
||||
data.append("username", username);
|
||||
const response = await fetch("/logout", {method: 'POST', body: data});
|
||||
const response = await fetch("/auth/logout", {method: 'POST', body: data});
|
||||
deleteCookie("username");
|
||||
response.ok && redirect("/");
|
||||
}
|
||||
|
|
|
@ -21,13 +21,13 @@
|
|||
userLoggedIn().then((loggedIn) => loggedIn && redirect("/"));
|
||||
|
||||
async function submitForm(formData) {
|
||||
const response = await fetch("/login", {method: 'POST', body: formData, redirect: 'follow'});
|
||||
const response = await fetch("/auth/login", {method: 'POST', body: formData, redirect: 'follow'});
|
||||
if (response.ok) {
|
||||
const json = await response.json();
|
||||
setCookie("username", json.username, 1);
|
||||
redirect("/");
|
||||
} else {
|
||||
redirect("/login");
|
||||
redirect("/view/login");
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
|
|
@ -19,11 +19,11 @@
|
|||
{{template "formScripts" .}}
|
||||
<script>
|
||||
async function submitForm(formData) {
|
||||
const response = await fetch("/register", {method: 'POST', body: formData, redirect: 'follow'});
|
||||
const response = await fetch("/auth/register", {method: 'POST', body: formData, redirect: 'follow'});
|
||||
if (response.ok) {
|
||||
redirect("/");
|
||||
} else {
|
||||
redirect("/register");
|
||||
redirect("/view/register");
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
|
||||
{{template "scripts" .}}
|
||||
<script>
|
||||
userLoggedIn().then((loggedIn) => !loggedIn && redirect("/login"));
|
||||
userLoggedIn().then((loggedIn) => !loggedIn && redirect("/view/login"));
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -8,22 +8,27 @@ import (
|
|||
)
|
||||
|
||||
func (wp *Webpage) redirectHome(c *gin.Context) {
|
||||
c.Redirect(http.StatusTemporaryRedirect, "/tasks")
|
||||
c.Redirect(http.StatusTemporaryRedirect, "/view/tasks")
|
||||
}
|
||||
|
||||
func (wp *Webpage) defineRoutes() {
|
||||
|
||||
wp.Router.GET("/tasks", func(c *gin.Context) {
|
||||
view := wp.Router.Group("/view")
|
||||
{
|
||||
view.GET("/tasks", func(c *gin.Context) {
|
||||
c.HTML(http.StatusOK, "tasks.tmpl", gin.H{"title": "Tasks"})
|
||||
})
|
||||
wp.Router.GET("/login", func(c *gin.Context) {
|
||||
view.GET("/login", func(c *gin.Context) {
|
||||
c.HTML(http.StatusOK, "login.tmpl", gin.H{"title": "Login"})
|
||||
})
|
||||
wp.Router.GET("/register", func(c *gin.Context) {
|
||||
view.GET("/register", func(c *gin.Context) {
|
||||
c.HTML(http.StatusOK, "register.tmpl", gin.H{"title": "Register"})
|
||||
})
|
||||
}
|
||||
|
||||
wp.Router.GET("/user", func(c *gin.Context) {
|
||||
auth := wp.Router.Group("/auth")
|
||||
{
|
||||
auth.GET("/user", func(c *gin.Context) {
|
||||
username := c.Request.Header.Get("username")
|
||||
if username != "" {
|
||||
success := wp.Database.UserIsLoggedIn(username)
|
||||
|
@ -32,8 +37,7 @@ func (wp *Webpage) defineRoutes() {
|
|||
}
|
||||
c.JSON(200, gin.H{"logged_in": false, "username": ""})
|
||||
})
|
||||
|
||||
wp.Router.POST("/logout", func(c *gin.Context) {
|
||||
auth.POST("/logout", func(c *gin.Context) {
|
||||
username, uExisting := c.GetPostForm("username")
|
||||
if uExisting == false || username == "" {
|
||||
c.JSON(400, gin.H{"message": "bad post form"})
|
||||
|
@ -42,8 +46,7 @@ func (wp *Webpage) defineRoutes() {
|
|||
success := wp.Database.LogoutUser(username)
|
||||
c.JSON(200, gin.H{"logged_out": success, "username": username})
|
||||
})
|
||||
|
||||
wp.Router.POST("/login", func(c *gin.Context) {
|
||||
auth.POST("/login", func(c *gin.Context) {
|
||||
username, uExisting := c.GetPostForm("username")
|
||||
password, pExisting := c.GetPostForm("password")
|
||||
if uExisting == false || pExisting == false || username == "" || password == "" {
|
||||
|
@ -57,8 +60,7 @@ func (wp *Webpage) defineRoutes() {
|
|||
}
|
||||
c.JSON(401, gin.H{"message": "user or password not found"})
|
||||
})
|
||||
|
||||
wp.Router.POST("/register", func(c *gin.Context) {
|
||||
auth.POST("/register", func(c *gin.Context) {
|
||||
username, uExisting := c.GetPostForm("username")
|
||||
password, pExisting := c.GetPostForm("password")
|
||||
if uExisting == false || pExisting == false || username == "" || password == "" {
|
||||
|
@ -72,7 +74,7 @@ func (wp *Webpage) defineRoutes() {
|
|||
}
|
||||
c.JSON(200, gin.H{"message": "user registered"})
|
||||
})
|
||||
|
||||
}
|
||||
wp.Router.NoRoute(func(c *gin.Context) {
|
||||
wp.redirectHome(c)
|
||||
})
|
||||
|
|
Reference in a new issue