parent
0e1176b44c
commit
5c7686a54f
@ -0,0 +1,46 @@ |
|||||||
|
package features_auth |
||||||
|
|
||||||
|
import ( |
||||||
|
"golang.org/x/crypto/bcrypt" |
||||||
|
|
||||||
|
"github.com/gofiber/fiber/v2" |
||||||
|
_ "github.com/mattn/go-sqlite3" |
||||||
|
sq "github.com/Masterminds/squirrel" |
||||||
|
|
||||||
|
"MY/webapp/data" |
||||||
|
"MY/webapp/common" |
||||||
|
) |
||||||
|
|
||||||
|
func SetUserPassword(user *data.User) error { |
||||||
|
hashed, err := bcrypt.GenerateFromPassword([]byte(user.Password), 12) |
||||||
|
if err != nil { return err } |
||||||
|
|
||||||
|
user.Password = string(hashed) |
||||||
|
return nil |
||||||
|
} |
||||||
|
|
||||||
|
func LogoutUser(c *fiber.Ctx) error { |
||||||
|
sess, err := common.STORE.Get(c) |
||||||
|
if err != nil { return err } |
||||||
|
|
||||||
|
err = sess.Destroy() |
||||||
|
if err != nil { return err } |
||||||
|
|
||||||
|
err = sess.Save() |
||||||
|
return err |
||||||
|
} |
||||||
|
|
||||||
|
func LoginUser(result *data.User, login *data.Login) (bool, error) { |
||||||
|
sql, args, err := sq.Select("username, password"). |
||||||
|
From("user").Where("username=?", login.Username).ToSql() |
||||||
|
|
||||||
|
if err != nil { return false, err } |
||||||
|
|
||||||
|
err = data.DB.Get(result, sql, args...) |
||||||
|
if err != nil { return false, err } |
||||||
|
|
||||||
|
pass_good := bcrypt.CompareHashAndPassword([]byte(result.Password), []byte(login.Password)) |
||||||
|
if pass_good != nil { return false, pass_good } |
||||||
|
|
||||||
|
return login.Username == result.Username && pass_good == nil, nil |
||||||
|
} |
||||||
@ -0,0 +1,10 @@ |
|||||||
|
package features_auth |
||||||
|
|
||||||
|
import ( |
||||||
|
"github.com/gofiber/fiber/v2" |
||||||
|
) |
||||||
|
|
||||||
|
func Setup(app *fiber.App) { |
||||||
|
SetupApi(app) |
||||||
|
SetupViews(app) |
||||||
|
} |
||||||
@ -0,0 +1,11 @@ |
|||||||
|
package features_auth |
||||||
|
|
||||||
|
import ( |
||||||
|
"github.com/gofiber/fiber/v2" |
||||||
|
. "MY/webapp/common" |
||||||
|
) |
||||||
|
|
||||||
|
func SetupViews(app *fiber.App) { |
||||||
|
err := ConfigViews(app, "views/auth") |
||||||
|
if err != nil { panic(err) } |
||||||
|
} |
||||||
@ -1,10 +1,11 @@ |
|||||||
package tests |
package tests_auth |
||||||
|
|
||||||
import ( |
import ( |
||||||
"testing" |
"testing" |
||||||
// "github.com/stretchr/testify/require"
|
// "github.com/stretchr/testify/require"
|
||||||
"MY/webapp/data" |
"MY/webapp/data" |
||||||
sq "github.com/Masterminds/squirrel" |
sq "github.com/Masterminds/squirrel" |
||||||
|
. "MY/webapp/tests/tools" |
||||||
) |
) |
||||||
|
|
||||||
func deleteTestUser(username string) { |
func deleteTestUser(username string) { |
||||||
@ -0,0 +1,15 @@ |
|||||||
|
package tests |
||||||
|
|
||||||
|
import ( |
||||||
|
"testing" |
||||||
|
// "github.com/stretchr/testify/require"
|
||||||
|
"MY/webapp/data" |
||||||
|
) |
||||||
|
|
||||||
|
func TestMain(m *testing.M) { |
||||||
|
data.Setup("sqlite3", "./db.sqlite3") |
||||||
|
|
||||||
|
m.Run() |
||||||
|
|
||||||
|
data.Shutdown() |
||||||
|
} |
||||||
Loading…
Reference in new issue