debian-forge-composer/vendor/github.com/modern-go/reflect2
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
go_above_17.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_17.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
Gopkg.lock auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
Gopkg.toml 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
README.md auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
reflect2.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
reflect2_amd64.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
reflect2_kind.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_386.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_amd64p32.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_arm.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_arm64.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_mips64x.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_mipsx.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_ppc64x.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
relfect2_s390x.s auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
safe_field.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
safe_map.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
safe_slice.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
safe_struct.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
safe_type.go 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
type_map.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_array.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_eface.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_field.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_iface.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_link.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_map.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_ptr.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_slice.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_struct.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00
unsafe_type.go auth: OpenID/OAUth2 middleware 2021-09-04 02:48:52 +02:00

reflect2

Sourcegraph GoDoc Build Status codecov rcard License

reflect api that avoids runtime reflect.Value cost

  • reflect get/set interface{}, with type checking
  • reflect get/set unsafe.Pointer, without type checking
  • reflect2.TypeByName works like Class.forName found in java

json-iterator use this package to save runtime dispatching cost. This package is designed for low level libraries to optimize reflection performance. General application should still use reflect standard library.

reflect2.TypeByName

// given package is github.com/your/awesome-package
type MyStruct struct {
	// ...
}

// will return the type
reflect2.TypeByName("awesome-package.MyStruct")
// however, if the type has not been used
// it will be eliminated by compiler, so we can not get it in runtime

reflect2 get/set interface

valType := reflect2.TypeOf(1)
i := 1
j := 10
valType.Set(&i, &j)
// i will be 10

to get set type, always use its pointer *type

reflect2 get/set unsafe.Pointer

valType := reflect2.TypeOf(1)
i := 1
j := 10
valType.UnsafeSet(unsafe.Pointer(&i), unsafe.Pointer(&j))
// i will be 10

to get set type, always use its pointer *type

benchmark

Benchmark is not necessary for this package. It does nothing actually. As it is just a thin wrapper to make go runtime public. Both reflect2 and reflect call same function provided by runtime package exposed by go language.

unsafe safety

Instead of casting []byte to sliceHeader in your application using unsafe. We can use reflect2 instead. This way, if sliceHeader changes in the future, only reflect2 need to be upgraded.

reflect2 tries its best to keep the implementation same as reflect (by testing).