2015-03-05 22:25:26 +07:00
|
|
|
package db
|
|
|
|
|
2015-03-06 20:35:13 +07:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2015-03-06 17:00:04 +07:00
|
|
|
type Org struct {
|
2015-03-20 22:22:49 +07:00
|
|
|
ID int `json:"id"`
|
2015-03-20 21:18:34 +07:00
|
|
|
Login string `json:"login"`
|
|
|
|
Company string `json:"company"`
|
|
|
|
AvatarURL string `json:"avatar_url" db:"avatar_url"`
|
|
|
|
UpdatedAt time.Time `json:"updated_at" db:"updated_at"`
|
2015-03-06 17:00:04 +07:00
|
|
|
}
|
2015-03-05 22:25:26 +07:00
|
|
|
|
2015-03-19 19:49:46 +07:00
|
|
|
func (o *Org) Save() {
|
2015-03-21 21:58:40 +07:00
|
|
|
defer measure(time.Now(), "SaveOrg")
|
2015-03-20 21:18:34 +07:00
|
|
|
mustExecN(`
|
2015-03-20 22:32:26 +07:00
|
|
|
insert into orgs (id, login, company, avatar_url, updated_at)
|
|
|
|
values (:id, :login, :company, :avatar_url, now())
|
2015-03-20 21:18:34 +07:00
|
|
|
on duplicate key update
|
|
|
|
login = values(login),
|
|
|
|
company = values(company),
|
|
|
|
avatar_url = values(avatar_url),
|
|
|
|
updated_at = now()
|
|
|
|
`, o)
|
2015-03-19 19:49:46 +07:00
|
|
|
}
|
2015-03-05 22:25:26 +07:00
|
|
|
|
2015-03-05 23:06:45 +07:00
|
|
|
func UserOrgs(login string) (orgs []*Org) {
|
2015-03-21 21:58:40 +07:00
|
|
|
defer measure(time.Now(), "UserOrgs")
|
2015-03-20 21:18:34 +07:00
|
|
|
mustSelect(&orgs, `
|
|
|
|
select o.*
|
|
|
|
from org_members m
|
|
|
|
join users u on u.id = m.user_id
|
|
|
|
join orgs o on o.id = m.org_id
|
|
|
|
where u.login = ?
|
|
|
|
`, login)
|
2015-03-05 22:25:26 +07:00
|
|
|
return
|
|
|
|
}
|
2015-03-22 20:23:18 +07:00
|
|
|
|
|
|
|
func OrgWeekRange(login string) (min int, max int) {
|
|
|
|
row := db.QueryRow(`
|
|
|
|
select
|
|
|
|
min(c.week) as min,
|
|
|
|
max(c.week) as max
|
|
|
|
from contribs c
|
|
|
|
join orgs o on o.id = c.org_id
|
|
|
|
where o.login = ?
|
|
|
|
`, login)
|
|
|
|
if err := row.Scan(&min, &max); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|