1
0
mirror of https://github.com/muety/wakapi.git synced 2023-08-10 21:12:56 +03:00

Compare commits

...

4 Commits

Author SHA1 Message Date
Ferdinand Mütsch
56800be8e8 chore: change info message in migration (resolve #128) 2021-02-16 17:18:56 +01:00
Steven Tang
c149766ecc fix: drop_badges_column migration for sqlite 2021-02-16 22:07:41 +11:00
Ferdinand Mütsch
759e8e4dfd chore: change logging middleware to use different output 2021-02-14 16:41:02 +01:00
Ferdinand Mütsch
708863fd33 fix: broken migration on postgres (resolve #127) 2021-02-14 16:02:05 +01:00
5 changed files with 39 additions and 17 deletions

View File

@@ -171,10 +171,7 @@ func main() {
// Globally used middlewares // Globally used middlewares
recoveryMiddleware := handlers.RecoveryHandler() recoveryMiddleware := handlers.RecoveryHandler()
loggingMiddleware := middlewares.NewLoggingMiddleware( loggingMiddleware := middlewares.NewLoggingMiddleware(logbuch.Info, []string{"/assets"})
log.New(os.Stdout, "", log.LstdFlags),
[]string{"/assets"},
)
// Router configs // Router configs
router.Use(loggingMiddleware, recoveryMiddleware) router.Use(loggingMiddleware, recoveryMiddleware)

View File

@@ -4,23 +4,24 @@ package middlewares
import ( import (
"io" "io"
"log"
"net/http" "net/http"
"strings" "strings"
"time" "time"
) )
type logFunc func(string, ...interface{})
type LoggingMiddleware struct { type LoggingMiddleware struct {
handler http.Handler handler http.Handler
output *log.Logger logFunc logFunc
excludePrefixes []string excludePrefixes []string
} }
func NewLoggingMiddleware(output *log.Logger, excludePrefixes []string) func(http.Handler) http.Handler { func NewLoggingMiddleware(logFunc logFunc, excludePrefixes []string) func(http.Handler) http.Handler {
return func(h http.Handler) http.Handler { return func(h http.Handler) http.Handler {
return &LoggingMiddleware{ return &LoggingMiddleware{
handler: h, handler: h,
output: output, logFunc: logFunc,
excludePrefixes: excludePrefixes, excludePrefixes: excludePrefixes,
} }
} }
@@ -41,9 +42,8 @@ func (lg *LoggingMiddleware) ServeHTTP(w http.ResponseWriter, r *http.Request) {
} }
} }
lg.output.Printf( lg.logFunc(
"%v status=%d, method=%s, uri=%s, duration=%v, bytes=%d, addr=%s\n", "[request] status=%d, method=%s, uri=%s, duration=%v, bytes=%d, addr=%s, user=%s\n",
time.Now().Format(time.RFC3339Nano),
ww.Status(), ww.Status(),
r.Method, r.Method,
r.URL.String(), r.URL.String(),

View File

@@ -14,7 +14,7 @@ func init() {
migrator := db.Migrator() migrator := db.Migrator()
if !migrator.HasColumn(&models.User{}, "badges_enabled") { if !migrator.HasColumn(&models.User{}, "badges_enabled") {
// empty database, nothing to migrate // empty database or already migrated, nothing to migrate
return nil return nil
} }
@@ -37,11 +37,15 @@ func init() {
return err return err
} }
if cfg.Db.Dialect == config.SQLDialectSqlite {
logbuch.Info("not attempting to drop column 'badges_enabled' on sqlite")
return nil
}
if err := migrator.DropColumn(&models.User{}, "badges_enabled"); err != nil { if err := migrator.DropColumn(&models.User{}, "badges_enabled"); err != nil {
return err return err
} else {
logbuch.Info("dropped column 'badges_enabled' after substituting it by sharing indicators")
} }
logbuch.Info("dropped column 'badges_enabled' after substituting it by sharing indicators")
return nil return nil
}, },

View File

@@ -1,17 +1,38 @@
package migrations package migrations
import ( import (
"github.com/emvi/logbuch"
"github.com/muety/wakapi/config" "github.com/muety/wakapi/config"
"github.com/muety/wakapi/models"
"gorm.io/gorm" "gorm.io/gorm"
) )
func init() { func init() {
const name = "20210213-add_has_data_field"
f := migrationFunc{ f := migrationFunc{
name: "20210213_add_has_data_field", name: name,
f: func(db *gorm.DB, cfg *config.Config) error { f: func(db *gorm.DB, cfg *config.Config) error {
if err := db.Exec("UPDATE users SET has_data = TRUE WHERE 1").Error; err != nil { condition := "key = ?"
if cfg.Db.Dialect == config.SQLDialectMysql {
condition = "`key` = ?"
}
lookupResult := db.Where(condition, name).First(&models.KeyStringValue{})
if lookupResult.Error == nil && lookupResult.RowsAffected > 0 {
logbuch.Info("no need to migrate '%s'", name)
return nil
}
if err := db.Exec("UPDATE users SET has_data = TRUE WHERE TRUE").Error; err != nil {
return err return err
} }
if err := db.Create(&models.KeyStringValue{
Key: name,
Value: "done",
}).Error; err != nil {
return err
}
return nil return nil
}, },
} }

View File

@@ -1 +1 @@
1.24.0 1.24.3