planetscale 0.3.1 → 0.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (368) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ci.yml +9 -1
  3. data/.github/workflows/gem-push.yml +9 -2
  4. data/.licenses/go/github.com/matoous/go-nanoid/v2.dep.yml +34 -0
  5. data/.licenses/go/github.com/planetscale/planetscale-go/planetscale.dep.yml +1 -1
  6. data/.licenses/go/github.com/planetscale/sql-proxy/proxy.dep.yml +1 -1
  7. data/.licenses/go/go.uber.org/zap/buffer.dep.yml +1 -1
  8. data/.licenses/go/go.uber.org/zap/internal/bufferpool.dep.yml +1 -1
  9. data/.licenses/go/go.uber.org/zap/internal/color.dep.yml +1 -1
  10. data/.licenses/go/go.uber.org/zap/internal/exit.dep.yml +1 -1
  11. data/.licenses/go/go.uber.org/zap/zapcore.dep.yml +1 -1
  12. data/.licenses/go/go.uber.org/zap.dep.yml +1 -1
  13. data/README.md +2 -0
  14. data/controller.go +21 -36
  15. data/go.mod +4 -3
  16. data/go.sum +32 -18
  17. data/lib/planetscale/version.rb +1 -1
  18. data/lib/planetscale.rb +2 -3
  19. data/planetscale.gemspec +1 -1
  20. data/proxy/planetscale-darwin.h +1 -1
  21. data/proxy/planetscale-darwin.so +0 -0
  22. data/proxy/planetscale-linux.h +1 -1
  23. data/proxy/planetscale-linux.so +0 -0
  24. data/proxy.go +1 -5
  25. metadata +3 -345
  26. data/vendor/github.com/armon/circbuf/.gitignore +0 -22
  27. data/vendor/github.com/armon/circbuf/LICENSE +0 -20
  28. data/vendor/github.com/armon/circbuf/README.md +0 -28
  29. data/vendor/github.com/armon/circbuf/circbuf.go +0 -92
  30. data/vendor/github.com/armon/circbuf/go.mod +0 -1
  31. data/vendor/github.com/golang/protobuf/AUTHORS +0 -3
  32. data/vendor/github.com/golang/protobuf/CONTRIBUTORS +0 -3
  33. data/vendor/github.com/golang/protobuf/LICENSE +0 -28
  34. data/vendor/github.com/golang/protobuf/proto/buffer.go +0 -324
  35. data/vendor/github.com/golang/protobuf/proto/defaults.go +0 -63
  36. data/vendor/github.com/golang/protobuf/proto/deprecated.go +0 -113
  37. data/vendor/github.com/golang/protobuf/proto/discard.go +0 -58
  38. data/vendor/github.com/golang/protobuf/proto/extensions.go +0 -356
  39. data/vendor/github.com/golang/protobuf/proto/properties.go +0 -306
  40. data/vendor/github.com/golang/protobuf/proto/proto.go +0 -167
  41. data/vendor/github.com/golang/protobuf/proto/registry.go +0 -317
  42. data/vendor/github.com/golang/protobuf/proto/text_decode.go +0 -801
  43. data/vendor/github.com/golang/protobuf/proto/text_encode.go +0 -560
  44. data/vendor/github.com/golang/protobuf/proto/wire.go +0 -78
  45. data/vendor/github.com/golang/protobuf/proto/wrappers.go +0 -34
  46. data/vendor/github.com/gorilla/mux/AUTHORS +0 -8
  47. data/vendor/github.com/gorilla/mux/LICENSE +0 -27
  48. data/vendor/github.com/gorilla/mux/README.md +0 -805
  49. data/vendor/github.com/gorilla/mux/doc.go +0 -306
  50. data/vendor/github.com/gorilla/mux/go.mod +0 -3
  51. data/vendor/github.com/gorilla/mux/middleware.go +0 -74
  52. data/vendor/github.com/gorilla/mux/mux.go +0 -606
  53. data/vendor/github.com/gorilla/mux/regexp.go +0 -388
  54. data/vendor/github.com/gorilla/mux/route.go +0 -736
  55. data/vendor/github.com/gorilla/mux/test_helpers.go +0 -19
  56. data/vendor/github.com/hashicorp/go-cleanhttp/LICENSE +0 -363
  57. data/vendor/github.com/hashicorp/go-cleanhttp/README.md +0 -30
  58. data/vendor/github.com/hashicorp/go-cleanhttp/cleanhttp.go +0 -58
  59. data/vendor/github.com/hashicorp/go-cleanhttp/doc.go +0 -20
  60. data/vendor/github.com/hashicorp/go-cleanhttp/go.mod +0 -3
  61. data/vendor/github.com/hashicorp/go-cleanhttp/handlers.go +0 -48
  62. data/vendor/github.com/mitchellh/go-homedir/LICENSE +0 -21
  63. data/vendor/github.com/mitchellh/go-homedir/README.md +0 -14
  64. data/vendor/github.com/mitchellh/go-homedir/go.mod +0 -1
  65. data/vendor/github.com/mitchellh/go-homedir/homedir.go +0 -167
  66. data/vendor/github.com/pkg/errors/.gitignore +0 -24
  67. data/vendor/github.com/pkg/errors/.travis.yml +0 -10
  68. data/vendor/github.com/pkg/errors/LICENSE +0 -23
  69. data/vendor/github.com/pkg/errors/Makefile +0 -44
  70. data/vendor/github.com/pkg/errors/README.md +0 -59
  71. data/vendor/github.com/pkg/errors/appveyor.yml +0 -32
  72. data/vendor/github.com/pkg/errors/errors.go +0 -288
  73. data/vendor/github.com/pkg/errors/go113.go +0 -38
  74. data/vendor/github.com/pkg/errors/stack.go +0 -177
  75. data/vendor/github.com/planetscale/planetscale-go/LICENSE +0 -202
  76. data/vendor/github.com/planetscale/planetscale-go/planetscale/audit_logs.go +0 -136
  77. data/vendor/github.com/planetscale/planetscale-go/planetscale/backups.go +0 -139
  78. data/vendor/github.com/planetscale/planetscale-go/planetscale/branches.go +0 -252
  79. data/vendor/github.com/planetscale/planetscale-go/planetscale/certs.go +0 -166
  80. data/vendor/github.com/planetscale/planetscale-go/planetscale/client.go +0 -312
  81. data/vendor/github.com/planetscale/planetscale-go/planetscale/databases.go +0 -133
  82. data/vendor/github.com/planetscale/planetscale-go/planetscale/deploy_requests.go +0 -368
  83. data/vendor/github.com/planetscale/planetscale-go/planetscale/organizations.go +0 -103
  84. data/vendor/github.com/planetscale/planetscale-go/planetscale/regions.go +0 -52
  85. data/vendor/github.com/planetscale/planetscale-go/planetscale/service_tokens.go +0 -163
  86. data/vendor/github.com/planetscale/sql-proxy/LICENSE +0 -202
  87. data/vendor/github.com/planetscale/sql-proxy/proxy/client.go +0 -476
  88. data/vendor/github.com/planetscale/sql-proxy/proxy/tls_cache.go +0 -73
  89. data/vendor/go.uber.org/atomic/.codecov.yml +0 -19
  90. data/vendor/go.uber.org/atomic/.gitignore +0 -12
  91. data/vendor/go.uber.org/atomic/.travis.yml +0 -27
  92. data/vendor/go.uber.org/atomic/CHANGELOG.md +0 -76
  93. data/vendor/go.uber.org/atomic/LICENSE.txt +0 -19
  94. data/vendor/go.uber.org/atomic/Makefile +0 -78
  95. data/vendor/go.uber.org/atomic/README.md +0 -63
  96. data/vendor/go.uber.org/atomic/bool.go +0 -81
  97. data/vendor/go.uber.org/atomic/bool_ext.go +0 -53
  98. data/vendor/go.uber.org/atomic/doc.go +0 -23
  99. data/vendor/go.uber.org/atomic/duration.go +0 -82
  100. data/vendor/go.uber.org/atomic/duration_ext.go +0 -40
  101. data/vendor/go.uber.org/atomic/error.go +0 -51
  102. data/vendor/go.uber.org/atomic/error_ext.go +0 -39
  103. data/vendor/go.uber.org/atomic/float64.go +0 -76
  104. data/vendor/go.uber.org/atomic/float64_ext.go +0 -47
  105. data/vendor/go.uber.org/atomic/gen.go +0 -26
  106. data/vendor/go.uber.org/atomic/go.mod +0 -8
  107. data/vendor/go.uber.org/atomic/go.sum +0 -9
  108. data/vendor/go.uber.org/atomic/int32.go +0 -102
  109. data/vendor/go.uber.org/atomic/int64.go +0 -102
  110. data/vendor/go.uber.org/atomic/nocmp.go +0 -35
  111. data/vendor/go.uber.org/atomic/string.go +0 -54
  112. data/vendor/go.uber.org/atomic/string_ext.go +0 -43
  113. data/vendor/go.uber.org/atomic/uint32.go +0 -102
  114. data/vendor/go.uber.org/atomic/uint64.go +0 -102
  115. data/vendor/go.uber.org/atomic/value.go +0 -31
  116. data/vendor/go.uber.org/multierr/.codecov.yml +0 -15
  117. data/vendor/go.uber.org/multierr/.gitignore +0 -4
  118. data/vendor/go.uber.org/multierr/.travis.yml +0 -23
  119. data/vendor/go.uber.org/multierr/CHANGELOG.md +0 -60
  120. data/vendor/go.uber.org/multierr/LICENSE.txt +0 -19
  121. data/vendor/go.uber.org/multierr/Makefile +0 -42
  122. data/vendor/go.uber.org/multierr/README.md +0 -23
  123. data/vendor/go.uber.org/multierr/error.go +0 -449
  124. data/vendor/go.uber.org/multierr/glide.yaml +0 -8
  125. data/vendor/go.uber.org/multierr/go.mod +0 -8
  126. data/vendor/go.uber.org/multierr/go.sum +0 -11
  127. data/vendor/go.uber.org/multierr/go113.go +0 -52
  128. data/vendor/go.uber.org/zap/.codecov.yml +0 -17
  129. data/vendor/go.uber.org/zap/.gitignore +0 -32
  130. data/vendor/go.uber.org/zap/.readme.tmpl +0 -109
  131. data/vendor/go.uber.org/zap/CHANGELOG.md +0 -492
  132. data/vendor/go.uber.org/zap/CODE_OF_CONDUCT.md +0 -75
  133. data/vendor/go.uber.org/zap/CONTRIBUTING.md +0 -75
  134. data/vendor/go.uber.org/zap/FAQ.md +0 -164
  135. data/vendor/go.uber.org/zap/LICENSE.txt +0 -19
  136. data/vendor/go.uber.org/zap/Makefile +0 -73
  137. data/vendor/go.uber.org/zap/README.md +0 -134
  138. data/vendor/go.uber.org/zap/array.go +0 -320
  139. data/vendor/go.uber.org/zap/buffer/buffer.go +0 -141
  140. data/vendor/go.uber.org/zap/buffer/pool.go +0 -49
  141. data/vendor/go.uber.org/zap/checklicense.sh +0 -17
  142. data/vendor/go.uber.org/zap/config.go +0 -264
  143. data/vendor/go.uber.org/zap/doc.go +0 -113
  144. data/vendor/go.uber.org/zap/encoder.go +0 -79
  145. data/vendor/go.uber.org/zap/error.go +0 -80
  146. data/vendor/go.uber.org/zap/field.go +0 -549
  147. data/vendor/go.uber.org/zap/flag.go +0 -39
  148. data/vendor/go.uber.org/zap/glide.yaml +0 -34
  149. data/vendor/go.uber.org/zap/global.go +0 -168
  150. data/vendor/go.uber.org/zap/global_go112.go +0 -26
  151. data/vendor/go.uber.org/zap/global_prego112.go +0 -26
  152. data/vendor/go.uber.org/zap/go.mod +0 -14
  153. data/vendor/go.uber.org/zap/go.sum +0 -54
  154. data/vendor/go.uber.org/zap/http_handler.go +0 -132
  155. data/vendor/go.uber.org/zap/internal/bufferpool/bufferpool.go +0 -31
  156. data/vendor/go.uber.org/zap/internal/color/color.go +0 -44
  157. data/vendor/go.uber.org/zap/internal/exit/exit.go +0 -64
  158. data/vendor/go.uber.org/zap/level.go +0 -132
  159. data/vendor/go.uber.org/zap/logger.go +0 -348
  160. data/vendor/go.uber.org/zap/options.go +0 -148
  161. data/vendor/go.uber.org/zap/sink.go +0 -161
  162. data/vendor/go.uber.org/zap/stacktrace.go +0 -85
  163. data/vendor/go.uber.org/zap/sugar.go +0 -315
  164. data/vendor/go.uber.org/zap/time.go +0 -27
  165. data/vendor/go.uber.org/zap/writer.go +0 -99
  166. data/vendor/go.uber.org/zap/zapcore/buffered_write_syncer.go +0 -188
  167. data/vendor/go.uber.org/zap/zapcore/clock.go +0 -50
  168. data/vendor/go.uber.org/zap/zapcore/console_encoder.go +0 -161
  169. data/vendor/go.uber.org/zap/zapcore/core.go +0 -113
  170. data/vendor/go.uber.org/zap/zapcore/doc.go +0 -24
  171. data/vendor/go.uber.org/zap/zapcore/encoder.go +0 -443
  172. data/vendor/go.uber.org/zap/zapcore/entry.go +0 -264
  173. data/vendor/go.uber.org/zap/zapcore/error.go +0 -132
  174. data/vendor/go.uber.org/zap/zapcore/field.go +0 -233
  175. data/vendor/go.uber.org/zap/zapcore/hook.go +0 -68
  176. data/vendor/go.uber.org/zap/zapcore/increase_level.go +0 -66
  177. data/vendor/go.uber.org/zap/zapcore/json_encoder.go +0 -534
  178. data/vendor/go.uber.org/zap/zapcore/level.go +0 -175
  179. data/vendor/go.uber.org/zap/zapcore/level_strings.go +0 -46
  180. data/vendor/go.uber.org/zap/zapcore/marshaler.go +0 -61
  181. data/vendor/go.uber.org/zap/zapcore/memory_encoder.go +0 -179
  182. data/vendor/go.uber.org/zap/zapcore/sampler.go +0 -208
  183. data/vendor/go.uber.org/zap/zapcore/tee.go +0 -81
  184. data/vendor/go.uber.org/zap/zapcore/write_syncer.go +0 -122
  185. data/vendor/golang.org/x/net/AUTHORS +0 -3
  186. data/vendor/golang.org/x/net/CONTRIBUTORS +0 -3
  187. data/vendor/golang.org/x/net/LICENSE +0 -27
  188. data/vendor/golang.org/x/net/PATENTS +0 -22
  189. data/vendor/golang.org/x/net/context/context.go +0 -56
  190. data/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +0 -71
  191. data/vendor/golang.org/x/net/context/go17.go +0 -73
  192. data/vendor/golang.org/x/net/context/go19.go +0 -21
  193. data/vendor/golang.org/x/net/context/pre_go17.go +0 -301
  194. data/vendor/golang.org/x/net/context/pre_go19.go +0 -110
  195. data/vendor/golang.org/x/oauth2/.travis.yml +0 -13
  196. data/vendor/golang.org/x/oauth2/AUTHORS +0 -3
  197. data/vendor/golang.org/x/oauth2/CONTRIBUTING.md +0 -26
  198. data/vendor/golang.org/x/oauth2/CONTRIBUTORS +0 -3
  199. data/vendor/golang.org/x/oauth2/LICENSE +0 -27
  200. data/vendor/golang.org/x/oauth2/README.md +0 -36
  201. data/vendor/golang.org/x/oauth2/go.mod +0 -9
  202. data/vendor/golang.org/x/oauth2/go.sum +0 -361
  203. data/vendor/golang.org/x/oauth2/internal/client_appengine.go +0 -14
  204. data/vendor/golang.org/x/oauth2/internal/doc.go +0 -6
  205. data/vendor/golang.org/x/oauth2/internal/oauth2.go +0 -37
  206. data/vendor/golang.org/x/oauth2/internal/token.go +0 -294
  207. data/vendor/golang.org/x/oauth2/internal/transport.go +0 -33
  208. data/vendor/golang.org/x/oauth2/oauth2.go +0 -381
  209. data/vendor/golang.org/x/oauth2/token.go +0 -178
  210. data/vendor/golang.org/x/oauth2/transport.go +0 -89
  211. data/vendor/google.golang.org/appengine/LICENSE +0 -202
  212. data/vendor/google.golang.org/appengine/internal/api.go +0 -678
  213. data/vendor/google.golang.org/appengine/internal/api_classic.go +0 -169
  214. data/vendor/google.golang.org/appengine/internal/api_common.go +0 -123
  215. data/vendor/google.golang.org/appengine/internal/app_id.go +0 -28
  216. data/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +0 -308
  217. data/vendor/google.golang.org/appengine/internal/base/api_base.proto +0 -33
  218. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +0 -4367
  219. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +0 -551
  220. data/vendor/google.golang.org/appengine/internal/identity.go +0 -55
  221. data/vendor/google.golang.org/appengine/internal/identity_classic.go +0 -61
  222. data/vendor/google.golang.org/appengine/internal/identity_flex.go +0 -11
  223. data/vendor/google.golang.org/appengine/internal/identity_vm.go +0 -134
  224. data/vendor/google.golang.org/appengine/internal/internal.go +0 -110
  225. data/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +0 -1313
  226. data/vendor/google.golang.org/appengine/internal/log/log_service.proto +0 -150
  227. data/vendor/google.golang.org/appengine/internal/main.go +0 -16
  228. data/vendor/google.golang.org/appengine/internal/main_common.go +0 -7
  229. data/vendor/google.golang.org/appengine/internal/main_vm.go +0 -69
  230. data/vendor/google.golang.org/appengine/internal/metadata.go +0 -60
  231. data/vendor/google.golang.org/appengine/internal/net.go +0 -56
  232. data/vendor/google.golang.org/appengine/internal/regen.sh +0 -40
  233. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +0 -361
  234. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +0 -44
  235. data/vendor/google.golang.org/appengine/internal/transaction.go +0 -115
  236. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.pb.go +0 -527
  237. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.proto +0 -64
  238. data/vendor/google.golang.org/appengine/urlfetch/urlfetch.go +0 -210
  239. data/vendor/google.golang.org/protobuf/AUTHORS +0 -3
  240. data/vendor/google.golang.org/protobuf/CONTRIBUTORS +0 -3
  241. data/vendor/google.golang.org/protobuf/LICENSE +0 -27
  242. data/vendor/google.golang.org/protobuf/PATENTS +0 -22
  243. data/vendor/google.golang.org/protobuf/encoding/prototext/decode.go +0 -773
  244. data/vendor/google.golang.org/protobuf/encoding/prototext/doc.go +0 -7
  245. data/vendor/google.golang.org/protobuf/encoding/prototext/encode.go +0 -371
  246. data/vendor/google.golang.org/protobuf/encoding/protowire/wire.go +0 -538
  247. data/vendor/google.golang.org/protobuf/internal/descfmt/stringer.go +0 -318
  248. data/vendor/google.golang.org/protobuf/internal/descopts/options.go +0 -29
  249. data/vendor/google.golang.org/protobuf/internal/detrand/rand.go +0 -69
  250. data/vendor/google.golang.org/protobuf/internal/encoding/defval/default.go +0 -213
  251. data/vendor/google.golang.org/protobuf/internal/encoding/messageset/messageset.go +0 -241
  252. data/vendor/google.golang.org/protobuf/internal/encoding/tag/tag.go +0 -207
  253. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode.go +0 -665
  254. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_number.go +0 -190
  255. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_string.go +0 -161
  256. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_token.go +0 -373
  257. data/vendor/google.golang.org/protobuf/internal/encoding/text/doc.go +0 -29
  258. data/vendor/google.golang.org/protobuf/internal/encoding/text/encode.go +0 -265
  259. data/vendor/google.golang.org/protobuf/internal/errors/errors.go +0 -89
  260. data/vendor/google.golang.org/protobuf/internal/errors/is_go112.go +0 -39
  261. data/vendor/google.golang.org/protobuf/internal/errors/is_go113.go +0 -12
  262. data/vendor/google.golang.org/protobuf/internal/filedesc/build.go +0 -158
  263. data/vendor/google.golang.org/protobuf/internal/filedesc/desc.go +0 -631
  264. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_init.go +0 -471
  265. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_lazy.go +0 -704
  266. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list.go +0 -450
  267. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list_gen.go +0 -356
  268. data/vendor/google.golang.org/protobuf/internal/filedesc/placeholder.go +0 -107
  269. data/vendor/google.golang.org/protobuf/internal/filetype/build.go +0 -297
  270. data/vendor/google.golang.org/protobuf/internal/flags/flags.go +0 -24
  271. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_disable.go +0 -9
  272. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_enable.go +0 -9
  273. data/vendor/google.golang.org/protobuf/internal/genid/any_gen.go +0 -34
  274. data/vendor/google.golang.org/protobuf/internal/genid/api_gen.go +0 -106
  275. data/vendor/google.golang.org/protobuf/internal/genid/descriptor_gen.go +0 -829
  276. data/vendor/google.golang.org/protobuf/internal/genid/doc.go +0 -11
  277. data/vendor/google.golang.org/protobuf/internal/genid/duration_gen.go +0 -34
  278. data/vendor/google.golang.org/protobuf/internal/genid/empty_gen.go +0 -19
  279. data/vendor/google.golang.org/protobuf/internal/genid/field_mask_gen.go +0 -31
  280. data/vendor/google.golang.org/protobuf/internal/genid/goname.go +0 -25
  281. data/vendor/google.golang.org/protobuf/internal/genid/map_entry.go +0 -16
  282. data/vendor/google.golang.org/protobuf/internal/genid/source_context_gen.go +0 -31
  283. data/vendor/google.golang.org/protobuf/internal/genid/struct_gen.go +0 -116
  284. data/vendor/google.golang.org/protobuf/internal/genid/timestamp_gen.go +0 -34
  285. data/vendor/google.golang.org/protobuf/internal/genid/type_gen.go +0 -184
  286. data/vendor/google.golang.org/protobuf/internal/genid/wrappers.go +0 -13
  287. data/vendor/google.golang.org/protobuf/internal/genid/wrappers_gen.go +0 -175
  288. data/vendor/google.golang.org/protobuf/internal/impl/api_export.go +0 -177
  289. data/vendor/google.golang.org/protobuf/internal/impl/checkinit.go +0 -141
  290. data/vendor/google.golang.org/protobuf/internal/impl/codec_extension.go +0 -223
  291. data/vendor/google.golang.org/protobuf/internal/impl/codec_field.go +0 -830
  292. data/vendor/google.golang.org/protobuf/internal/impl/codec_gen.go +0 -5637
  293. data/vendor/google.golang.org/protobuf/internal/impl/codec_map.go +0 -388
  294. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go111.go +0 -37
  295. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go112.go +0 -11
  296. data/vendor/google.golang.org/protobuf/internal/impl/codec_message.go +0 -217
  297. data/vendor/google.golang.org/protobuf/internal/impl/codec_messageset.go +0 -123
  298. data/vendor/google.golang.org/protobuf/internal/impl/codec_reflect.go +0 -209
  299. data/vendor/google.golang.org/protobuf/internal/impl/codec_tables.go +0 -557
  300. data/vendor/google.golang.org/protobuf/internal/impl/codec_unsafe.go +0 -17
  301. data/vendor/google.golang.org/protobuf/internal/impl/convert.go +0 -496
  302. data/vendor/google.golang.org/protobuf/internal/impl/convert_list.go +0 -141
  303. data/vendor/google.golang.org/protobuf/internal/impl/convert_map.go +0 -121
  304. data/vendor/google.golang.org/protobuf/internal/impl/decode.go +0 -276
  305. data/vendor/google.golang.org/protobuf/internal/impl/encode.go +0 -201
  306. data/vendor/google.golang.org/protobuf/internal/impl/enum.go +0 -21
  307. data/vendor/google.golang.org/protobuf/internal/impl/extension.go +0 -156
  308. data/vendor/google.golang.org/protobuf/internal/impl/legacy_enum.go +0 -219
  309. data/vendor/google.golang.org/protobuf/internal/impl/legacy_export.go +0 -92
  310. data/vendor/google.golang.org/protobuf/internal/impl/legacy_extension.go +0 -176
  311. data/vendor/google.golang.org/protobuf/internal/impl/legacy_file.go +0 -81
  312. data/vendor/google.golang.org/protobuf/internal/impl/legacy_message.go +0 -558
  313. data/vendor/google.golang.org/protobuf/internal/impl/merge.go +0 -176
  314. data/vendor/google.golang.org/protobuf/internal/impl/merge_gen.go +0 -209
  315. data/vendor/google.golang.org/protobuf/internal/impl/message.go +0 -276
  316. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect.go +0 -465
  317. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_field.go +0 -543
  318. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_gen.go +0 -249
  319. data/vendor/google.golang.org/protobuf/internal/impl/pointer_reflect.go +0 -178
  320. data/vendor/google.golang.org/protobuf/internal/impl/pointer_unsafe.go +0 -174
  321. data/vendor/google.golang.org/protobuf/internal/impl/validate.go +0 -576
  322. data/vendor/google.golang.org/protobuf/internal/impl/weak.go +0 -74
  323. data/vendor/google.golang.org/protobuf/internal/order/order.go +0 -89
  324. data/vendor/google.golang.org/protobuf/internal/order/range.go +0 -115
  325. data/vendor/google.golang.org/protobuf/internal/pragma/pragma.go +0 -29
  326. data/vendor/google.golang.org/protobuf/internal/set/ints.go +0 -58
  327. data/vendor/google.golang.org/protobuf/internal/strs/strings.go +0 -196
  328. data/vendor/google.golang.org/protobuf/internal/strs/strings_pure.go +0 -27
  329. data/vendor/google.golang.org/protobuf/internal/strs/strings_unsafe.go +0 -94
  330. data/vendor/google.golang.org/protobuf/internal/version/version.go +0 -79
  331. data/vendor/google.golang.org/protobuf/proto/checkinit.go +0 -71
  332. data/vendor/google.golang.org/protobuf/proto/decode.go +0 -278
  333. data/vendor/google.golang.org/protobuf/proto/decode_gen.go +0 -603
  334. data/vendor/google.golang.org/protobuf/proto/doc.go +0 -94
  335. data/vendor/google.golang.org/protobuf/proto/encode.go +0 -319
  336. data/vendor/google.golang.org/protobuf/proto/encode_gen.go +0 -97
  337. data/vendor/google.golang.org/protobuf/proto/equal.go +0 -167
  338. data/vendor/google.golang.org/protobuf/proto/extension.go +0 -92
  339. data/vendor/google.golang.org/protobuf/proto/merge.go +0 -139
  340. data/vendor/google.golang.org/protobuf/proto/messageset.go +0 -93
  341. data/vendor/google.golang.org/protobuf/proto/proto.go +0 -43
  342. data/vendor/google.golang.org/protobuf/proto/proto_methods.go +0 -19
  343. data/vendor/google.golang.org/protobuf/proto/proto_reflect.go +0 -19
  344. data/vendor/google.golang.org/protobuf/proto/reset.go +0 -43
  345. data/vendor/google.golang.org/protobuf/proto/size.go +0 -97
  346. data/vendor/google.golang.org/protobuf/proto/size_gen.go +0 -55
  347. data/vendor/google.golang.org/protobuf/proto/wrappers.go +0 -29
  348. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc.go +0 -276
  349. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_init.go +0 -248
  350. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_resolve.go +0 -286
  351. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_validate.go +0 -374
  352. data/vendor/google.golang.org/protobuf/reflect/protodesc/proto.go +0 -252
  353. data/vendor/google.golang.org/protobuf/reflect/protoreflect/methods.go +0 -77
  354. data/vendor/google.golang.org/protobuf/reflect/protoreflect/proto.go +0 -504
  355. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source.go +0 -128
  356. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source_gen.go +0 -461
  357. data/vendor/google.golang.org/protobuf/reflect/protoreflect/type.go +0 -665
  358. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value.go +0 -285
  359. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_pure.go +0 -59
  360. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_union.go +0 -411
  361. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_unsafe.go +0 -98
  362. data/vendor/google.golang.org/protobuf/reflect/protoregistry/registry.go +0 -869
  363. data/vendor/google.golang.org/protobuf/runtime/protoiface/legacy.go +0 -15
  364. data/vendor/google.golang.org/protobuf/runtime/protoiface/methods.go +0 -167
  365. data/vendor/google.golang.org/protobuf/runtime/protoimpl/impl.go +0 -44
  366. data/vendor/google.golang.org/protobuf/runtime/protoimpl/version.go +0 -56
  367. data/vendor/google.golang.org/protobuf/types/descriptorpb/descriptor.pb.go +0 -4039
  368. 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
- }