2018-05-16 10:46:14 +00:00
|
|
|
package common
|
|
|
|
|
2018-12-14 04:08:53 +00:00
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/Azareal/Gosora/query_gen"
|
|
|
|
)
|
2018-05-16 10:46:14 +00:00
|
|
|
|
|
|
|
var RegLogs RegLogStore
|
|
|
|
|
|
|
|
type RegLogItem struct {
|
|
|
|
ID int
|
|
|
|
Username string
|
|
|
|
Email string
|
|
|
|
FailureReason string
|
|
|
|
Success bool
|
|
|
|
IPAddress string
|
|
|
|
DoneAt string
|
|
|
|
}
|
|
|
|
|
|
|
|
type RegLogStmts struct {
|
|
|
|
update *sql.Stmt
|
|
|
|
create *sql.Stmt
|
|
|
|
}
|
|
|
|
|
|
|
|
var regLogStmts RegLogStmts
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
DbInits.Add(func(acc *qgen.Accumulator) error {
|
|
|
|
regLogStmts = RegLogStmts{
|
|
|
|
update: acc.Update("registration_logs").Set("username = ?, email = ?, failureReason = ?, success = ?").Where("rlid = ?").Prepare(),
|
|
|
|
create: acc.Insert("registration_logs").Columns("username, email, failureReason, success, ipaddress, doneAt").Fields("?,?,?,?,?,UTC_TIMESTAMP()").Prepare(),
|
|
|
|
}
|
|
|
|
return acc.FirstError()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Reload this item in the store, probably doesn't matter right now, but it might when we start caching this stuff in memory
|
|
|
|
// ! Retroactive updates of date are not permitted for integrity reasons
|
|
|
|
func (log *RegLogItem) Commit() error {
|
|
|
|
_, err := regLogStmts.update.Exec(log.Username, log.Email, log.FailureReason, log.Success, log.ID)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (log *RegLogItem) Create() (id int, err error) {
|
|
|
|
res, err := regLogStmts.create.Exec(log.Username, log.Email, log.FailureReason, log.Success, log.IPAddress)
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
id64, err := res.LastInsertId()
|
|
|
|
log.ID = int(id64)
|
|
|
|
return log.ID, err
|
|
|
|
}
|
|
|
|
|
|
|
|
type RegLogStore interface {
|
|
|
|
GlobalCount() (logCount int)
|
|
|
|
GetOffset(offset int, perPage int) (logs []RegLogItem, err error)
|
|
|
|
}
|
|
|
|
|
|
|
|
type SQLRegLogStore struct {
|
|
|
|
count *sql.Stmt
|
|
|
|
getOffset *sql.Stmt
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewRegLogStore(acc *qgen.Accumulator) (*SQLRegLogStore, error) {
|
|
|
|
return &SQLRegLogStore{
|
|
|
|
count: acc.Count("registration_logs").Prepare(),
|
|
|
|
getOffset: acc.Select("registration_logs").Columns("rlid, username, email, failureReason, success, ipaddress, doneAt").Orderby("doneAt DESC").Limit("?,?").Prepare(),
|
|
|
|
}, acc.FirstError()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (store *SQLRegLogStore) GlobalCount() (logCount int) {
|
|
|
|
err := store.count.QueryRow().Scan(&logCount)
|
|
|
|
if err != nil {
|
|
|
|
LogError(err)
|
|
|
|
}
|
|
|
|
return logCount
|
|
|
|
}
|
|
|
|
|
|
|
|
func (store *SQLRegLogStore) GetOffset(offset int, perPage int) (logs []RegLogItem, err error) {
|
|
|
|
rows, err := store.getOffset.Query(offset, perPage)
|
|
|
|
if err != nil {
|
|
|
|
return logs, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
for rows.Next() {
|
|
|
|
var log RegLogItem
|
2018-12-14 04:08:53 +00:00
|
|
|
var doneAt time.Time
|
|
|
|
err := rows.Scan(&log.ID, &log.Username, &log.Email, &log.FailureReason, &log.Success, &log.IPAddress, &doneAt)
|
2018-05-16 10:46:14 +00:00
|
|
|
if err != nil {
|
|
|
|
return logs, err
|
|
|
|
}
|
2018-12-14 04:08:53 +00:00
|
|
|
log.DoneAt = doneAt.Format("2006-01-02 15:04:05")
|
2018-05-16 10:46:14 +00:00
|
|
|
logs = append(logs, log)
|
|
|
|
}
|
|
|
|
return logs, rows.Err()
|
|
|
|
}
|