mirror of https://github.com/dexidp/dex.git
5 changed files with 39 additions and 163 deletions
@ -1,58 +0,0 @@
|
||||
package kubernetes |
||||
|
||||
import ( |
||||
"fmt" |
||||
"log" |
||||
"time" |
||||
|
||||
"golang.org/x/net/context" |
||||
) |
||||
|
||||
// gc begins the gc process for Kubernetes.
|
||||
func (cli *client) gc(ctx context.Context, every time.Duration) { |
||||
handleErr := func(err error) { log.Println(err.Error()) } |
||||
|
||||
for { |
||||
select { |
||||
case <-ctx.Done(): |
||||
return |
||||
case <-time.After(every): |
||||
} |
||||
|
||||
// TODO(ericchiang): On failures, run garbage collection more often.
|
||||
log.Println("kubernetes: running garbage collection") |
||||
cli.gcAuthRequests(handleErr) |
||||
cli.gcAuthCodes(handleErr) |
||||
log.Printf("kubernetes: garbage collection finished, next run at %s", cli.now().Add(every)) |
||||
} |
||||
} |
||||
|
||||
func (cli *client) gcAuthRequests(handleErr func(error)) { |
||||
var authRequests AuthRequestList |
||||
if err := cli.list(resourceAuthRequest, &authRequests); err != nil { |
||||
handleErr(fmt.Errorf("failed to list auth requests: %v", err)) |
||||
return |
||||
} |
||||
for _, authRequest := range authRequests.AuthRequests { |
||||
if cli.now().After(authRequest.Expiry) { |
||||
if err := cli.delete(resourceAuthRequest, authRequest.ObjectMeta.Name); err != nil { |
||||
handleErr(fmt.Errorf("failed to detele auth request: %v", err)) |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
func (cli *client) gcAuthCodes(handleErr func(error)) { |
||||
var authCodes AuthCodeList |
||||
if err := cli.list(resourceAuthCode, &authCodes); err != nil { |
||||
handleErr(fmt.Errorf("failed to list auth codes: %v", err)) |
||||
return |
||||
} |
||||
for _, authCode := range authCodes.AuthCodes { |
||||
if cli.now().After(authCode.Expiry) { |
||||
if err := cli.delete(resourceAuthCode, authCode.ObjectMeta.Name); err != nil { |
||||
handleErr(fmt.Errorf("failed to delete auth code: %v", err)) |
||||
} |
||||
} |
||||
} |
||||
} |
||||
@ -1,88 +0,0 @@
|
||||
package kubernetes |
||||
|
||||
import ( |
||||
"testing" |
||||
"time" |
||||
|
||||
"github.com/coreos/dex/storage" |
||||
) |
||||
|
||||
func muster(t *testing.T) func(err error) { |
||||
return func(err error) { |
||||
if err != nil { |
||||
t.Fatal(err) |
||||
} |
||||
} |
||||
} |
||||
|
||||
func TestGCAuthRequests(t *testing.T) { |
||||
cli := loadClient(t) |
||||
must := muster(t) |
||||
|
||||
now := time.Now() |
||||
cli.now = func() time.Time { return now } |
||||
|
||||
expiredID := storage.NewID() |
||||
goodID := storage.NewID() |
||||
|
||||
must(cli.CreateAuthRequest(storage.AuthRequest{ |
||||
ID: expiredID, |
||||
Expiry: now.Add(-time.Second), |
||||
})) |
||||
|
||||
must(cli.CreateAuthRequest(storage.AuthRequest{ |
||||
ID: goodID, |
||||
Expiry: now.Add(time.Second), |
||||
})) |
||||
|
||||
handleErr := func(err error) { t.Error(err.Error()) } |
||||
cli.gcAuthRequests(handleErr) |
||||
|
||||
if _, err := cli.GetAuthRequest(goodID); err != nil { |
||||
t.Errorf("failed to get good auth ID: %v", err) |
||||
} |
||||
_, err := cli.GetAuthRequest(expiredID) |
||||
switch { |
||||
case err == nil: |
||||
t.Errorf("gc did not remove expired auth request") |
||||
case err == storage.ErrNotFound: |
||||
default: |
||||
t.Errorf("expected storage.ErrNotFound, got %v", err) |
||||
} |
||||
} |
||||
|
||||
func TestGCAuthCodes(t *testing.T) { |
||||
cli := loadClient(t) |
||||
must := muster(t) |
||||
|
||||
now := time.Now() |
||||
cli.now = func() time.Time { return now } |
||||
|
||||
expiredID := storage.NewID() |
||||
goodID := storage.NewID() |
||||
|
||||
must(cli.CreateAuthCode(storage.AuthCode{ |
||||
ID: expiredID, |
||||
Expiry: now.Add(-time.Second), |
||||
})) |
||||
|
||||
must(cli.CreateAuthCode(storage.AuthCode{ |
||||
ID: goodID, |
||||
Expiry: now.Add(time.Second), |
||||
})) |
||||
|
||||
handleErr := func(err error) { t.Error(err.Error()) } |
||||
cli.gcAuthCodes(handleErr) |
||||
|
||||
if _, err := cli.GetAuthCode(goodID); err != nil { |
||||
t.Errorf("failed to get good auth ID: %v", err) |
||||
} |
||||
_, err := cli.GetAuthCode(expiredID) |
||||
switch { |
||||
case err == nil: |
||||
t.Errorf("gc did not remove expired auth request") |
||||
case err == storage.ErrNotFound: |
||||
default: |
||||
t.Errorf("expected storage.ErrNotFound, got %v", err) |
||||
} |
||||
} |
||||
Loading…
Reference in new issue