2015-03-05 22:04:44 +07:00
|
|
|
package db
|
|
|
|
|
2015-03-06 20:35:13 +07:00
|
|
|
import "time"
|
|
|
|
|
2015-03-06 17:00:04 +07:00
|
|
|
type User struct {
|
2015-03-19 19:49:12 +07:00
|
|
|
ID uint64 `json:"id"`
|
2015-03-06 17:00:04 +07:00
|
|
|
Login string `json:"login"`
|
|
|
|
Name string `json:"name"`
|
2015-03-06 20:23:01 +07:00
|
|
|
AvatarURL string `json:"avatar_url" db:"avatar_url"`
|
2015-03-06 17:00:04 +07:00
|
|
|
}
|
2015-03-05 22:04:44 +07:00
|
|
|
|
2015-03-15 00:34:37 +07:00
|
|
|
const orgUsersQuery = `
|
|
|
|
select
|
|
|
|
u.*
|
|
|
|
from members m
|
|
|
|
join teams t on
|
|
|
|
m.team_id = t.id
|
|
|
|
join users u on
|
|
|
|
m.user = u.login
|
|
|
|
where m.org = ?`
|
|
|
|
|
2015-03-06 17:00:04 +07:00
|
|
|
const saveUserQuery = `
|
2015-03-19 19:49:12 +07:00
|
|
|
insert into users (id, login, name, avatar_url, created_at, updated_at)
|
|
|
|
values (:id, :login, :name, :avatar_url, now(), now())
|
2015-03-06 17:00:04 +07:00
|
|
|
on duplicate key update
|
2015-03-19 19:49:12 +07:00
|
|
|
login = values(login),
|
|
|
|
name = values(name),
|
|
|
|
avatar_url = values(avatar_url),
|
|
|
|
updated_at = now()`
|
2015-03-05 22:04:44 +07:00
|
|
|
|
|
|
|
func (u *User) Save() {
|
2015-03-06 20:35:13 +07:00
|
|
|
defer measure("SaveUser", time.Now())
|
2015-03-06 18:29:52 +07:00
|
|
|
mustExecN(saveUserQuery, u)
|
2015-03-05 22:04:44 +07:00
|
|
|
}
|
2015-03-15 00:34:37 +07:00
|
|
|
|
|
|
|
func OrgUsers(login string) (users []*User) {
|
|
|
|
defer measure("OrgUsers", time.Now())
|
|
|
|
mustSelect(&users, orgUsersQuery, login)
|
|
|
|
return
|
|
|
|
}
|