initial commit

This commit is contained in:
silva guimaraes 2025-04-21 17:59:57 -03:00
commit c21f569144
37 changed files with 3956 additions and 0 deletions

69
database/usuario.go Normal file
View file

@ -0,0 +1,69 @@
package database
import (
"database/sql"
"time"
)
type Usuario struct {
identity
Email string
Nome string
// senhaHash string `json:"-"`
Ctime time.Time
}
func VerifyUser(tx *sql.Tx, email, senha string) (*Usuario, error) {
row := tx.QueryRow(
`SELECT id, nome, ctime, senha_hash FROM usuario WHERE email = $1 LIMIT 1`,
email,
)
if row.Err() != nil {
return nil, row.Err()
}
usuario := &Usuario{
Email: email,
}
var id int
var senhaHash string
err := row.Scan(
&id,
&usuario.Nome,
&usuario.Ctime,
&senhaHash,
)
if err != nil {
return nil, err
}
usuario.SetId(id)
if err = checkPasswordHash(senha, senhaHash); err != nil {
return nil, err
}
return usuario, nil
}
func FindUsuarioByID(tx *sql.Tx, id int) (*Usuario, error) {
row := tx.QueryRow(
`SELECT id, nome, email, ctime FROM usuario WHERE id = $1 LIMIT 1`,
id,
)
if row.Err() != nil {
return nil, row.Err()
}
usuario := &Usuario{}
err := row.Scan(
&id,
&usuario.Nome,
&usuario.Email,
&usuario.Ctime,
)
if err != nil {
return nil, err
}
usuario.SetId(id)
return usuario, nil
}