Skip to content

Commit

Permalink
prevent per-user concurrent sync
Browse files Browse the repository at this point in the history
  • Loading branch information
bradrydzewski committed Sep 29, 2017
1 parent ca8a00e commit 9a0a6f9
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 13 deletions.
19 changes: 19 additions & 0 deletions .drone.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ pipeline:
publish_server_alpine:
image: plugins/docker
repo: drone/drone
dockerfile: Dockerfile.alpine
secrets: [ docker_username, docker_password ]
tag: [ alpine ]
when:
Expand Down Expand Up @@ -95,6 +96,24 @@ pipeline:
branch: master
event: push

release_server_alpine:
image: plugins/docker
repo: drone/drone
dockerfile: Dockerfile.alpine
secrets: [ docker_username, docker_password ]
tag: [ 0.8-alpine ]
when:
event: tag

release_agent_alpine:
image: plugins/docker
repo: drone/agent
dockerfile: Dockerfile.agent.alpine
secrets: [ docker_username, docker_password ]
tag: [ 0.8-alpine ]
when:
event: tag

release_server:
image: plugins/docker
repo: drone/drone
Expand Down
4 changes: 4 additions & 0 deletions model/limit.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ package model
type Limiter interface {
LimitUser(*User) error
LimitRepo(*User, *Repo) error
LimitRepos(*User, []*Repo) []*Repo
LimitBuild(*User, *Repo, *Build) error
}

Expand All @@ -19,5 +20,8 @@ func (NoLimit) LimitUser(*User) error { return nil }
// LimitRepo is a no-op for limiting repo creation.
func (NoLimit) LimitRepo(*User, *Repo) error { return nil }

// LimitRepos is a no-op for limiting repository listings.
func (NoLimit) LimitRepos(user *User, repos []*Repo) []*Repo { return repos }

// LimitBuild is a no-op for limiting build creation.
func (NoLimit) LimitBuild(*User, *Repo, *Build) error { return nil }
11 changes: 8 additions & 3 deletions server/sync.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,10 @@ type Syncer interface {
}

type syncer struct {
remote remote.Remote
store store.Store
perms model.PermStore
remote remote.Remote
store store.Store
perms model.PermStore
limiter model.Limiter
}

func (s *syncer) Sync(user *model.User) error {
Expand All @@ -26,6 +27,10 @@ func (s *syncer) Sync(user *model.User) error {
return err
}

if s.limiter != nil {
repos = s.limiter.LimitRepos(user, repos)
}

var perms []*model.Perm
for _, repo := range repos {
perm := model.Perm{
Expand Down
25 changes: 15 additions & 10 deletions server/user.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,17 +27,20 @@ func GetFeed(c *gin.Context) {

if time.Unix(user.Synced, 0).Add(time.Hour * 72).Before(time.Now()) {
logrus.Debugf("sync begin: %s", user.Login)

user.Synced = time.Now().Unix()
store.FromContext(c).UpdateUser(user)

sync := syncer{
remote: remote.FromContext(c),
store: store.FromContext(c),
perms: store.FromContext(c),
remote: remote.FromContext(c),
store: store.FromContext(c),
perms: store.FromContext(c),
limiter: Config.Services.Limiter,
}
if err := sync.Sync(user); err != nil {
logrus.Debugf("sync error: %s: %s", user.Login, err)
} else {
logrus.Debugf("sync complete: %s", user.Login)
user.Synced = time.Now().Unix()
store.FromContext(c).UpdateUser(user)
}
}

Expand Down Expand Up @@ -68,17 +71,19 @@ func GetRepos(c *gin.Context) {

if flush || time.Unix(user.Synced, 0).Add(time.Hour*72).Before(time.Now()) {
logrus.Debugf("sync begin: %s", user.Login)
user.Synced = time.Now().Unix()
store.FromContext(c).UpdateUser(user)

sync := syncer{
remote: remote.FromContext(c),
store: store.FromContext(c),
perms: store.FromContext(c),
remote: remote.FromContext(c),
store: store.FromContext(c),
perms: store.FromContext(c),
limiter: Config.Services.Limiter,
}
if err := sync.Sync(user); err != nil {
logrus.Debugf("sync error: %s: %s", user.Login, err)
} else {
logrus.Debugf("sync complete: %s", user.Login)
user.Synced = time.Now().Unix()
store.FromContext(c).UpdateUser(user)
}
}

Expand Down

0 comments on commit 9a0a6f9

Please sign in to comment.