From d9a0f21f1b66a88b8009cf59e0a50b49fa2e33af Mon Sep 17 00:00:00 2001 From: Boshi LIAN Date: Thu, 22 Jun 2023 15:35:00 -0700 Subject: [PATCH 1/2] basic impl for go todos api --- .../TechEmpower/go-gin/TodosApi/go.mod | 35 +++ .../TechEmpower/go-gin/TodosApi/go.sum | 87 +++++++ .../TechEmpower/go-gin/TodosApi/main.go | 42 +++ .../TechEmpower/go-gin/TodosApi/todoapi.go | 243 ++++++++++++++++++ 4 files changed, 407 insertions(+) create mode 100644 src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod create mode 100644 src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum create mode 100644 src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go create mode 100644 src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod new file mode 100644 index 000000000..274b39b91 --- /dev/null +++ b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod @@ -0,0 +1,35 @@ +module TodosApi + +go 1.20 + +require ( + github.com/gin-gonic/gin v1.9.1 + github.com/lib/pq v1.10.9 +) + +require ( + github.com/bytedance/sonic v1.9.1 // indirect + github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 // indirect + github.com/gabriel-vasile/mimetype v1.4.2 // indirect + github.com/gin-contrib/sse v0.1.0 // indirect + github.com/go-playground/locales v0.14.1 // indirect + github.com/go-playground/universal-translator v0.18.1 // indirect + github.com/go-playground/validator/v10 v10.14.0 // indirect + github.com/goccy/go-json v0.10.2 // indirect + github.com/json-iterator/go v1.1.12 // indirect + github.com/klauspost/cpuid/v2 v2.2.4 // indirect + github.com/leodido/go-urn v1.2.4 // indirect + github.com/mattn/go-isatty v0.0.19 // indirect + github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect + github.com/modern-go/reflect2 v1.0.2 // indirect + github.com/pelletier/go-toml/v2 v2.0.8 // indirect + github.com/twitchyliquid64/golang-asm v0.15.1 // indirect + github.com/ugorji/go/codec v1.2.11 // indirect + golang.org/x/arch v0.3.0 // indirect + golang.org/x/crypto v0.9.0 // indirect + golang.org/x/net v0.10.0 // indirect + golang.org/x/sys v0.8.0 // indirect + golang.org/x/text v0.9.0 // indirect + google.golang.org/protobuf v1.30.0 // indirect + gopkg.in/yaml.v3 v3.0.1 // indirect +) diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum new file mode 100644 index 000000000..af479af29 --- /dev/null +++ b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum @@ -0,0 +1,87 @@ +github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM= +github.com/bytedance/sonic v1.9.1 h1:6iJ6NqdoxCDr6mbY8h18oSO+cShGSMRGCEo7F2h0x8s= +github.com/bytedance/sonic v1.9.1/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= +github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY= +github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 h1:qSGYFH7+jGhDF8vLC+iwCD4WpbV1EBDSzWkJODFLams= +github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= +github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= +github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/gabriel-vasile/mimetype v1.4.2 h1:w5qFW6JKBz9Y393Y4q372O9A7cUSequkh1Q7OhCmWKU= +github.com/gabriel-vasile/mimetype v1.4.2/go.mod h1:zApsH/mKG4w07erKIaJPFiX0Tsq9BFQgN3qGY5GnNgA= +github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= +github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI= +github.com/gin-gonic/gin v1.9.1 h1:4idEAncQnU5cB7BeOkPtxjfCSye0AAm1R0RVIqJ+Jmg= +github.com/gin-gonic/gin v1.9.1/go.mod h1:hPrL7YrpYKXt5YId3A/Tnip5kqbEAP+KLuI3SUcPTeU= +github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= +github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= +github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= +github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= +github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= +github.com/go-playground/validator/v10 v10.14.0 h1:vgvQWe3XCz3gIeFDm/HnTIbj6UGmg/+t63MyGU2n5js= +github.com/go-playground/validator/v10 v10.14.0/go.mod h1:9iXMNT7sEkjXb0I+enO7QXmzG6QCsPWY4zveKFVRSyU= +github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= +github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= +github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= +github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU= +github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= +github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= +github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= +github.com/klauspost/cpuid/v2 v2.2.4 h1:acbojRNwl3o09bUq+yDCtZFc1aiwaAAxtcn8YkZXnvk= +github.com/klauspost/cpuid/v2 v2.2.4/go.mod h1:RVVoqg1df56z8g3pUjL/3lE5UfnlrJX8tyFgg4nqhuY= +github.com/leodido/go-urn v1.2.4 h1:XlAE/cm/ms7TE/VMVoduSpNBoyc2dOxHs5MZSwAN63Q= +github.com/leodido/go-urn v1.2.4/go.mod h1:7ZrI8mTSeBSHl/UaRyKQW1qZeMgak41ANeCNaVckg+4= +github.com/lib/pq v1.10.9 h1:YXG7RB+JIjhP29X+OtkiDnYaXQwpS4JEWq7dtCCRUEw= +github.com/lib/pq v1.10.9/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o= +github.com/mattn/go-isatty v0.0.19 h1:JITubQf0MOLdlGRuRq+jtsDlekdYPia9ZFsB8h/APPA= +github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= +github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= +github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= +github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= +github.com/pelletier/go-toml/v2 v2.0.8 h1:0ctb6s9mE31h0/lhu+J6OPmVeDxJn+kYnJc2jZR9tGQ= +github.com/pelletier/go-toml/v2 v2.0.8/go.mod h1:vuYfssBdrU2XDZ9bYydBu6t+6a6PYNcZljzZR9VXg+4= +github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= +github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= +github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= +github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= +github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= +github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= +github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= +github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= +github.com/stretchr/testify v1.8.3 h1:RP3t2pwF7cMEbC1dqtB6poj3niw/9gnV4Cjg5oW5gtY= +github.com/stretchr/testify v1.8.3/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= +github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= +github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= +github.com/ugorji/go/codec v1.2.11 h1:BMaWp1Bb6fHwEtbplGBGJ498wD+LKlNSl25MjdZY4dU= +github.com/ugorji/go/codec v1.2.11/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= +golang.org/x/arch v0.0.0-20210923205945-b76863e36670/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8= +golang.org/x/arch v0.3.0 h1:02VY4/ZcO/gBOH6PUaoiptASxtXU10jazRCP865E97k= +golang.org/x/arch v0.3.0/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8= +golang.org/x/crypto v0.9.0 h1:LF6fAI+IutBocDJ2OT0Q1g8plpYljMZ4+lty+dsqw3g= +golang.org/x/crypto v0.9.0/go.mod h1:yrmDGqONDYtNj3tH8X9dzUun2m2lzPa9ngI6/RUPGR0= +golang.org/x/net v0.10.0 h1:X2//UzNDwYmtCLn7To6G58Wr6f5ahEAQgKNzv9Y951M= +golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= +golang.org/x/sys v0.0.0-20220704084225-05e143d24a9e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.8.0 h1:EBmGv8NaZBZTWvrbjNoL6HVt+IVy3QDQpJs7VRIw3tU= +golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/text v0.9.0 h1:2sjJmO8cDvYveuX97RDLsxlyUxLl+GHoLxBiRdHllBE= +golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= +golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4= +golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= +google.golang.org/protobuf v1.30.0 h1:kPPoIgf3TsEvrm0PFe15JQ+570QVxYzEvvHqChK+cng= +google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go new file mode 100644 index 000000000..616a76ce9 --- /dev/null +++ b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go @@ -0,0 +1,42 @@ +package main + +import ( + "database/sql" + "log" + "net/http" + "os" + + _ "github.com/lib/pq" + + "github.com/gin-gonic/gin" +) + +func main() { + connStr := os.Getenv("DATABASE_CONNECTION") + listenAddr := os.Getenv("LISTEN_ADDRESS") + + if connStr == "" { + log.Fatalln("DATABASE_CONNECTION environment variable not set") + } + + if listenAddr == "" { + listenAddr = ":8080" + } + + db, err := sql.Open("postgres", connStr) + if err != nil { + log.Fatal(err) + } + + todoapi := &todoapi{db} + + router := gin.Default() + + router.GET("/favicon.ico", func(c *gin.Context) { + c.String(http.StatusNotFound, "") + }) + + todoapi.MapTodoApi(router) + + router.Run(listenAddr) +} diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go new file mode 100644 index 000000000..1cf995059 --- /dev/null +++ b/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go @@ -0,0 +1,243 @@ +package main + +import ( + "database/sql" + "fmt" + "net/http" + "strconv" + + "github.com/gin-gonic/gin" +) + +type HttpValidationProblemDetails struct { + Type *string `json:"type,omitempty"` + Title *string `json:"title,omitempty"` + Status *int32 `json:"status,omitempty"` + Detail *string `json:"detail,omitempty"` + Instance *string `json:"instance,omitempty"` + Errors map[string][]string `json:"errors,omitempty"` +} + +type Todo struct { + ID int32 `json:"id"` + Title *string `json:"title,omitempty"` + DueBy *string `json:"dueBy,omitempty"` + IsComplete bool `json:"isComplete"` +} + +type todoapi struct { + db *sql.DB +} + +func (t *todoapi) Query(query string, args ...any) ([]Todo, error) { + rows, err := t.db.Query(query, args...) + if err != nil { + return nil, err + } + defer rows.Close() + + var todos []Todo + for rows.Next() { + var todo Todo + if err := rows.Scan(&todo.ID, &todo.Title, &todo.DueBy, &todo.IsComplete); err != nil { + return nil, err + } + todos = append(todos, todo) + } + return todos, nil +} + +func (t *todoapi) QueryRow(query string, args ...any) (*Todo, error) { + row := t.db.QueryRow(query, args...) + + var todo Todo + if err := row.Scan(&todo.ID, &todo.Title, &todo.DueBy, &todo.IsComplete); err != nil { + return nil, err + } + return &todo, nil +} + +func (t *todoapi) Exec(query string, args ...any) (int64, error) { + result, err := t.db.Exec(query, args) + if err != nil { + return 0, err + } + + return result.RowsAffected() +} + +func (t *todoapi) MapTodoApi(router gin.IRouter) { + group := router.Group("/api/todos") + + group.GET("/", func(c *gin.Context) { + + todos, err := t.Query("SELECT * FROM Todos") + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + c.JSON(http.StatusOK, todos) + }) + + group.GET("/complete", func(c *gin.Context) { + + todos, err := t.Query("SELECT * FROM Todos WHERE IsComplete = true") + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + c.JSON(http.StatusOK, todos) + }) + + group.GET("/incomplete", func(c *gin.Context) { + + todos, err := t.Query("SELECT * FROM Todos WHERE IsComplete = false") + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + c.JSON(http.StatusOK, todos) + }) + + group.GET("/:id", func(c *gin.Context) { + + id := c.Param("id") + todo, err := t.QueryRow("SELECT * FROM Todos WHERE Id = ?", id) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if todo != nil { + c.JSON(http.StatusOK, todo) + } else { + c.Status(http.StatusNotFound) + } + }) + + group.GET("/find", func(c *gin.Context) { + + title := c.Query("title") + isComplete := c.Query("isComplete") + todo, err := t.QueryRow(` + SELECT * FROM Todos + WHERE LOWER(Title) = LOWER(?) + AND (? IS NULL OR IsComplete = ?) + `, title, isComplete, isComplete) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if todo != nil { + c.JSON(http.StatusOK, todo) + } else { + c.Status(http.StatusNotFound) + } + }) + + group.POST("/", func(c *gin.Context) { + + var todo Todo + if err := c.ShouldBindJSON(&todo); err != nil { + c.AbortWithError(http.StatusBadRequest, err) + return + } + createdTodo, err := t.QueryRow(` + INSERT INTO Todos(Title, IsComplete) + VALUES (%s, %s) + RETURNING * + `, todo.Title, todo.IsComplete) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + location := fmt.Sprintf("/todos/%d", createdTodo.ID) + c.JSON(http.StatusCreated, gin.H{"location": location, "data": createdTodo}) + }) + + group.PUT("/:id", func(c *gin.Context) { + + var inputTodo Todo + if err := c.ShouldBindJSON(&inputTodo); err != nil { + c.AbortWithError(http.StatusBadRequest, err) + return + } + + id, err := strconv.ParseInt(c.Param("id"), 10, 32) + if err != nil { + c.AbortWithError(http.StatusBadRequest, err) + return + } + + inputTodo.ID = int32(id) + result, err := t.Exec(` + UPDATE Todos + SET Title = ?, IsComplete = ? + WHERE Id = ? + `, inputTodo.Title, inputTodo.IsComplete, id) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if result == 1 { + c.Status(http.StatusNoContent) + } else { + c.Status(http.StatusNotFound) + } + }) + + group.PUT("/:id/mark-complete", func(c *gin.Context) { + + id := c.Param("id") + result, err := t.Exec("UPDATE Todos SET IsComplete = true WHERE Id = ?", id) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if result == 1 { + c.Status(http.StatusNoContent) + } else { + c.Status(http.StatusNotFound) + } + }) + + group.PUT("/:id/mark-incomplete", func(c *gin.Context) { + + id := c.Param("id") + result, err := t.Exec("UPDATE Todos SET IsComplete = false WHERE Id = ?", id) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if result == 1 { + c.Status(http.StatusNoContent) + } else { + c.Status(http.StatusNotFound) + } + }) + + group.DELETE("/:id", func(c *gin.Context) { + id := c.Param("id") + result, err := t.Exec("DELETE FROM Todos WHERE Id = ?", id) + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + if result == 1 { + c.Status(http.StatusNoContent) + } else { + c.Status(http.StatusNotFound) + } + }) + + // TODO: Add authentication + // RequireAuthenticatdUser().RequireRole("admin") + group.DELETE("/delete-all", func(c *gin.Context) { + + result, err := t.Exec("DELETE FROM Todos") + if err != nil { + c.AbortWithError(http.StatusInternalServerError, err) + return + } + c.JSON(http.StatusOK, result) + }) +} From daeb926bec79fef100032ae0d171955440f900b1 Mon Sep 17 00:00:00 2001 From: Boshi LIAN Date: Thu, 22 Jun 2023 15:51:08 -0700 Subject: [PATCH 2/2] mv folder --- src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/go.mod | 0 src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/go.sum | 0 src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/main.go | 0 src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/todoapi.go | 0 4 files changed, 0 insertions(+), 0 deletions(-) rename src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/go.mod (100%) rename src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/go.sum (100%) rename src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/main.go (100%) rename src/BenchmarksApps/{TechEmpower => }/go-gin/TodosApi/todoapi.go (100%) diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod b/src/BenchmarksApps/go-gin/TodosApi/go.mod similarity index 100% rename from src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.mod rename to src/BenchmarksApps/go-gin/TodosApi/go.mod diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum b/src/BenchmarksApps/go-gin/TodosApi/go.sum similarity index 100% rename from src/BenchmarksApps/TechEmpower/go-gin/TodosApi/go.sum rename to src/BenchmarksApps/go-gin/TodosApi/go.sum diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go b/src/BenchmarksApps/go-gin/TodosApi/main.go similarity index 100% rename from src/BenchmarksApps/TechEmpower/go-gin/TodosApi/main.go rename to src/BenchmarksApps/go-gin/TodosApi/main.go diff --git a/src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go b/src/BenchmarksApps/go-gin/TodosApi/todoapi.go similarity index 100% rename from src/BenchmarksApps/TechEmpower/go-gin/TodosApi/todoapi.go rename to src/BenchmarksApps/go-gin/TodosApi/todoapi.go