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.
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
- }