39 lines
857 B
Go
39 lines
857 B
Go
package db
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
type User struct {
|
|
ID int `json:"id"`
|
|
Login string `json:"login"`
|
|
Name string `json:"name"`
|
|
AvatarURL string `json:"avatar_url" db:"avatar_url"`
|
|
UpdatedAt time.Time `json:"updated_at" db:"updated_at"`
|
|
}
|
|
|
|
func (u *User) Save() {
|
|
defer measure(time.Now(), "SaveUser")
|
|
mustExecN(`
|
|
insert into users (id, login, name, avatar_url, updated_at)
|
|
values (:id, :login, :name, :avatar_url, now())
|
|
on duplicate key update
|
|
login = values(login),
|
|
name = values(name),
|
|
avatar_url = values(avatar_url),
|
|
updated_at = now()
|
|
`, u)
|
|
}
|
|
|
|
func OrgUsers(login string) (users []*User) {
|
|
defer measure(time.Now(), "OrgUsers")
|
|
mustSelect(&users, `
|
|
select u.*
|
|
from org_members om
|
|
join users u on u.id = om.user_id
|
|
join orgs o on o.id = om.org_id
|
|
where o.login = ?
|
|
`, login)
|
|
return
|
|
}
|