planetscale 0.3.1 → 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +9 -1
- data/.github/workflows/gem-push.yml +9 -2
- data/.licenses/go/github.com/matoous/go-nanoid/v2.dep.yml +34 -0
- data/.licenses/go/github.com/planetscale/planetscale-go/planetscale.dep.yml +1 -1
- data/.licenses/go/github.com/planetscale/sql-proxy/proxy.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap/buffer.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap/internal/bufferpool.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap/internal/color.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap/internal/exit.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap/zapcore.dep.yml +1 -1
- data/.licenses/go/go.uber.org/zap.dep.yml +1 -1
- data/README.md +2 -0
- data/controller.go +21 -36
- data/go.mod +4 -3
- data/go.sum +32 -18
- data/lib/planetscale/version.rb +1 -1
- data/lib/planetscale.rb +2 -3
- data/planetscale.gemspec +1 -1
- data/proxy/planetscale-darwin.h +1 -1
- data/proxy/planetscale-darwin.so +0 -0
- data/proxy/planetscale-linux.h +1 -1
- data/proxy/planetscale-linux.so +0 -0
- data/proxy.go +1 -5
- metadata +3 -345
- data/vendor/github.com/armon/circbuf/.gitignore +0 -22
- data/vendor/github.com/armon/circbuf/LICENSE +0 -20
- data/vendor/github.com/armon/circbuf/README.md +0 -28
- data/vendor/github.com/armon/circbuf/circbuf.go +0 -92
- data/vendor/github.com/armon/circbuf/go.mod +0 -1
- data/vendor/github.com/golang/protobuf/AUTHORS +0 -3
- data/vendor/github.com/golang/protobuf/CONTRIBUTORS +0 -3
- data/vendor/github.com/golang/protobuf/LICENSE +0 -28
- data/vendor/github.com/golang/protobuf/proto/buffer.go +0 -324
- data/vendor/github.com/golang/protobuf/proto/defaults.go +0 -63
- data/vendor/github.com/golang/protobuf/proto/deprecated.go +0 -113
- data/vendor/github.com/golang/protobuf/proto/discard.go +0 -58
- data/vendor/github.com/golang/protobuf/proto/extensions.go +0 -356
- data/vendor/github.com/golang/protobuf/proto/properties.go +0 -306
- data/vendor/github.com/golang/protobuf/proto/proto.go +0 -167
- data/vendor/github.com/golang/protobuf/proto/registry.go +0 -317
- data/vendor/github.com/golang/protobuf/proto/text_decode.go +0 -801
- data/vendor/github.com/golang/protobuf/proto/text_encode.go +0 -560
- data/vendor/github.com/golang/protobuf/proto/wire.go +0 -78
- data/vendor/github.com/golang/protobuf/proto/wrappers.go +0 -34
- data/vendor/github.com/gorilla/mux/AUTHORS +0 -8
- data/vendor/github.com/gorilla/mux/LICENSE +0 -27
- data/vendor/github.com/gorilla/mux/README.md +0 -805
- data/vendor/github.com/gorilla/mux/doc.go +0 -306
- data/vendor/github.com/gorilla/mux/go.mod +0 -3
- data/vendor/github.com/gorilla/mux/middleware.go +0 -74
- data/vendor/github.com/gorilla/mux/mux.go +0 -606
- data/vendor/github.com/gorilla/mux/regexp.go +0 -388
- data/vendor/github.com/gorilla/mux/route.go +0 -736
- data/vendor/github.com/gorilla/mux/test_helpers.go +0 -19
- data/vendor/github.com/hashicorp/go-cleanhttp/LICENSE +0 -363
- data/vendor/github.com/hashicorp/go-cleanhttp/README.md +0 -30
- data/vendor/github.com/hashicorp/go-cleanhttp/cleanhttp.go +0 -58
- data/vendor/github.com/hashicorp/go-cleanhttp/doc.go +0 -20
- data/vendor/github.com/hashicorp/go-cleanhttp/go.mod +0 -3
- data/vendor/github.com/hashicorp/go-cleanhttp/handlers.go +0 -48
- data/vendor/github.com/mitchellh/go-homedir/LICENSE +0 -21
- data/vendor/github.com/mitchellh/go-homedir/README.md +0 -14
- data/vendor/github.com/mitchellh/go-homedir/go.mod +0 -1
- data/vendor/github.com/mitchellh/go-homedir/homedir.go +0 -167
- data/vendor/github.com/pkg/errors/.gitignore +0 -24
- data/vendor/github.com/pkg/errors/.travis.yml +0 -10
- data/vendor/github.com/pkg/errors/LICENSE +0 -23
- data/vendor/github.com/pkg/errors/Makefile +0 -44
- data/vendor/github.com/pkg/errors/README.md +0 -59
- data/vendor/github.com/pkg/errors/appveyor.yml +0 -32
- data/vendor/github.com/pkg/errors/errors.go +0 -288
- data/vendor/github.com/pkg/errors/go113.go +0 -38
- data/vendor/github.com/pkg/errors/stack.go +0 -177
- data/vendor/github.com/planetscale/planetscale-go/LICENSE +0 -202
- data/vendor/github.com/planetscale/planetscale-go/planetscale/audit_logs.go +0 -136
- data/vendor/github.com/planetscale/planetscale-go/planetscale/backups.go +0 -139
- data/vendor/github.com/planetscale/planetscale-go/planetscale/branches.go +0 -252
- data/vendor/github.com/planetscale/planetscale-go/planetscale/certs.go +0 -166
- data/vendor/github.com/planetscale/planetscale-go/planetscale/client.go +0 -312
- data/vendor/github.com/planetscale/planetscale-go/planetscale/databases.go +0 -133
- data/vendor/github.com/planetscale/planetscale-go/planetscale/deploy_requests.go +0 -368
- data/vendor/github.com/planetscale/planetscale-go/planetscale/organizations.go +0 -103
- data/vendor/github.com/planetscale/planetscale-go/planetscale/regions.go +0 -52
- data/vendor/github.com/planetscale/planetscale-go/planetscale/service_tokens.go +0 -163
- data/vendor/github.com/planetscale/sql-proxy/LICENSE +0 -202
- data/vendor/github.com/planetscale/sql-proxy/proxy/client.go +0 -476
- data/vendor/github.com/planetscale/sql-proxy/proxy/tls_cache.go +0 -73
- data/vendor/go.uber.org/atomic/.codecov.yml +0 -19
- data/vendor/go.uber.org/atomic/.gitignore +0 -12
- data/vendor/go.uber.org/atomic/.travis.yml +0 -27
- data/vendor/go.uber.org/atomic/CHANGELOG.md +0 -76
- data/vendor/go.uber.org/atomic/LICENSE.txt +0 -19
- data/vendor/go.uber.org/atomic/Makefile +0 -78
- data/vendor/go.uber.org/atomic/README.md +0 -63
- data/vendor/go.uber.org/atomic/bool.go +0 -81
- data/vendor/go.uber.org/atomic/bool_ext.go +0 -53
- data/vendor/go.uber.org/atomic/doc.go +0 -23
- data/vendor/go.uber.org/atomic/duration.go +0 -82
- data/vendor/go.uber.org/atomic/duration_ext.go +0 -40
- data/vendor/go.uber.org/atomic/error.go +0 -51
- data/vendor/go.uber.org/atomic/error_ext.go +0 -39
- data/vendor/go.uber.org/atomic/float64.go +0 -76
- data/vendor/go.uber.org/atomic/float64_ext.go +0 -47
- data/vendor/go.uber.org/atomic/gen.go +0 -26
- data/vendor/go.uber.org/atomic/go.mod +0 -8
- data/vendor/go.uber.org/atomic/go.sum +0 -9
- data/vendor/go.uber.org/atomic/int32.go +0 -102
- data/vendor/go.uber.org/atomic/int64.go +0 -102
- data/vendor/go.uber.org/atomic/nocmp.go +0 -35
- data/vendor/go.uber.org/atomic/string.go +0 -54
- data/vendor/go.uber.org/atomic/string_ext.go +0 -43
- data/vendor/go.uber.org/atomic/uint32.go +0 -102
- data/vendor/go.uber.org/atomic/uint64.go +0 -102
- data/vendor/go.uber.org/atomic/value.go +0 -31
- data/vendor/go.uber.org/multierr/.codecov.yml +0 -15
- data/vendor/go.uber.org/multierr/.gitignore +0 -4
- data/vendor/go.uber.org/multierr/.travis.yml +0 -23
- data/vendor/go.uber.org/multierr/CHANGELOG.md +0 -60
- data/vendor/go.uber.org/multierr/LICENSE.txt +0 -19
- data/vendor/go.uber.org/multierr/Makefile +0 -42
- data/vendor/go.uber.org/multierr/README.md +0 -23
- data/vendor/go.uber.org/multierr/error.go +0 -449
- data/vendor/go.uber.org/multierr/glide.yaml +0 -8
- data/vendor/go.uber.org/multierr/go.mod +0 -8
- data/vendor/go.uber.org/multierr/go.sum +0 -11
- data/vendor/go.uber.org/multierr/go113.go +0 -52
- data/vendor/go.uber.org/zap/.codecov.yml +0 -17
- data/vendor/go.uber.org/zap/.gitignore +0 -32
- data/vendor/go.uber.org/zap/.readme.tmpl +0 -109
- data/vendor/go.uber.org/zap/CHANGELOG.md +0 -492
- data/vendor/go.uber.org/zap/CODE_OF_CONDUCT.md +0 -75
- data/vendor/go.uber.org/zap/CONTRIBUTING.md +0 -75
- data/vendor/go.uber.org/zap/FAQ.md +0 -164
- data/vendor/go.uber.org/zap/LICENSE.txt +0 -19
- data/vendor/go.uber.org/zap/Makefile +0 -73
- data/vendor/go.uber.org/zap/README.md +0 -134
- data/vendor/go.uber.org/zap/array.go +0 -320
- data/vendor/go.uber.org/zap/buffer/buffer.go +0 -141
- data/vendor/go.uber.org/zap/buffer/pool.go +0 -49
- data/vendor/go.uber.org/zap/checklicense.sh +0 -17
- data/vendor/go.uber.org/zap/config.go +0 -264
- data/vendor/go.uber.org/zap/doc.go +0 -113
- data/vendor/go.uber.org/zap/encoder.go +0 -79
- data/vendor/go.uber.org/zap/error.go +0 -80
- data/vendor/go.uber.org/zap/field.go +0 -549
- data/vendor/go.uber.org/zap/flag.go +0 -39
- data/vendor/go.uber.org/zap/glide.yaml +0 -34
- data/vendor/go.uber.org/zap/global.go +0 -168
- data/vendor/go.uber.org/zap/global_go112.go +0 -26
- data/vendor/go.uber.org/zap/global_prego112.go +0 -26
- data/vendor/go.uber.org/zap/go.mod +0 -14
- data/vendor/go.uber.org/zap/go.sum +0 -54
- data/vendor/go.uber.org/zap/http_handler.go +0 -132
- data/vendor/go.uber.org/zap/internal/bufferpool/bufferpool.go +0 -31
- data/vendor/go.uber.org/zap/internal/color/color.go +0 -44
- data/vendor/go.uber.org/zap/internal/exit/exit.go +0 -64
- data/vendor/go.uber.org/zap/level.go +0 -132
- data/vendor/go.uber.org/zap/logger.go +0 -348
- data/vendor/go.uber.org/zap/options.go +0 -148
- data/vendor/go.uber.org/zap/sink.go +0 -161
- data/vendor/go.uber.org/zap/stacktrace.go +0 -85
- data/vendor/go.uber.org/zap/sugar.go +0 -315
- data/vendor/go.uber.org/zap/time.go +0 -27
- data/vendor/go.uber.org/zap/writer.go +0 -99
- data/vendor/go.uber.org/zap/zapcore/buffered_write_syncer.go +0 -188
- data/vendor/go.uber.org/zap/zapcore/clock.go +0 -50
- data/vendor/go.uber.org/zap/zapcore/console_encoder.go +0 -161
- data/vendor/go.uber.org/zap/zapcore/core.go +0 -113
- data/vendor/go.uber.org/zap/zapcore/doc.go +0 -24
- data/vendor/go.uber.org/zap/zapcore/encoder.go +0 -443
- data/vendor/go.uber.org/zap/zapcore/entry.go +0 -264
- data/vendor/go.uber.org/zap/zapcore/error.go +0 -132
- data/vendor/go.uber.org/zap/zapcore/field.go +0 -233
- data/vendor/go.uber.org/zap/zapcore/hook.go +0 -68
- data/vendor/go.uber.org/zap/zapcore/increase_level.go +0 -66
- data/vendor/go.uber.org/zap/zapcore/json_encoder.go +0 -534
- data/vendor/go.uber.org/zap/zapcore/level.go +0 -175
- data/vendor/go.uber.org/zap/zapcore/level_strings.go +0 -46
- data/vendor/go.uber.org/zap/zapcore/marshaler.go +0 -61
- data/vendor/go.uber.org/zap/zapcore/memory_encoder.go +0 -179
- data/vendor/go.uber.org/zap/zapcore/sampler.go +0 -208
- data/vendor/go.uber.org/zap/zapcore/tee.go +0 -81
- data/vendor/go.uber.org/zap/zapcore/write_syncer.go +0 -122
- data/vendor/golang.org/x/net/AUTHORS +0 -3
- data/vendor/golang.org/x/net/CONTRIBUTORS +0 -3
- data/vendor/golang.org/x/net/LICENSE +0 -27
- data/vendor/golang.org/x/net/PATENTS +0 -22
- data/vendor/golang.org/x/net/context/context.go +0 -56
- data/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +0 -71
- data/vendor/golang.org/x/net/context/go17.go +0 -73
- data/vendor/golang.org/x/net/context/go19.go +0 -21
- data/vendor/golang.org/x/net/context/pre_go17.go +0 -301
- data/vendor/golang.org/x/net/context/pre_go19.go +0 -110
- data/vendor/golang.org/x/oauth2/.travis.yml +0 -13
- data/vendor/golang.org/x/oauth2/AUTHORS +0 -3
- data/vendor/golang.org/x/oauth2/CONTRIBUTING.md +0 -26
- data/vendor/golang.org/x/oauth2/CONTRIBUTORS +0 -3
- data/vendor/golang.org/x/oauth2/LICENSE +0 -27
- data/vendor/golang.org/x/oauth2/README.md +0 -36
- data/vendor/golang.org/x/oauth2/go.mod +0 -9
- data/vendor/golang.org/x/oauth2/go.sum +0 -361
- data/vendor/golang.org/x/oauth2/internal/client_appengine.go +0 -14
- data/vendor/golang.org/x/oauth2/internal/doc.go +0 -6
- data/vendor/golang.org/x/oauth2/internal/oauth2.go +0 -37
- data/vendor/golang.org/x/oauth2/internal/token.go +0 -294
- data/vendor/golang.org/x/oauth2/internal/transport.go +0 -33
- data/vendor/golang.org/x/oauth2/oauth2.go +0 -381
- data/vendor/golang.org/x/oauth2/token.go +0 -178
- data/vendor/golang.org/x/oauth2/transport.go +0 -89
- data/vendor/google.golang.org/appengine/LICENSE +0 -202
- data/vendor/google.golang.org/appengine/internal/api.go +0 -678
- data/vendor/google.golang.org/appengine/internal/api_classic.go +0 -169
- data/vendor/google.golang.org/appengine/internal/api_common.go +0 -123
- data/vendor/google.golang.org/appengine/internal/app_id.go +0 -28
- data/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +0 -308
- data/vendor/google.golang.org/appengine/internal/base/api_base.proto +0 -33
- data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +0 -4367
- data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +0 -551
- data/vendor/google.golang.org/appengine/internal/identity.go +0 -55
- data/vendor/google.golang.org/appengine/internal/identity_classic.go +0 -61
- data/vendor/google.golang.org/appengine/internal/identity_flex.go +0 -11
- data/vendor/google.golang.org/appengine/internal/identity_vm.go +0 -134
- data/vendor/google.golang.org/appengine/internal/internal.go +0 -110
- data/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +0 -1313
- data/vendor/google.golang.org/appengine/internal/log/log_service.proto +0 -150
- data/vendor/google.golang.org/appengine/internal/main.go +0 -16
- data/vendor/google.golang.org/appengine/internal/main_common.go +0 -7
- data/vendor/google.golang.org/appengine/internal/main_vm.go +0 -69
- data/vendor/google.golang.org/appengine/internal/metadata.go +0 -60
- data/vendor/google.golang.org/appengine/internal/net.go +0 -56
- data/vendor/google.golang.org/appengine/internal/regen.sh +0 -40
- data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +0 -361
- data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +0 -44
- data/vendor/google.golang.org/appengine/internal/transaction.go +0 -115
- data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.pb.go +0 -527
- data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.proto +0 -64
- data/vendor/google.golang.org/appengine/urlfetch/urlfetch.go +0 -210
- data/vendor/google.golang.org/protobuf/AUTHORS +0 -3
- data/vendor/google.golang.org/protobuf/CONTRIBUTORS +0 -3
- data/vendor/google.golang.org/protobuf/LICENSE +0 -27
- data/vendor/google.golang.org/protobuf/PATENTS +0 -22
- data/vendor/google.golang.org/protobuf/encoding/prototext/decode.go +0 -773
- data/vendor/google.golang.org/protobuf/encoding/prototext/doc.go +0 -7
- data/vendor/google.golang.org/protobuf/encoding/prototext/encode.go +0 -371
- data/vendor/google.golang.org/protobuf/encoding/protowire/wire.go +0 -538
- data/vendor/google.golang.org/protobuf/internal/descfmt/stringer.go +0 -318
- data/vendor/google.golang.org/protobuf/internal/descopts/options.go +0 -29
- data/vendor/google.golang.org/protobuf/internal/detrand/rand.go +0 -69
- data/vendor/google.golang.org/protobuf/internal/encoding/defval/default.go +0 -213
- data/vendor/google.golang.org/protobuf/internal/encoding/messageset/messageset.go +0 -241
- data/vendor/google.golang.org/protobuf/internal/encoding/tag/tag.go +0 -207
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode.go +0 -665
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_number.go +0 -190
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_string.go +0 -161
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_token.go +0 -373
- data/vendor/google.golang.org/protobuf/internal/encoding/text/doc.go +0 -29
- data/vendor/google.golang.org/protobuf/internal/encoding/text/encode.go +0 -265
- data/vendor/google.golang.org/protobuf/internal/errors/errors.go +0 -89
- data/vendor/google.golang.org/protobuf/internal/errors/is_go112.go +0 -39
- data/vendor/google.golang.org/protobuf/internal/errors/is_go113.go +0 -12
- data/vendor/google.golang.org/protobuf/internal/filedesc/build.go +0 -158
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc.go +0 -631
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_init.go +0 -471
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_lazy.go +0 -704
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list.go +0 -450
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list_gen.go +0 -356
- data/vendor/google.golang.org/protobuf/internal/filedesc/placeholder.go +0 -107
- data/vendor/google.golang.org/protobuf/internal/filetype/build.go +0 -297
- data/vendor/google.golang.org/protobuf/internal/flags/flags.go +0 -24
- data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_disable.go +0 -9
- data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_enable.go +0 -9
- data/vendor/google.golang.org/protobuf/internal/genid/any_gen.go +0 -34
- data/vendor/google.golang.org/protobuf/internal/genid/api_gen.go +0 -106
- data/vendor/google.golang.org/protobuf/internal/genid/descriptor_gen.go +0 -829
- data/vendor/google.golang.org/protobuf/internal/genid/doc.go +0 -11
- data/vendor/google.golang.org/protobuf/internal/genid/duration_gen.go +0 -34
- data/vendor/google.golang.org/protobuf/internal/genid/empty_gen.go +0 -19
- data/vendor/google.golang.org/protobuf/internal/genid/field_mask_gen.go +0 -31
- data/vendor/google.golang.org/protobuf/internal/genid/goname.go +0 -25
- data/vendor/google.golang.org/protobuf/internal/genid/map_entry.go +0 -16
- data/vendor/google.golang.org/protobuf/internal/genid/source_context_gen.go +0 -31
- data/vendor/google.golang.org/protobuf/internal/genid/struct_gen.go +0 -116
- data/vendor/google.golang.org/protobuf/internal/genid/timestamp_gen.go +0 -34
- data/vendor/google.golang.org/protobuf/internal/genid/type_gen.go +0 -184
- data/vendor/google.golang.org/protobuf/internal/genid/wrappers.go +0 -13
- data/vendor/google.golang.org/protobuf/internal/genid/wrappers_gen.go +0 -175
- data/vendor/google.golang.org/protobuf/internal/impl/api_export.go +0 -177
- data/vendor/google.golang.org/protobuf/internal/impl/checkinit.go +0 -141
- data/vendor/google.golang.org/protobuf/internal/impl/codec_extension.go +0 -223
- data/vendor/google.golang.org/protobuf/internal/impl/codec_field.go +0 -830
- data/vendor/google.golang.org/protobuf/internal/impl/codec_gen.go +0 -5637
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map.go +0 -388
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go111.go +0 -37
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go112.go +0 -11
- data/vendor/google.golang.org/protobuf/internal/impl/codec_message.go +0 -217
- data/vendor/google.golang.org/protobuf/internal/impl/codec_messageset.go +0 -123
- data/vendor/google.golang.org/protobuf/internal/impl/codec_reflect.go +0 -209
- data/vendor/google.golang.org/protobuf/internal/impl/codec_tables.go +0 -557
- data/vendor/google.golang.org/protobuf/internal/impl/codec_unsafe.go +0 -17
- data/vendor/google.golang.org/protobuf/internal/impl/convert.go +0 -496
- data/vendor/google.golang.org/protobuf/internal/impl/convert_list.go +0 -141
- data/vendor/google.golang.org/protobuf/internal/impl/convert_map.go +0 -121
- data/vendor/google.golang.org/protobuf/internal/impl/decode.go +0 -276
- data/vendor/google.golang.org/protobuf/internal/impl/encode.go +0 -201
- data/vendor/google.golang.org/protobuf/internal/impl/enum.go +0 -21
- data/vendor/google.golang.org/protobuf/internal/impl/extension.go +0 -156
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_enum.go +0 -219
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_export.go +0 -92
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_extension.go +0 -176
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_file.go +0 -81
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_message.go +0 -558
- data/vendor/google.golang.org/protobuf/internal/impl/merge.go +0 -176
- data/vendor/google.golang.org/protobuf/internal/impl/merge_gen.go +0 -209
- data/vendor/google.golang.org/protobuf/internal/impl/message.go +0 -276
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect.go +0 -465
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_field.go +0 -543
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_gen.go +0 -249
- data/vendor/google.golang.org/protobuf/internal/impl/pointer_reflect.go +0 -178
- data/vendor/google.golang.org/protobuf/internal/impl/pointer_unsafe.go +0 -174
- data/vendor/google.golang.org/protobuf/internal/impl/validate.go +0 -576
- data/vendor/google.golang.org/protobuf/internal/impl/weak.go +0 -74
- data/vendor/google.golang.org/protobuf/internal/order/order.go +0 -89
- data/vendor/google.golang.org/protobuf/internal/order/range.go +0 -115
- data/vendor/google.golang.org/protobuf/internal/pragma/pragma.go +0 -29
- data/vendor/google.golang.org/protobuf/internal/set/ints.go +0 -58
- data/vendor/google.golang.org/protobuf/internal/strs/strings.go +0 -196
- data/vendor/google.golang.org/protobuf/internal/strs/strings_pure.go +0 -27
- data/vendor/google.golang.org/protobuf/internal/strs/strings_unsafe.go +0 -94
- data/vendor/google.golang.org/protobuf/internal/version/version.go +0 -79
- data/vendor/google.golang.org/protobuf/proto/checkinit.go +0 -71
- data/vendor/google.golang.org/protobuf/proto/decode.go +0 -278
- data/vendor/google.golang.org/protobuf/proto/decode_gen.go +0 -603
- data/vendor/google.golang.org/protobuf/proto/doc.go +0 -94
- data/vendor/google.golang.org/protobuf/proto/encode.go +0 -319
- data/vendor/google.golang.org/protobuf/proto/encode_gen.go +0 -97
- data/vendor/google.golang.org/protobuf/proto/equal.go +0 -167
- data/vendor/google.golang.org/protobuf/proto/extension.go +0 -92
- data/vendor/google.golang.org/protobuf/proto/merge.go +0 -139
- data/vendor/google.golang.org/protobuf/proto/messageset.go +0 -93
- data/vendor/google.golang.org/protobuf/proto/proto.go +0 -43
- data/vendor/google.golang.org/protobuf/proto/proto_methods.go +0 -19
- data/vendor/google.golang.org/protobuf/proto/proto_reflect.go +0 -19
- data/vendor/google.golang.org/protobuf/proto/reset.go +0 -43
- data/vendor/google.golang.org/protobuf/proto/size.go +0 -97
- data/vendor/google.golang.org/protobuf/proto/size_gen.go +0 -55
- data/vendor/google.golang.org/protobuf/proto/wrappers.go +0 -29
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc.go +0 -276
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_init.go +0 -248
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_resolve.go +0 -286
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_validate.go +0 -374
- data/vendor/google.golang.org/protobuf/reflect/protodesc/proto.go +0 -252
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/methods.go +0 -77
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/proto.go +0 -504
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/source.go +0 -128
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/source_gen.go +0 -461
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/type.go +0 -665
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value.go +0 -285
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_pure.go +0 -59
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_union.go +0 -411
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_unsafe.go +0 -98
- data/vendor/google.golang.org/protobuf/reflect/protoregistry/registry.go +0 -869
- data/vendor/google.golang.org/protobuf/runtime/protoiface/legacy.go +0 -15
- data/vendor/google.golang.org/protobuf/runtime/protoiface/methods.go +0 -167
- data/vendor/google.golang.org/protobuf/runtime/protoimpl/impl.go +0 -44
- data/vendor/google.golang.org/protobuf/runtime/protoimpl/version.go +0 -56
- data/vendor/google.golang.org/protobuf/types/descriptorpb/descriptor.pb.go +0 -4039
- data/vendor/modules.txt +0 -79
|
@@ -1,381 +0,0 @@
|
|
|
1
|
-
// Copyright 2014 The Go Authors. All rights reserved.
|
|
2
|
-
// Use of this source code is governed by a BSD-style
|
|
3
|
-
// license that can be found in the LICENSE file.
|
|
4
|
-
|
|
5
|
-
// Package oauth2 provides support for making
|
|
6
|
-
// OAuth2 authorized and authenticated HTTP requests,
|
|
7
|
-
// as specified in RFC 6749.
|
|
8
|
-
// It can additionally grant authorization with Bearer JWT.
|
|
9
|
-
package oauth2 // import "golang.org/x/oauth2"
|
|
10
|
-
|
|
11
|
-
import (
|
|
12
|
-
"bytes"
|
|
13
|
-
"context"
|
|
14
|
-
"errors"
|
|
15
|
-
"net/http"
|
|
16
|
-
"net/url"
|
|
17
|
-
"strings"
|
|
18
|
-
"sync"
|
|
19
|
-
|
|
20
|
-
"golang.org/x/oauth2/internal"
|
|
21
|
-
)
|
|
22
|
-
|
|
23
|
-
// NoContext is the default context you should supply if not using
|
|
24
|
-
// your own context.Context (see https://golang.org/x/net/context).
|
|
25
|
-
//
|
|
26
|
-
// Deprecated: Use context.Background() or context.TODO() instead.
|
|
27
|
-
var NoContext = context.TODO()
|
|
28
|
-
|
|
29
|
-
// RegisterBrokenAuthHeaderProvider previously did something. It is now a no-op.
|
|
30
|
-
//
|
|
31
|
-
// Deprecated: this function no longer does anything. Caller code that
|
|
32
|
-
// wants to avoid potential extra HTTP requests made during
|
|
33
|
-
// auto-probing of the provider's auth style should set
|
|
34
|
-
// Endpoint.AuthStyle.
|
|
35
|
-
func RegisterBrokenAuthHeaderProvider(tokenURL string) {}
|
|
36
|
-
|
|
37
|
-
// Config describes a typical 3-legged OAuth2 flow, with both the
|
|
38
|
-
// client application information and the server's endpoint URLs.
|
|
39
|
-
// For the client credentials 2-legged OAuth2 flow, see the clientcredentials
|
|
40
|
-
// package (https://golang.org/x/oauth2/clientcredentials).
|
|
41
|
-
type Config struct {
|
|
42
|
-
// ClientID is the application's ID.
|
|
43
|
-
ClientID string
|
|
44
|
-
|
|
45
|
-
// ClientSecret is the application's secret.
|
|
46
|
-
ClientSecret string
|
|
47
|
-
|
|
48
|
-
// Endpoint contains the resource server's token endpoint
|
|
49
|
-
// URLs. These are constants specific to each server and are
|
|
50
|
-
// often available via site-specific packages, such as
|
|
51
|
-
// google.Endpoint or github.Endpoint.
|
|
52
|
-
Endpoint Endpoint
|
|
53
|
-
|
|
54
|
-
// RedirectURL is the URL to redirect users going through
|
|
55
|
-
// the OAuth flow, after the resource owner's URLs.
|
|
56
|
-
RedirectURL string
|
|
57
|
-
|
|
58
|
-
// Scope specifies optional requested permissions.
|
|
59
|
-
Scopes []string
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// A TokenSource is anything that can return a token.
|
|
63
|
-
type TokenSource interface {
|
|
64
|
-
// Token returns a token or an error.
|
|
65
|
-
// Token must be safe for concurrent use by multiple goroutines.
|
|
66
|
-
// The returned Token must not be modified.
|
|
67
|
-
Token() (*Token, error)
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// Endpoint represents an OAuth 2.0 provider's authorization and token
|
|
71
|
-
// endpoint URLs.
|
|
72
|
-
type Endpoint struct {
|
|
73
|
-
AuthURL string
|
|
74
|
-
TokenURL string
|
|
75
|
-
|
|
76
|
-
// AuthStyle optionally specifies how the endpoint wants the
|
|
77
|
-
// client ID & client secret sent. The zero value means to
|
|
78
|
-
// auto-detect.
|
|
79
|
-
AuthStyle AuthStyle
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// AuthStyle represents how requests for tokens are authenticated
|
|
83
|
-
// to the server.
|
|
84
|
-
type AuthStyle int
|
|
85
|
-
|
|
86
|
-
const (
|
|
87
|
-
// AuthStyleAutoDetect means to auto-detect which authentication
|
|
88
|
-
// style the provider wants by trying both ways and caching
|
|
89
|
-
// the successful way for the future.
|
|
90
|
-
AuthStyleAutoDetect AuthStyle = 0
|
|
91
|
-
|
|
92
|
-
// AuthStyleInParams sends the "client_id" and "client_secret"
|
|
93
|
-
// in the POST body as application/x-www-form-urlencoded parameters.
|
|
94
|
-
AuthStyleInParams AuthStyle = 1
|
|
95
|
-
|
|
96
|
-
// AuthStyleInHeader sends the client_id and client_password
|
|
97
|
-
// using HTTP Basic Authorization. This is an optional style
|
|
98
|
-
// described in the OAuth2 RFC 6749 section 2.3.1.
|
|
99
|
-
AuthStyleInHeader AuthStyle = 2
|
|
100
|
-
)
|
|
101
|
-
|
|
102
|
-
var (
|
|
103
|
-
// AccessTypeOnline and AccessTypeOffline are options passed
|
|
104
|
-
// to the Options.AuthCodeURL method. They modify the
|
|
105
|
-
// "access_type" field that gets sent in the URL returned by
|
|
106
|
-
// AuthCodeURL.
|
|
107
|
-
//
|
|
108
|
-
// Online is the default if neither is specified. If your
|
|
109
|
-
// application needs to refresh access tokens when the user
|
|
110
|
-
// is not present at the browser, then use offline. This will
|
|
111
|
-
// result in your application obtaining a refresh token the
|
|
112
|
-
// first time your application exchanges an authorization
|
|
113
|
-
// code for a user.
|
|
114
|
-
AccessTypeOnline AuthCodeOption = SetAuthURLParam("access_type", "online")
|
|
115
|
-
AccessTypeOffline AuthCodeOption = SetAuthURLParam("access_type", "offline")
|
|
116
|
-
|
|
117
|
-
// ApprovalForce forces the users to view the consent dialog
|
|
118
|
-
// and confirm the permissions request at the URL returned
|
|
119
|
-
// from AuthCodeURL, even if they've already done so.
|
|
120
|
-
ApprovalForce AuthCodeOption = SetAuthURLParam("prompt", "consent")
|
|
121
|
-
)
|
|
122
|
-
|
|
123
|
-
// An AuthCodeOption is passed to Config.AuthCodeURL.
|
|
124
|
-
type AuthCodeOption interface {
|
|
125
|
-
setValue(url.Values)
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
type setParam struct{ k, v string }
|
|
129
|
-
|
|
130
|
-
func (p setParam) setValue(m url.Values) { m.Set(p.k, p.v) }
|
|
131
|
-
|
|
132
|
-
// SetAuthURLParam builds an AuthCodeOption which passes key/value parameters
|
|
133
|
-
// to a provider's authorization endpoint.
|
|
134
|
-
func SetAuthURLParam(key, value string) AuthCodeOption {
|
|
135
|
-
return setParam{key, value}
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// AuthCodeURL returns a URL to OAuth 2.0 provider's consent page
|
|
139
|
-
// that asks for permissions for the required scopes explicitly.
|
|
140
|
-
//
|
|
141
|
-
// State is a token to protect the user from CSRF attacks. You must
|
|
142
|
-
// always provide a non-empty string and validate that it matches the
|
|
143
|
-
// the state query parameter on your redirect callback.
|
|
144
|
-
// See http://tools.ietf.org/html/rfc6749#section-10.12 for more info.
|
|
145
|
-
//
|
|
146
|
-
// Opts may include AccessTypeOnline or AccessTypeOffline, as well
|
|
147
|
-
// as ApprovalForce.
|
|
148
|
-
// It can also be used to pass the PKCE challenge.
|
|
149
|
-
// See https://www.oauth.com/oauth2-servers/pkce/ for more info.
|
|
150
|
-
func (c *Config) AuthCodeURL(state string, opts ...AuthCodeOption) string {
|
|
151
|
-
var buf bytes.Buffer
|
|
152
|
-
buf.WriteString(c.Endpoint.AuthURL)
|
|
153
|
-
v := url.Values{
|
|
154
|
-
"response_type": {"code"},
|
|
155
|
-
"client_id": {c.ClientID},
|
|
156
|
-
}
|
|
157
|
-
if c.RedirectURL != "" {
|
|
158
|
-
v.Set("redirect_uri", c.RedirectURL)
|
|
159
|
-
}
|
|
160
|
-
if len(c.Scopes) > 0 {
|
|
161
|
-
v.Set("scope", strings.Join(c.Scopes, " "))
|
|
162
|
-
}
|
|
163
|
-
if state != "" {
|
|
164
|
-
// TODO(light): Docs say never to omit state; don't allow empty.
|
|
165
|
-
v.Set("state", state)
|
|
166
|
-
}
|
|
167
|
-
for _, opt := range opts {
|
|
168
|
-
opt.setValue(v)
|
|
169
|
-
}
|
|
170
|
-
if strings.Contains(c.Endpoint.AuthURL, "?") {
|
|
171
|
-
buf.WriteByte('&')
|
|
172
|
-
} else {
|
|
173
|
-
buf.WriteByte('?')
|
|
174
|
-
}
|
|
175
|
-
buf.WriteString(v.Encode())
|
|
176
|
-
return buf.String()
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
// PasswordCredentialsToken converts a resource owner username and password
|
|
180
|
-
// pair into a token.
|
|
181
|
-
//
|
|
182
|
-
// Per the RFC, this grant type should only be used "when there is a high
|
|
183
|
-
// degree of trust between the resource owner and the client (e.g., the client
|
|
184
|
-
// is part of the device operating system or a highly privileged application),
|
|
185
|
-
// and when other authorization grant types are not available."
|
|
186
|
-
// See https://tools.ietf.org/html/rfc6749#section-4.3 for more info.
|
|
187
|
-
//
|
|
188
|
-
// The provided context optionally controls which HTTP client is used. See the HTTPClient variable.
|
|
189
|
-
func (c *Config) PasswordCredentialsToken(ctx context.Context, username, password string) (*Token, error) {
|
|
190
|
-
v := url.Values{
|
|
191
|
-
"grant_type": {"password"},
|
|
192
|
-
"username": {username},
|
|
193
|
-
"password": {password},
|
|
194
|
-
}
|
|
195
|
-
if len(c.Scopes) > 0 {
|
|
196
|
-
v.Set("scope", strings.Join(c.Scopes, " "))
|
|
197
|
-
}
|
|
198
|
-
return retrieveToken(ctx, c, v)
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
// Exchange converts an authorization code into a token.
|
|
202
|
-
//
|
|
203
|
-
// It is used after a resource provider redirects the user back
|
|
204
|
-
// to the Redirect URI (the URL obtained from AuthCodeURL).
|
|
205
|
-
//
|
|
206
|
-
// The provided context optionally controls which HTTP client is used. See the HTTPClient variable.
|
|
207
|
-
//
|
|
208
|
-
// The code will be in the *http.Request.FormValue("code"). Before
|
|
209
|
-
// calling Exchange, be sure to validate FormValue("state").
|
|
210
|
-
//
|
|
211
|
-
// Opts may include the PKCE verifier code if previously used in AuthCodeURL.
|
|
212
|
-
// See https://www.oauth.com/oauth2-servers/pkce/ for more info.
|
|
213
|
-
func (c *Config) Exchange(ctx context.Context, code string, opts ...AuthCodeOption) (*Token, error) {
|
|
214
|
-
v := url.Values{
|
|
215
|
-
"grant_type": {"authorization_code"},
|
|
216
|
-
"code": {code},
|
|
217
|
-
}
|
|
218
|
-
if c.RedirectURL != "" {
|
|
219
|
-
v.Set("redirect_uri", c.RedirectURL)
|
|
220
|
-
}
|
|
221
|
-
for _, opt := range opts {
|
|
222
|
-
opt.setValue(v)
|
|
223
|
-
}
|
|
224
|
-
return retrieveToken(ctx, c, v)
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
// Client returns an HTTP client using the provided token.
|
|
228
|
-
// The token will auto-refresh as necessary. The underlying
|
|
229
|
-
// HTTP transport will be obtained using the provided context.
|
|
230
|
-
// The returned client and its Transport should not be modified.
|
|
231
|
-
func (c *Config) Client(ctx context.Context, t *Token) *http.Client {
|
|
232
|
-
return NewClient(ctx, c.TokenSource(ctx, t))
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
// TokenSource returns a TokenSource that returns t until t expires,
|
|
236
|
-
// automatically refreshing it as necessary using the provided context.
|
|
237
|
-
//
|
|
238
|
-
// Most users will use Config.Client instead.
|
|
239
|
-
func (c *Config) TokenSource(ctx context.Context, t *Token) TokenSource {
|
|
240
|
-
tkr := &tokenRefresher{
|
|
241
|
-
ctx: ctx,
|
|
242
|
-
conf: c,
|
|
243
|
-
}
|
|
244
|
-
if t != nil {
|
|
245
|
-
tkr.refreshToken = t.RefreshToken
|
|
246
|
-
}
|
|
247
|
-
return &reuseTokenSource{
|
|
248
|
-
t: t,
|
|
249
|
-
new: tkr,
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
// tokenRefresher is a TokenSource that makes "grant_type"=="refresh_token"
|
|
254
|
-
// HTTP requests to renew a token using a RefreshToken.
|
|
255
|
-
type tokenRefresher struct {
|
|
256
|
-
ctx context.Context // used to get HTTP requests
|
|
257
|
-
conf *Config
|
|
258
|
-
refreshToken string
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
// WARNING: Token is not safe for concurrent access, as it
|
|
262
|
-
// updates the tokenRefresher's refreshToken field.
|
|
263
|
-
// Within this package, it is used by reuseTokenSource which
|
|
264
|
-
// synchronizes calls to this method with its own mutex.
|
|
265
|
-
func (tf *tokenRefresher) Token() (*Token, error) {
|
|
266
|
-
if tf.refreshToken == "" {
|
|
267
|
-
return nil, errors.New("oauth2: token expired and refresh token is not set")
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
tk, err := retrieveToken(tf.ctx, tf.conf, url.Values{
|
|
271
|
-
"grant_type": {"refresh_token"},
|
|
272
|
-
"refresh_token": {tf.refreshToken},
|
|
273
|
-
})
|
|
274
|
-
|
|
275
|
-
if err != nil {
|
|
276
|
-
return nil, err
|
|
277
|
-
}
|
|
278
|
-
if tf.refreshToken != tk.RefreshToken {
|
|
279
|
-
tf.refreshToken = tk.RefreshToken
|
|
280
|
-
}
|
|
281
|
-
return tk, err
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
// reuseTokenSource is a TokenSource that holds a single token in memory
|
|
285
|
-
// and validates its expiry before each call to retrieve it with
|
|
286
|
-
// Token. If it's expired, it will be auto-refreshed using the
|
|
287
|
-
// new TokenSource.
|
|
288
|
-
type reuseTokenSource struct {
|
|
289
|
-
new TokenSource // called when t is expired.
|
|
290
|
-
|
|
291
|
-
mu sync.Mutex // guards t
|
|
292
|
-
t *Token
|
|
293
|
-
}
|
|
294
|
-
|
|
295
|
-
// Token returns the current token if it's still valid, else will
|
|
296
|
-
// refresh the current token (using r.Context for HTTP client
|
|
297
|
-
// information) and return the new one.
|
|
298
|
-
func (s *reuseTokenSource) Token() (*Token, error) {
|
|
299
|
-
s.mu.Lock()
|
|
300
|
-
defer s.mu.Unlock()
|
|
301
|
-
if s.t.Valid() {
|
|
302
|
-
return s.t, nil
|
|
303
|
-
}
|
|
304
|
-
t, err := s.new.Token()
|
|
305
|
-
if err != nil {
|
|
306
|
-
return nil, err
|
|
307
|
-
}
|
|
308
|
-
s.t = t
|
|
309
|
-
return t, nil
|
|
310
|
-
}
|
|
311
|
-
|
|
312
|
-
// StaticTokenSource returns a TokenSource that always returns the same token.
|
|
313
|
-
// Because the provided token t is never refreshed, StaticTokenSource is only
|
|
314
|
-
// useful for tokens that never expire.
|
|
315
|
-
func StaticTokenSource(t *Token) TokenSource {
|
|
316
|
-
return staticTokenSource{t}
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
// staticTokenSource is a TokenSource that always returns the same Token.
|
|
320
|
-
type staticTokenSource struct {
|
|
321
|
-
t *Token
|
|
322
|
-
}
|
|
323
|
-
|
|
324
|
-
func (s staticTokenSource) Token() (*Token, error) {
|
|
325
|
-
return s.t, nil
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
// HTTPClient is the context key to use with golang.org/x/net/context's
|
|
329
|
-
// WithValue function to associate an *http.Client value with a context.
|
|
330
|
-
var HTTPClient internal.ContextKey
|
|
331
|
-
|
|
332
|
-
// NewClient creates an *http.Client from a Context and TokenSource.
|
|
333
|
-
// The returned client is not valid beyond the lifetime of the context.
|
|
334
|
-
//
|
|
335
|
-
// Note that if a custom *http.Client is provided via the Context it
|
|
336
|
-
// is used only for token acquisition and is not used to configure the
|
|
337
|
-
// *http.Client returned from NewClient.
|
|
338
|
-
//
|
|
339
|
-
// As a special case, if src is nil, a non-OAuth2 client is returned
|
|
340
|
-
// using the provided context. This exists to support related OAuth2
|
|
341
|
-
// packages.
|
|
342
|
-
func NewClient(ctx context.Context, src TokenSource) *http.Client {
|
|
343
|
-
if src == nil {
|
|
344
|
-
return internal.ContextClient(ctx)
|
|
345
|
-
}
|
|
346
|
-
return &http.Client{
|
|
347
|
-
Transport: &Transport{
|
|
348
|
-
Base: internal.ContextClient(ctx).Transport,
|
|
349
|
-
Source: ReuseTokenSource(nil, src),
|
|
350
|
-
},
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
// ReuseTokenSource returns a TokenSource which repeatedly returns the
|
|
355
|
-
// same token as long as it's valid, starting with t.
|
|
356
|
-
// When its cached token is invalid, a new token is obtained from src.
|
|
357
|
-
//
|
|
358
|
-
// ReuseTokenSource is typically used to reuse tokens from a cache
|
|
359
|
-
// (such as a file on disk) between runs of a program, rather than
|
|
360
|
-
// obtaining new tokens unnecessarily.
|
|
361
|
-
//
|
|
362
|
-
// The initial token t may be nil, in which case the TokenSource is
|
|
363
|
-
// wrapped in a caching version if it isn't one already. This also
|
|
364
|
-
// means it's always safe to wrap ReuseTokenSource around any other
|
|
365
|
-
// TokenSource without adverse effects.
|
|
366
|
-
func ReuseTokenSource(t *Token, src TokenSource) TokenSource {
|
|
367
|
-
// Don't wrap a reuseTokenSource in itself. That would work,
|
|
368
|
-
// but cause an unnecessary number of mutex operations.
|
|
369
|
-
// Just build the equivalent one.
|
|
370
|
-
if rt, ok := src.(*reuseTokenSource); ok {
|
|
371
|
-
if t == nil {
|
|
372
|
-
// Just use it directly.
|
|
373
|
-
return rt
|
|
374
|
-
}
|
|
375
|
-
src = rt.new
|
|
376
|
-
}
|
|
377
|
-
return &reuseTokenSource{
|
|
378
|
-
t: t,
|
|
379
|
-
new: src,
|
|
380
|
-
}
|
|
381
|
-
}
|
|
@@ -1,178 +0,0 @@
|
|
|
1
|
-
// Copyright 2014 The Go Authors. All rights reserved.
|
|
2
|
-
// Use of this source code is governed by a BSD-style
|
|
3
|
-
// license that can be found in the LICENSE file.
|
|
4
|
-
|
|
5
|
-
package oauth2
|
|
6
|
-
|
|
7
|
-
import (
|
|
8
|
-
"context"
|
|
9
|
-
"fmt"
|
|
10
|
-
"net/http"
|
|
11
|
-
"net/url"
|
|
12
|
-
"strconv"
|
|
13
|
-
"strings"
|
|
14
|
-
"time"
|
|
15
|
-
|
|
16
|
-
"golang.org/x/oauth2/internal"
|
|
17
|
-
)
|
|
18
|
-
|
|
19
|
-
// expiryDelta determines how earlier a token should be considered
|
|
20
|
-
// expired than its actual expiration time. It is used to avoid late
|
|
21
|
-
// expirations due to client-server time mismatches.
|
|
22
|
-
const expiryDelta = 10 * time.Second
|
|
23
|
-
|
|
24
|
-
// Token represents the credentials used to authorize
|
|
25
|
-
// the requests to access protected resources on the OAuth 2.0
|
|
26
|
-
// provider's backend.
|
|
27
|
-
//
|
|
28
|
-
// Most users of this package should not access fields of Token
|
|
29
|
-
// directly. They're exported mostly for use by related packages
|
|
30
|
-
// implementing derivative OAuth2 flows.
|
|
31
|
-
type Token struct {
|
|
32
|
-
// AccessToken is the token that authorizes and authenticates
|
|
33
|
-
// the requests.
|
|
34
|
-
AccessToken string `json:"access_token"`
|
|
35
|
-
|
|
36
|
-
// TokenType is the type of token.
|
|
37
|
-
// The Type method returns either this or "Bearer", the default.
|
|
38
|
-
TokenType string `json:"token_type,omitempty"`
|
|
39
|
-
|
|
40
|
-
// RefreshToken is a token that's used by the application
|
|
41
|
-
// (as opposed to the user) to refresh the access token
|
|
42
|
-
// if it expires.
|
|
43
|
-
RefreshToken string `json:"refresh_token,omitempty"`
|
|
44
|
-
|
|
45
|
-
// Expiry is the optional expiration time of the access token.
|
|
46
|
-
//
|
|
47
|
-
// If zero, TokenSource implementations will reuse the same
|
|
48
|
-
// token forever and RefreshToken or equivalent
|
|
49
|
-
// mechanisms for that TokenSource will not be used.
|
|
50
|
-
Expiry time.Time `json:"expiry,omitempty"`
|
|
51
|
-
|
|
52
|
-
// raw optionally contains extra metadata from the server
|
|
53
|
-
// when updating a token.
|
|
54
|
-
raw interface{}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// Type returns t.TokenType if non-empty, else "Bearer".
|
|
58
|
-
func (t *Token) Type() string {
|
|
59
|
-
if strings.EqualFold(t.TokenType, "bearer") {
|
|
60
|
-
return "Bearer"
|
|
61
|
-
}
|
|
62
|
-
if strings.EqualFold(t.TokenType, "mac") {
|
|
63
|
-
return "MAC"
|
|
64
|
-
}
|
|
65
|
-
if strings.EqualFold(t.TokenType, "basic") {
|
|
66
|
-
return "Basic"
|
|
67
|
-
}
|
|
68
|
-
if t.TokenType != "" {
|
|
69
|
-
return t.TokenType
|
|
70
|
-
}
|
|
71
|
-
return "Bearer"
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
// SetAuthHeader sets the Authorization header to r using the access
|
|
75
|
-
// token in t.
|
|
76
|
-
//
|
|
77
|
-
// This method is unnecessary when using Transport or an HTTP Client
|
|
78
|
-
// returned by this package.
|
|
79
|
-
func (t *Token) SetAuthHeader(r *http.Request) {
|
|
80
|
-
r.Header.Set("Authorization", t.Type()+" "+t.AccessToken)
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// WithExtra returns a new Token that's a clone of t, but using the
|
|
84
|
-
// provided raw extra map. This is only intended for use by packages
|
|
85
|
-
// implementing derivative OAuth2 flows.
|
|
86
|
-
func (t *Token) WithExtra(extra interface{}) *Token {
|
|
87
|
-
t2 := new(Token)
|
|
88
|
-
*t2 = *t
|
|
89
|
-
t2.raw = extra
|
|
90
|
-
return t2
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// Extra returns an extra field.
|
|
94
|
-
// Extra fields are key-value pairs returned by the server as a
|
|
95
|
-
// part of the token retrieval response.
|
|
96
|
-
func (t *Token) Extra(key string) interface{} {
|
|
97
|
-
if raw, ok := t.raw.(map[string]interface{}); ok {
|
|
98
|
-
return raw[key]
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
vals, ok := t.raw.(url.Values)
|
|
102
|
-
if !ok {
|
|
103
|
-
return nil
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
v := vals.Get(key)
|
|
107
|
-
switch s := strings.TrimSpace(v); strings.Count(s, ".") {
|
|
108
|
-
case 0: // Contains no "."; try to parse as int
|
|
109
|
-
if i, err := strconv.ParseInt(s, 10, 64); err == nil {
|
|
110
|
-
return i
|
|
111
|
-
}
|
|
112
|
-
case 1: // Contains a single "."; try to parse as float
|
|
113
|
-
if f, err := strconv.ParseFloat(s, 64); err == nil {
|
|
114
|
-
return f
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
return v
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// timeNow is time.Now but pulled out as a variable for tests.
|
|
122
|
-
var timeNow = time.Now
|
|
123
|
-
|
|
124
|
-
// expired reports whether the token is expired.
|
|
125
|
-
// t must be non-nil.
|
|
126
|
-
func (t *Token) expired() bool {
|
|
127
|
-
if t.Expiry.IsZero() {
|
|
128
|
-
return false
|
|
129
|
-
}
|
|
130
|
-
return t.Expiry.Round(0).Add(-expiryDelta).Before(timeNow())
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
// Valid reports whether t is non-nil, has an AccessToken, and is not expired.
|
|
134
|
-
func (t *Token) Valid() bool {
|
|
135
|
-
return t != nil && t.AccessToken != "" && !t.expired()
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// tokenFromInternal maps an *internal.Token struct into
|
|
139
|
-
// a *Token struct.
|
|
140
|
-
func tokenFromInternal(t *internal.Token) *Token {
|
|
141
|
-
if t == nil {
|
|
142
|
-
return nil
|
|
143
|
-
}
|
|
144
|
-
return &Token{
|
|
145
|
-
AccessToken: t.AccessToken,
|
|
146
|
-
TokenType: t.TokenType,
|
|
147
|
-
RefreshToken: t.RefreshToken,
|
|
148
|
-
Expiry: t.Expiry,
|
|
149
|
-
raw: t.Raw,
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
// retrieveToken takes a *Config and uses that to retrieve an *internal.Token.
|
|
154
|
-
// This token is then mapped from *internal.Token into an *oauth2.Token which is returned along
|
|
155
|
-
// with an error..
|
|
156
|
-
func retrieveToken(ctx context.Context, c *Config, v url.Values) (*Token, error) {
|
|
157
|
-
tk, err := internal.RetrieveToken(ctx, c.ClientID, c.ClientSecret, c.Endpoint.TokenURL, v, internal.AuthStyle(c.Endpoint.AuthStyle))
|
|
158
|
-
if err != nil {
|
|
159
|
-
if rErr, ok := err.(*internal.RetrieveError); ok {
|
|
160
|
-
return nil, (*RetrieveError)(rErr)
|
|
161
|
-
}
|
|
162
|
-
return nil, err
|
|
163
|
-
}
|
|
164
|
-
return tokenFromInternal(tk), nil
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
// RetrieveError is the error returned when the token endpoint returns a
|
|
168
|
-
// non-2XX HTTP status code.
|
|
169
|
-
type RetrieveError struct {
|
|
170
|
-
Response *http.Response
|
|
171
|
-
// Body is the body that was consumed by reading Response.Body.
|
|
172
|
-
// It may be truncated.
|
|
173
|
-
Body []byte
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
func (r *RetrieveError) Error() string {
|
|
177
|
-
return fmt.Sprintf("oauth2: cannot fetch token: %v\nResponse: %s", r.Response.Status, r.Body)
|
|
178
|
-
}
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
// Copyright 2014 The Go Authors. All rights reserved.
|
|
2
|
-
// Use of this source code is governed by a BSD-style
|
|
3
|
-
// license that can be found in the LICENSE file.
|
|
4
|
-
|
|
5
|
-
package oauth2
|
|
6
|
-
|
|
7
|
-
import (
|
|
8
|
-
"errors"
|
|
9
|
-
"log"
|
|
10
|
-
"net/http"
|
|
11
|
-
"sync"
|
|
12
|
-
)
|
|
13
|
-
|
|
14
|
-
// Transport is an http.RoundTripper that makes OAuth 2.0 HTTP requests,
|
|
15
|
-
// wrapping a base RoundTripper and adding an Authorization header
|
|
16
|
-
// with a token from the supplied Sources.
|
|
17
|
-
//
|
|
18
|
-
// Transport is a low-level mechanism. Most code will use the
|
|
19
|
-
// higher-level Config.Client method instead.
|
|
20
|
-
type Transport struct {
|
|
21
|
-
// Source supplies the token to add to outgoing requests'
|
|
22
|
-
// Authorization headers.
|
|
23
|
-
Source TokenSource
|
|
24
|
-
|
|
25
|
-
// Base is the base RoundTripper used to make HTTP requests.
|
|
26
|
-
// If nil, http.DefaultTransport is used.
|
|
27
|
-
Base http.RoundTripper
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// RoundTrip authorizes and authenticates the request with an
|
|
31
|
-
// access token from Transport's Source.
|
|
32
|
-
func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) {
|
|
33
|
-
reqBodyClosed := false
|
|
34
|
-
if req.Body != nil {
|
|
35
|
-
defer func() {
|
|
36
|
-
if !reqBodyClosed {
|
|
37
|
-
req.Body.Close()
|
|
38
|
-
}
|
|
39
|
-
}()
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
if t.Source == nil {
|
|
43
|
-
return nil, errors.New("oauth2: Transport's Source is nil")
|
|
44
|
-
}
|
|
45
|
-
token, err := t.Source.Token()
|
|
46
|
-
if err != nil {
|
|
47
|
-
return nil, err
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
req2 := cloneRequest(req) // per RoundTripper contract
|
|
51
|
-
token.SetAuthHeader(req2)
|
|
52
|
-
|
|
53
|
-
// req.Body is assumed to be closed by the base RoundTripper.
|
|
54
|
-
reqBodyClosed = true
|
|
55
|
-
return t.base().RoundTrip(req2)
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
var cancelOnce sync.Once
|
|
59
|
-
|
|
60
|
-
// CancelRequest does nothing. It used to be a legacy cancellation mechanism
|
|
61
|
-
// but now only it only logs on first use to warn that it's deprecated.
|
|
62
|
-
//
|
|
63
|
-
// Deprecated: use contexts for cancellation instead.
|
|
64
|
-
func (t *Transport) CancelRequest(req *http.Request) {
|
|
65
|
-
cancelOnce.Do(func() {
|
|
66
|
-
log.Printf("deprecated: golang.org/x/oauth2: Transport.CancelRequest no longer does anything; use contexts")
|
|
67
|
-
})
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
func (t *Transport) base() http.RoundTripper {
|
|
71
|
-
if t.Base != nil {
|
|
72
|
-
return t.Base
|
|
73
|
-
}
|
|
74
|
-
return http.DefaultTransport
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
// cloneRequest returns a clone of the provided *http.Request.
|
|
78
|
-
// The clone is a shallow copy of the struct and its Header map.
|
|
79
|
-
func cloneRequest(r *http.Request) *http.Request {
|
|
80
|
-
// shallow copy of the struct
|
|
81
|
-
r2 := new(http.Request)
|
|
82
|
-
*r2 = *r
|
|
83
|
-
// deep copy of the Header
|
|
84
|
-
r2.Header = make(http.Header, len(r.Header))
|
|
85
|
-
for k, s := range r.Header {
|
|
86
|
-
r2.Header[k] = append([]string(nil), s...)
|
|
87
|
-
}
|
|
88
|
-
return r2
|
|
89
|
-
}
|