debian-forge-composer/vendor/github.com/modern-go/concurrent
sanne 4a057bf3d5 auth: OpenID/OAUth2 middleware
2 configurations for the listeners are now possible:
- enableJWT=false with client ssl auth
- enableJWT=true with https

Actual verification of the tokens is handled by
https://github.com/openshift-online/ocm-sdk-go.

An authentication handler is run as the top level handler, before any
routing is done. Routes which do not require authentication should be
listed as exceptions.

Authentication can be restricted using an ACL file which allows
filtering based on JWT claims. For more information see the inline
comments in ocm-sdk/authentication.

As an added quirk the `-v` flag for the osbuild-composer executable was
changed to `-verbose` to avoid flag collision with glog which declares
the `-v` flag in the package `init()` function. The ocm-sdk depends on
glog and pulls it in.
2021-09-04 02:48:52 +02:00
..
.gitignore auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
.travis.yml auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
executor.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
go_above_19.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
go_below_19.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
LICENSE auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
log.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
README.md auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
test.sh auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unbounded_executor.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00

concurrent

Sourcegraph GoDoc Build Status codecov rcard License

  • concurrent.Map: backport sync.Map for go below 1.9
  • concurrent.Executor: goroutine with explicit ownership and cancellable

concurrent.Map

because sync.Map is only available in go 1.9, we can use concurrent.Map to make code portable

m := concurrent.NewMap()
m.Store("hello", "world")
elem, found := m.Load("hello")
// elem will be "world"
// found will be true

concurrent.Executor

executor := concurrent.NewUnboundedExecutor()
executor.Go(func(ctx context.Context) {
    everyMillisecond := time.NewTicker(time.Millisecond)
    for {
        select {
        case <-ctx.Done():
            fmt.Println("goroutine exited")
            return
        case <-everyMillisecond.C:
            // do something
        }
    }
})
time.Sleep(time.Second)
executor.StopAndWaitForever()
fmt.Println("executor stopped")

attach goroutine to executor instance, so that we can

  • cancel it by stop the executor with Stop/StopAndWait/StopAndWaitForever
  • handle panic by callback: the default behavior will no longer crash your application