1
0
Fork 0
empact/db/org.go

54 lines
1.1 KiB
Go
Raw Normal View History

2015-03-05 15:25:26 +00:00
package db
2015-03-06 13:35:13 +00:00
import (
"time"
)
2015-03-06 10:00:04 +00:00
type Org struct {
2015-03-20 15:22:49 +00:00
ID int `json:"id"`
2015-03-20 14:18:34 +00: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 10:00:04 +00:00
}
2015-03-05 15:25:26 +00:00
2015-03-19 12:49:46 +00:00
func (o *Org) Save() {
2015-03-21 14:58:40 +00:00
defer measure(time.Now(), "SaveOrg")
2015-03-20 14:18:34 +00:00
mustExecN(`
insert into orgs (id, login, company, avatar_url, updated_at)
values (:id, :login, :company, :avatar_url, now())
2015-03-20 14:18:34 +00:00
on duplicate key update
login = values(login),
company = values(company),
avatar_url = values(avatar_url),
updated_at = now()
`, o)
2015-03-19 12:49:46 +00:00
}
2015-03-05 15:25:26 +00:00
2015-03-05 16:06:45 +00:00
func UserOrgs(login string) (orgs []*Org) {
2015-03-21 14:58:40 +00:00
defer measure(time.Now(), "UserOrgs")
2015-03-20 14:18:34 +00: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 15:25:26 +00:00
return
}
2015-03-22 13:23:18 +00: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
}