mirror of
https://github.com/xiaoxinpro/nginx-proxy-manager-zh.git
synced 2025-01-24 05:38:15 -05:00
84 lines
1.5 KiB
Go
84 lines
1.5 KiB
Go
package auth
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"npm/internal/database"
|
|
|
|
"github.com/rotisserie/eris"
|
|
)
|
|
|
|
// GetByID finds a auth by ID
|
|
func GetByID(id int) (Model, error) {
|
|
var m Model
|
|
err := m.LoadByID(id)
|
|
return m, err
|
|
}
|
|
|
|
// GetByUserIDType finds a user by email
|
|
func GetByUserIDType(userID int, authType string) (Model, error) {
|
|
var m Model
|
|
err := m.LoadByUserIDType(userID, authType)
|
|
return m, err
|
|
}
|
|
|
|
// Create will create a Auth from this model
|
|
func Create(auth *Model) (int, error) {
|
|
if auth.ID != 0 {
|
|
return 0, eris.New("Cannot create auth when model already has an ID")
|
|
}
|
|
|
|
auth.Touch(true)
|
|
|
|
db := database.GetInstance()
|
|
// nolint: gosec
|
|
result, err := db.NamedExec(`INSERT INTO `+fmt.Sprintf("`%s`", tableName)+` (
|
|
created_on,
|
|
modified_on,
|
|
user_id,
|
|
type,
|
|
secret,
|
|
is_deleted
|
|
) VALUES (
|
|
:created_on,
|
|
:modified_on,
|
|
:user_id,
|
|
:type,
|
|
:secret,
|
|
:is_deleted
|
|
)`, auth)
|
|
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
last, lastErr := result.LastInsertId()
|
|
if lastErr != nil {
|
|
return 0, lastErr
|
|
}
|
|
|
|
return int(last), nil
|
|
}
|
|
|
|
// Update will Update a Auth from this model
|
|
func Update(auth *Model) error {
|
|
if auth.ID == 0 {
|
|
return eris.New("Cannot update auth when model doesn't have an ID")
|
|
}
|
|
|
|
auth.Touch(false)
|
|
|
|
db := database.GetInstance()
|
|
// nolint: gosec
|
|
_, err := db.NamedExec(`UPDATE `+fmt.Sprintf("`%s`", tableName)+` SET
|
|
created_on = :created_on,
|
|
modified_on = :modified_on,
|
|
user_id = :user_id,
|
|
type = :type,
|
|
secret = :secret,
|
|
is_deleted = :is_deleted
|
|
WHERE id = :id`, auth)
|
|
|
|
return err
|
|
}
|