planetscale 0.2.0 → 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 (365) hide show
  1. checksums.yaml +4 -4
  2. data/.buildkite/pipeline.yml +21 -0
  3. data/.github/workflows/ci.yml +9 -1
  4. data/.github/workflows/gem-push.yml +9 -2
  5. data/.licenses/go/github.com/matoous/go-nanoid/v2.dep.yml +34 -0
  6. data/.licenses/go/github.com/planetscale/planetscale-go/planetscale.dep.yml +56 -3
  7. data/.licenses/go/github.com/planetscale/sql-proxy/proxy.dep.yml +205 -172
  8. data/.licenses/go/go.uber.org/zap/buffer.dep.yml +1 -1
  9. data/.licenses/go/go.uber.org/zap/internal/bufferpool.dep.yml +1 -1
  10. data/.licenses/go/go.uber.org/zap/internal/color.dep.yml +1 -1
  11. data/.licenses/go/go.uber.org/zap/internal/exit.dep.yml +1 -1
  12. data/.licenses/go/go.uber.org/zap/zapcore.dep.yml +1 -1
  13. data/.licenses/go/go.uber.org/zap.dep.yml +1 -1
  14. data/README.md +11 -8
  15. data/controller.go +24 -26
  16. data/go.mod +4 -3
  17. data/go.sum +42 -27
  18. data/lib/generators/planetscale/install_generator.rb +8 -6
  19. data/lib/planetscale/version.rb +1 -1
  20. data/lib/planetscale.rb +14 -15
  21. data/planetscale.gemspec +2 -2
  22. data/proxy/planetscale-darwin.h +1 -1
  23. data/proxy/planetscale-darwin.so +0 -0
  24. data/proxy/planetscale-linux.h +1 -1
  25. data/proxy/planetscale-linux.so +0 -0
  26. data/proxy.go +1 -5
  27. metadata +6 -342
  28. data/vendor/github.com/armon/circbuf/.gitignore +0 -22
  29. data/vendor/github.com/armon/circbuf/LICENSE +0 -20
  30. data/vendor/github.com/armon/circbuf/README.md +0 -28
  31. data/vendor/github.com/armon/circbuf/circbuf.go +0 -92
  32. data/vendor/github.com/armon/circbuf/go.mod +0 -1
  33. data/vendor/github.com/golang/protobuf/AUTHORS +0 -3
  34. data/vendor/github.com/golang/protobuf/CONTRIBUTORS +0 -3
  35. data/vendor/github.com/golang/protobuf/LICENSE +0 -28
  36. data/vendor/github.com/golang/protobuf/proto/buffer.go +0 -324
  37. data/vendor/github.com/golang/protobuf/proto/defaults.go +0 -63
  38. data/vendor/github.com/golang/protobuf/proto/deprecated.go +0 -113
  39. data/vendor/github.com/golang/protobuf/proto/discard.go +0 -58
  40. data/vendor/github.com/golang/protobuf/proto/extensions.go +0 -356
  41. data/vendor/github.com/golang/protobuf/proto/properties.go +0 -306
  42. data/vendor/github.com/golang/protobuf/proto/proto.go +0 -167
  43. data/vendor/github.com/golang/protobuf/proto/registry.go +0 -317
  44. data/vendor/github.com/golang/protobuf/proto/text_decode.go +0 -801
  45. data/vendor/github.com/golang/protobuf/proto/text_encode.go +0 -560
  46. data/vendor/github.com/golang/protobuf/proto/wire.go +0 -78
  47. data/vendor/github.com/golang/protobuf/proto/wrappers.go +0 -34
  48. data/vendor/github.com/gorilla/mux/AUTHORS +0 -8
  49. data/vendor/github.com/gorilla/mux/LICENSE +0 -27
  50. data/vendor/github.com/gorilla/mux/README.md +0 -805
  51. data/vendor/github.com/gorilla/mux/doc.go +0 -306
  52. data/vendor/github.com/gorilla/mux/go.mod +0 -3
  53. data/vendor/github.com/gorilla/mux/middleware.go +0 -74
  54. data/vendor/github.com/gorilla/mux/mux.go +0 -606
  55. data/vendor/github.com/gorilla/mux/regexp.go +0 -388
  56. data/vendor/github.com/gorilla/mux/route.go +0 -736
  57. data/vendor/github.com/gorilla/mux/test_helpers.go +0 -19
  58. data/vendor/github.com/hashicorp/go-cleanhttp/LICENSE +0 -363
  59. data/vendor/github.com/hashicorp/go-cleanhttp/README.md +0 -30
  60. data/vendor/github.com/hashicorp/go-cleanhttp/cleanhttp.go +0 -58
  61. data/vendor/github.com/hashicorp/go-cleanhttp/doc.go +0 -20
  62. data/vendor/github.com/hashicorp/go-cleanhttp/go.mod +0 -3
  63. data/vendor/github.com/hashicorp/go-cleanhttp/handlers.go +0 -48
  64. data/vendor/github.com/mitchellh/go-homedir/LICENSE +0 -21
  65. data/vendor/github.com/mitchellh/go-homedir/README.md +0 -14
  66. data/vendor/github.com/mitchellh/go-homedir/go.mod +0 -1
  67. data/vendor/github.com/mitchellh/go-homedir/homedir.go +0 -167
  68. data/vendor/github.com/pkg/errors/.gitignore +0 -24
  69. data/vendor/github.com/pkg/errors/.travis.yml +0 -10
  70. data/vendor/github.com/pkg/errors/LICENSE +0 -23
  71. data/vendor/github.com/pkg/errors/Makefile +0 -44
  72. data/vendor/github.com/pkg/errors/README.md +0 -59
  73. data/vendor/github.com/pkg/errors/appveyor.yml +0 -32
  74. data/vendor/github.com/pkg/errors/errors.go +0 -288
  75. data/vendor/github.com/pkg/errors/go113.go +0 -38
  76. data/vendor/github.com/pkg/errors/stack.go +0 -177
  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 -258
  79. data/vendor/github.com/planetscale/planetscale-go/planetscale/certs.go +0 -142
  80. data/vendor/github.com/planetscale/planetscale-go/planetscale/client.go +0 -305
  81. data/vendor/github.com/planetscale/planetscale-go/planetscale/databases.go +0 -131
  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 -78
  84. data/vendor/github.com/planetscale/planetscale-go/planetscale/service_tokens.go +0 -163
  85. data/vendor/github.com/planetscale/sql-proxy/proxy/client.go +0 -467
  86. data/vendor/github.com/planetscale/sql-proxy/proxy/tls_cache.go +0 -73
  87. data/vendor/go.uber.org/atomic/.codecov.yml +0 -19
  88. data/vendor/go.uber.org/atomic/.gitignore +0 -12
  89. data/vendor/go.uber.org/atomic/.travis.yml +0 -27
  90. data/vendor/go.uber.org/atomic/CHANGELOG.md +0 -76
  91. data/vendor/go.uber.org/atomic/LICENSE.txt +0 -19
  92. data/vendor/go.uber.org/atomic/Makefile +0 -78
  93. data/vendor/go.uber.org/atomic/README.md +0 -63
  94. data/vendor/go.uber.org/atomic/bool.go +0 -81
  95. data/vendor/go.uber.org/atomic/bool_ext.go +0 -53
  96. data/vendor/go.uber.org/atomic/doc.go +0 -23
  97. data/vendor/go.uber.org/atomic/duration.go +0 -82
  98. data/vendor/go.uber.org/atomic/duration_ext.go +0 -40
  99. data/vendor/go.uber.org/atomic/error.go +0 -51
  100. data/vendor/go.uber.org/atomic/error_ext.go +0 -39
  101. data/vendor/go.uber.org/atomic/float64.go +0 -76
  102. data/vendor/go.uber.org/atomic/float64_ext.go +0 -47
  103. data/vendor/go.uber.org/atomic/gen.go +0 -26
  104. data/vendor/go.uber.org/atomic/go.mod +0 -8
  105. data/vendor/go.uber.org/atomic/go.sum +0 -9
  106. data/vendor/go.uber.org/atomic/int32.go +0 -102
  107. data/vendor/go.uber.org/atomic/int64.go +0 -102
  108. data/vendor/go.uber.org/atomic/nocmp.go +0 -35
  109. data/vendor/go.uber.org/atomic/string.go +0 -54
  110. data/vendor/go.uber.org/atomic/string_ext.go +0 -43
  111. data/vendor/go.uber.org/atomic/uint32.go +0 -102
  112. data/vendor/go.uber.org/atomic/uint64.go +0 -102
  113. data/vendor/go.uber.org/atomic/value.go +0 -31
  114. data/vendor/go.uber.org/multierr/.codecov.yml +0 -15
  115. data/vendor/go.uber.org/multierr/.gitignore +0 -4
  116. data/vendor/go.uber.org/multierr/.travis.yml +0 -23
  117. data/vendor/go.uber.org/multierr/CHANGELOG.md +0 -60
  118. data/vendor/go.uber.org/multierr/LICENSE.txt +0 -19
  119. data/vendor/go.uber.org/multierr/Makefile +0 -42
  120. data/vendor/go.uber.org/multierr/README.md +0 -23
  121. data/vendor/go.uber.org/multierr/error.go +0 -449
  122. data/vendor/go.uber.org/multierr/glide.yaml +0 -8
  123. data/vendor/go.uber.org/multierr/go.mod +0 -8
  124. data/vendor/go.uber.org/multierr/go.sum +0 -11
  125. data/vendor/go.uber.org/multierr/go113.go +0 -52
  126. data/vendor/go.uber.org/zap/.codecov.yml +0 -17
  127. data/vendor/go.uber.org/zap/.gitignore +0 -32
  128. data/vendor/go.uber.org/zap/.readme.tmpl +0 -109
  129. data/vendor/go.uber.org/zap/.travis.yml +0 -23
  130. data/vendor/go.uber.org/zap/CHANGELOG.md +0 -432
  131. data/vendor/go.uber.org/zap/CODE_OF_CONDUCT.md +0 -75
  132. data/vendor/go.uber.org/zap/CONTRIBUTING.md +0 -81
  133. data/vendor/go.uber.org/zap/FAQ.md +0 -156
  134. data/vendor/go.uber.org/zap/LICENSE.txt +0 -19
  135. data/vendor/go.uber.org/zap/Makefile +0 -63
  136. data/vendor/go.uber.org/zap/README.md +0 -134
  137. data/vendor/go.uber.org/zap/array.go +0 -320
  138. data/vendor/go.uber.org/zap/buffer/buffer.go +0 -123
  139. data/vendor/go.uber.org/zap/buffer/pool.go +0 -49
  140. data/vendor/go.uber.org/zap/checklicense.sh +0 -17
  141. data/vendor/go.uber.org/zap/config.go +0 -264
  142. data/vendor/go.uber.org/zap/doc.go +0 -113
  143. data/vendor/go.uber.org/zap/encoder.go +0 -79
  144. data/vendor/go.uber.org/zap/error.go +0 -80
  145. data/vendor/go.uber.org/zap/field.go +0 -539
  146. data/vendor/go.uber.org/zap/flag.go +0 -39
  147. data/vendor/go.uber.org/zap/glide.yaml +0 -34
  148. data/vendor/go.uber.org/zap/global.go +0 -168
  149. data/vendor/go.uber.org/zap/global_go112.go +0 -26
  150. data/vendor/go.uber.org/zap/global_prego112.go +0 -26
  151. data/vendor/go.uber.org/zap/go.mod +0 -13
  152. data/vendor/go.uber.org/zap/go.sum +0 -56
  153. data/vendor/go.uber.org/zap/http_handler.go +0 -81
  154. data/vendor/go.uber.org/zap/internal/bufferpool/bufferpool.go +0 -31
  155. data/vendor/go.uber.org/zap/internal/color/color.go +0 -44
  156. data/vendor/go.uber.org/zap/internal/exit/exit.go +0 -64
  157. data/vendor/go.uber.org/zap/level.go +0 -132
  158. data/vendor/go.uber.org/zap/logger.go +0 -344
  159. data/vendor/go.uber.org/zap/options.go +0 -140
  160. data/vendor/go.uber.org/zap/sink.go +0 -161
  161. data/vendor/go.uber.org/zap/stacktrace.go +0 -85
  162. data/vendor/go.uber.org/zap/sugar.go +0 -304
  163. data/vendor/go.uber.org/zap/time.go +0 -27
  164. data/vendor/go.uber.org/zap/writer.go +0 -99
  165. data/vendor/go.uber.org/zap/zapcore/console_encoder.go +0 -161
  166. data/vendor/go.uber.org/zap/zapcore/core.go +0 -113
  167. data/vendor/go.uber.org/zap/zapcore/doc.go +0 -24
  168. data/vendor/go.uber.org/zap/zapcore/encoder.go +0 -443
  169. data/vendor/go.uber.org/zap/zapcore/entry.go +0 -264
  170. data/vendor/go.uber.org/zap/zapcore/error.go +0 -115
  171. data/vendor/go.uber.org/zap/zapcore/field.go +0 -227
  172. data/vendor/go.uber.org/zap/zapcore/hook.go +0 -68
  173. data/vendor/go.uber.org/zap/zapcore/increase_level.go +0 -66
  174. data/vendor/go.uber.org/zap/zapcore/json_encoder.go +0 -534
  175. data/vendor/go.uber.org/zap/zapcore/level.go +0 -175
  176. data/vendor/go.uber.org/zap/zapcore/level_strings.go +0 -46
  177. data/vendor/go.uber.org/zap/zapcore/marshaler.go +0 -61
  178. data/vendor/go.uber.org/zap/zapcore/memory_encoder.go +0 -179
  179. data/vendor/go.uber.org/zap/zapcore/sampler.go +0 -208
  180. data/vendor/go.uber.org/zap/zapcore/tee.go +0 -81
  181. data/vendor/go.uber.org/zap/zapcore/write_syncer.go +0 -123
  182. data/vendor/golang.org/x/net/AUTHORS +0 -3
  183. data/vendor/golang.org/x/net/CONTRIBUTORS +0 -3
  184. data/vendor/golang.org/x/net/LICENSE +0 -27
  185. data/vendor/golang.org/x/net/PATENTS +0 -22
  186. data/vendor/golang.org/x/net/context/context.go +0 -56
  187. data/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +0 -71
  188. data/vendor/golang.org/x/net/context/go17.go +0 -73
  189. data/vendor/golang.org/x/net/context/go19.go +0 -21
  190. data/vendor/golang.org/x/net/context/pre_go17.go +0 -301
  191. data/vendor/golang.org/x/net/context/pre_go19.go +0 -110
  192. data/vendor/golang.org/x/oauth2/.travis.yml +0 -13
  193. data/vendor/golang.org/x/oauth2/AUTHORS +0 -3
  194. data/vendor/golang.org/x/oauth2/CONTRIBUTING.md +0 -26
  195. data/vendor/golang.org/x/oauth2/CONTRIBUTORS +0 -3
  196. data/vendor/golang.org/x/oauth2/LICENSE +0 -27
  197. data/vendor/golang.org/x/oauth2/README.md +0 -36
  198. data/vendor/golang.org/x/oauth2/go.mod +0 -9
  199. data/vendor/golang.org/x/oauth2/go.sum +0 -361
  200. data/vendor/golang.org/x/oauth2/internal/client_appengine.go +0 -14
  201. data/vendor/golang.org/x/oauth2/internal/doc.go +0 -6
  202. data/vendor/golang.org/x/oauth2/internal/oauth2.go +0 -37
  203. data/vendor/golang.org/x/oauth2/internal/token.go +0 -294
  204. data/vendor/golang.org/x/oauth2/internal/transport.go +0 -33
  205. data/vendor/golang.org/x/oauth2/oauth2.go +0 -381
  206. data/vendor/golang.org/x/oauth2/token.go +0 -178
  207. data/vendor/golang.org/x/oauth2/transport.go +0 -89
  208. data/vendor/google.golang.org/appengine/LICENSE +0 -202
  209. data/vendor/google.golang.org/appengine/internal/api.go +0 -678
  210. data/vendor/google.golang.org/appengine/internal/api_classic.go +0 -169
  211. data/vendor/google.golang.org/appengine/internal/api_common.go +0 -123
  212. data/vendor/google.golang.org/appengine/internal/app_id.go +0 -28
  213. data/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +0 -308
  214. data/vendor/google.golang.org/appengine/internal/base/api_base.proto +0 -33
  215. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +0 -4367
  216. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +0 -551
  217. data/vendor/google.golang.org/appengine/internal/identity.go +0 -55
  218. data/vendor/google.golang.org/appengine/internal/identity_classic.go +0 -61
  219. data/vendor/google.golang.org/appengine/internal/identity_flex.go +0 -11
  220. data/vendor/google.golang.org/appengine/internal/identity_vm.go +0 -134
  221. data/vendor/google.golang.org/appengine/internal/internal.go +0 -110
  222. data/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +0 -1313
  223. data/vendor/google.golang.org/appengine/internal/log/log_service.proto +0 -150
  224. data/vendor/google.golang.org/appengine/internal/main.go +0 -16
  225. data/vendor/google.golang.org/appengine/internal/main_common.go +0 -7
  226. data/vendor/google.golang.org/appengine/internal/main_vm.go +0 -69
  227. data/vendor/google.golang.org/appengine/internal/metadata.go +0 -60
  228. data/vendor/google.golang.org/appengine/internal/net.go +0 -56
  229. data/vendor/google.golang.org/appengine/internal/regen.sh +0 -40
  230. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +0 -361
  231. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +0 -44
  232. data/vendor/google.golang.org/appengine/internal/transaction.go +0 -115
  233. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.pb.go +0 -527
  234. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.proto +0 -64
  235. data/vendor/google.golang.org/appengine/urlfetch/urlfetch.go +0 -210
  236. data/vendor/google.golang.org/protobuf/AUTHORS +0 -3
  237. data/vendor/google.golang.org/protobuf/CONTRIBUTORS +0 -3
  238. data/vendor/google.golang.org/protobuf/LICENSE +0 -27
  239. data/vendor/google.golang.org/protobuf/PATENTS +0 -22
  240. data/vendor/google.golang.org/protobuf/encoding/prototext/decode.go +0 -773
  241. data/vendor/google.golang.org/protobuf/encoding/prototext/doc.go +0 -7
  242. data/vendor/google.golang.org/protobuf/encoding/prototext/encode.go +0 -371
  243. data/vendor/google.golang.org/protobuf/encoding/protowire/wire.go +0 -538
  244. data/vendor/google.golang.org/protobuf/internal/descfmt/stringer.go +0 -318
  245. data/vendor/google.golang.org/protobuf/internal/descopts/options.go +0 -29
  246. data/vendor/google.golang.org/protobuf/internal/detrand/rand.go +0 -69
  247. data/vendor/google.golang.org/protobuf/internal/encoding/defval/default.go +0 -213
  248. data/vendor/google.golang.org/protobuf/internal/encoding/messageset/messageset.go +0 -241
  249. data/vendor/google.golang.org/protobuf/internal/encoding/tag/tag.go +0 -207
  250. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode.go +0 -665
  251. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_number.go +0 -190
  252. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_string.go +0 -161
  253. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_token.go +0 -373
  254. data/vendor/google.golang.org/protobuf/internal/encoding/text/doc.go +0 -29
  255. data/vendor/google.golang.org/protobuf/internal/encoding/text/encode.go +0 -265
  256. data/vendor/google.golang.org/protobuf/internal/errors/errors.go +0 -89
  257. data/vendor/google.golang.org/protobuf/internal/errors/is_go112.go +0 -39
  258. data/vendor/google.golang.org/protobuf/internal/errors/is_go113.go +0 -12
  259. data/vendor/google.golang.org/protobuf/internal/filedesc/build.go +0 -158
  260. data/vendor/google.golang.org/protobuf/internal/filedesc/desc.go +0 -631
  261. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_init.go +0 -471
  262. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_lazy.go +0 -704
  263. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list.go +0 -450
  264. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list_gen.go +0 -356
  265. data/vendor/google.golang.org/protobuf/internal/filedesc/placeholder.go +0 -107
  266. data/vendor/google.golang.org/protobuf/internal/filetype/build.go +0 -297
  267. data/vendor/google.golang.org/protobuf/internal/flags/flags.go +0 -24
  268. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_disable.go +0 -9
  269. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_enable.go +0 -9
  270. data/vendor/google.golang.org/protobuf/internal/genid/any_gen.go +0 -34
  271. data/vendor/google.golang.org/protobuf/internal/genid/api_gen.go +0 -106
  272. data/vendor/google.golang.org/protobuf/internal/genid/descriptor_gen.go +0 -829
  273. data/vendor/google.golang.org/protobuf/internal/genid/doc.go +0 -11
  274. data/vendor/google.golang.org/protobuf/internal/genid/duration_gen.go +0 -34
  275. data/vendor/google.golang.org/protobuf/internal/genid/empty_gen.go +0 -19
  276. data/vendor/google.golang.org/protobuf/internal/genid/field_mask_gen.go +0 -31
  277. data/vendor/google.golang.org/protobuf/internal/genid/goname.go +0 -25
  278. data/vendor/google.golang.org/protobuf/internal/genid/map_entry.go +0 -16
  279. data/vendor/google.golang.org/protobuf/internal/genid/source_context_gen.go +0 -31
  280. data/vendor/google.golang.org/protobuf/internal/genid/struct_gen.go +0 -116
  281. data/vendor/google.golang.org/protobuf/internal/genid/timestamp_gen.go +0 -34
  282. data/vendor/google.golang.org/protobuf/internal/genid/type_gen.go +0 -184
  283. data/vendor/google.golang.org/protobuf/internal/genid/wrappers.go +0 -13
  284. data/vendor/google.golang.org/protobuf/internal/genid/wrappers_gen.go +0 -175
  285. data/vendor/google.golang.org/protobuf/internal/impl/api_export.go +0 -177
  286. data/vendor/google.golang.org/protobuf/internal/impl/checkinit.go +0 -141
  287. data/vendor/google.golang.org/protobuf/internal/impl/codec_extension.go +0 -223
  288. data/vendor/google.golang.org/protobuf/internal/impl/codec_field.go +0 -830
  289. data/vendor/google.golang.org/protobuf/internal/impl/codec_gen.go +0 -5637
  290. data/vendor/google.golang.org/protobuf/internal/impl/codec_map.go +0 -388
  291. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go111.go +0 -37
  292. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go112.go +0 -11
  293. data/vendor/google.golang.org/protobuf/internal/impl/codec_message.go +0 -217
  294. data/vendor/google.golang.org/protobuf/internal/impl/codec_messageset.go +0 -123
  295. data/vendor/google.golang.org/protobuf/internal/impl/codec_reflect.go +0 -209
  296. data/vendor/google.golang.org/protobuf/internal/impl/codec_tables.go +0 -557
  297. data/vendor/google.golang.org/protobuf/internal/impl/codec_unsafe.go +0 -17
  298. data/vendor/google.golang.org/protobuf/internal/impl/convert.go +0 -496
  299. data/vendor/google.golang.org/protobuf/internal/impl/convert_list.go +0 -141
  300. data/vendor/google.golang.org/protobuf/internal/impl/convert_map.go +0 -121
  301. data/vendor/google.golang.org/protobuf/internal/impl/decode.go +0 -276
  302. data/vendor/google.golang.org/protobuf/internal/impl/encode.go +0 -201
  303. data/vendor/google.golang.org/protobuf/internal/impl/enum.go +0 -21
  304. data/vendor/google.golang.org/protobuf/internal/impl/extension.go +0 -156
  305. data/vendor/google.golang.org/protobuf/internal/impl/legacy_enum.go +0 -219
  306. data/vendor/google.golang.org/protobuf/internal/impl/legacy_export.go +0 -92
  307. data/vendor/google.golang.org/protobuf/internal/impl/legacy_extension.go +0 -176
  308. data/vendor/google.golang.org/protobuf/internal/impl/legacy_file.go +0 -81
  309. data/vendor/google.golang.org/protobuf/internal/impl/legacy_message.go +0 -558
  310. data/vendor/google.golang.org/protobuf/internal/impl/merge.go +0 -176
  311. data/vendor/google.golang.org/protobuf/internal/impl/merge_gen.go +0 -209
  312. data/vendor/google.golang.org/protobuf/internal/impl/message.go +0 -276
  313. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect.go +0 -465
  314. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_field.go +0 -543
  315. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_gen.go +0 -249
  316. data/vendor/google.golang.org/protobuf/internal/impl/pointer_reflect.go +0 -178
  317. data/vendor/google.golang.org/protobuf/internal/impl/pointer_unsafe.go +0 -174
  318. data/vendor/google.golang.org/protobuf/internal/impl/validate.go +0 -576
  319. data/vendor/google.golang.org/protobuf/internal/impl/weak.go +0 -74
  320. data/vendor/google.golang.org/protobuf/internal/order/order.go +0 -89
  321. data/vendor/google.golang.org/protobuf/internal/order/range.go +0 -115
  322. data/vendor/google.golang.org/protobuf/internal/pragma/pragma.go +0 -29
  323. data/vendor/google.golang.org/protobuf/internal/set/ints.go +0 -58
  324. data/vendor/google.golang.org/protobuf/internal/strs/strings.go +0 -196
  325. data/vendor/google.golang.org/protobuf/internal/strs/strings_pure.go +0 -27
  326. data/vendor/google.golang.org/protobuf/internal/strs/strings_unsafe.go +0 -94
  327. data/vendor/google.golang.org/protobuf/internal/version/version.go +0 -79
  328. data/vendor/google.golang.org/protobuf/proto/checkinit.go +0 -71
  329. data/vendor/google.golang.org/protobuf/proto/decode.go +0 -278
  330. data/vendor/google.golang.org/protobuf/proto/decode_gen.go +0 -603
  331. data/vendor/google.golang.org/protobuf/proto/doc.go +0 -94
  332. data/vendor/google.golang.org/protobuf/proto/encode.go +0 -319
  333. data/vendor/google.golang.org/protobuf/proto/encode_gen.go +0 -97
  334. data/vendor/google.golang.org/protobuf/proto/equal.go +0 -167
  335. data/vendor/google.golang.org/protobuf/proto/extension.go +0 -92
  336. data/vendor/google.golang.org/protobuf/proto/merge.go +0 -139
  337. data/vendor/google.golang.org/protobuf/proto/messageset.go +0 -93
  338. data/vendor/google.golang.org/protobuf/proto/proto.go +0 -43
  339. data/vendor/google.golang.org/protobuf/proto/proto_methods.go +0 -19
  340. data/vendor/google.golang.org/protobuf/proto/proto_reflect.go +0 -19
  341. data/vendor/google.golang.org/protobuf/proto/reset.go +0 -43
  342. data/vendor/google.golang.org/protobuf/proto/size.go +0 -97
  343. data/vendor/google.golang.org/protobuf/proto/size_gen.go +0 -55
  344. data/vendor/google.golang.org/protobuf/proto/wrappers.go +0 -29
  345. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc.go +0 -276
  346. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_init.go +0 -248
  347. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_resolve.go +0 -286
  348. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_validate.go +0 -374
  349. data/vendor/google.golang.org/protobuf/reflect/protodesc/proto.go +0 -252
  350. data/vendor/google.golang.org/protobuf/reflect/protoreflect/methods.go +0 -77
  351. data/vendor/google.golang.org/protobuf/reflect/protoreflect/proto.go +0 -504
  352. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source.go +0 -128
  353. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source_gen.go +0 -461
  354. data/vendor/google.golang.org/protobuf/reflect/protoreflect/type.go +0 -665
  355. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value.go +0 -285
  356. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_pure.go +0 -59
  357. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_union.go +0 -411
  358. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_unsafe.go +0 -98
  359. data/vendor/google.golang.org/protobuf/reflect/protoregistry/registry.go +0 -869
  360. data/vendor/google.golang.org/protobuf/runtime/protoiface/legacy.go +0 -15
  361. data/vendor/google.golang.org/protobuf/runtime/protoiface/methods.go +0 -167
  362. data/vendor/google.golang.org/protobuf/runtime/protoimpl/impl.go +0 -44
  363. data/vendor/google.golang.org/protobuf/runtime/protoimpl/version.go +0 -56
  364. data/vendor/google.golang.org/protobuf/types/descriptorpb/descriptor.pb.go +0 -4039
  365. data/vendor/modules.txt +0 -79
@@ -1,467 +0,0 @@
1
- package proxy
2
-
3
- import (
4
- "context"
5
- "crypto/tls"
6
- "crypto/x509"
7
- "errors"
8
- "fmt"
9
- "io"
10
- "net"
11
- "os"
12
- "strings"
13
- "sync/atomic"
14
- "time"
15
-
16
- "go.uber.org/zap"
17
- )
18
-
19
- const (
20
- keepAlivePeriod = time.Minute
21
- )
22
-
23
- // Cert represents the client certificate key pair in the root certiciate
24
- // authority that the client uses to verify server certificates.
25
-
26
- type Cert struct {
27
- ClientCert tls.Certificate
28
- CACert *x509.Certificate
29
- RemoteAddr string
30
- Ports RemotePorts
31
- }
32
-
33
- type RemotePorts struct {
34
- Proxy int
35
- MySQL int
36
- }
37
-
38
- // CertSource is used
39
- type CertSource interface {
40
- // Cert returns the required certs needed to establish a TLS connection
41
- // from the client to the server.
42
- Cert(ctx context.Context, org, db, branch string) (*Cert, error)
43
- }
44
-
45
- // Client is responsible for listening to unsecured connections over a TCP
46
- // localhost port and tunneling them securely over a TLS connection to a remote
47
- // database instance defined by its PlanetScale unique branch identifier.
48
- type Client struct {
49
- // connectionsCounter is used to enforce the optional maxConnections limit
50
- // NOTE: don't move this field, as we need to make sure the fields are
51
- // 64-bit aligned
52
- connectionsCounter uint64
53
-
54
- remoteAddr string
55
- localAddr string
56
- instance string
57
- maxConnections uint64
58
- certSource CertSource
59
-
60
- log *zap.Logger
61
-
62
- // configCache contains the TLS certificate chache for each indiviual
63
- // database
64
- configCache *tlsCache
65
-
66
- listener net.Listener
67
- // done is closed after a successfull net.Listen bind.
68
- done chan struct{}
69
- }
70
-
71
- // Options are the options for creating a new Client.
72
- type Options struct {
73
- // RemoteAddr defines the server address to tunnel local connections. By
74
- // default we connect to the remote address given by the CertSource. This
75
- // option can be used to over write it.
76
- RemoteAddr string
77
-
78
- // LocalAddr defines the address to listen for new connection
79
- LocalAddr string
80
-
81
- // Instance defines the remote DB instance to proxy new connection
82
- Instance string
83
-
84
- // MaxConnections is the maximum number of connections to establish
85
- // before refusing new connections. 0 means no limit.
86
- MaxConnections uint64
87
-
88
- // CertSource defines the certificate source to obtain the required TLS
89
- // certificates for the client and the remote address of the server to
90
- // connect.
91
- CertSource CertSource
92
-
93
- // Logger defines which zap.Logger to use. Use it to override the default
94
- // Development logger . Useful for tests.
95
- Logger *zap.Logger
96
- }
97
-
98
- // NewClient creates a new proxy client instance
99
- func NewClient(opts Options) (*Client, error) {
100
- c := &Client{
101
- certSource: opts.CertSource,
102
- localAddr: opts.LocalAddr,
103
- remoteAddr: opts.RemoteAddr,
104
- instance: opts.Instance,
105
- configCache: newtlsCache(),
106
- done: make(chan struct{}),
107
- }
108
-
109
- if opts.Logger != nil {
110
- c.log = opts.Logger
111
- } else {
112
- logger, err := zap.NewDevelopment(
113
- zap.Fields(zap.String("app", "sql-proxy-client")),
114
- )
115
- if err != nil {
116
- return nil, err
117
- }
118
- zap.ReplaceGlobals(logger)
119
- c.log = logger
120
- }
121
-
122
- // cache the certs for the given instance(s)
123
- _, _, err := c.clientCerts(context.Background(), opts.Instance)
124
- if err != nil {
125
- c.log.Error("couldn't retrieve TLS certificate for the client", zap.Error(err))
126
- }
127
-
128
- return c, nil
129
- }
130
-
131
- // Conn represents a connection from a client to a specific instance.
132
- type Conn struct {
133
- Instance string
134
- Conn net.Conn
135
- }
136
-
137
- // Run runs the proxy. It listens to the configured localhost address and
138
- // proxies the connection over a TLS tunnel to the remote DB instance.
139
- func (c *Client) Run(ctx context.Context) error {
140
- c.log.Info("ready for new connections")
141
- l, err := c.getListener()
142
- if err != nil {
143
- return fmt.Errorf("error net.Listen: %w", err)
144
- }
145
- defer c.log.Sync() // nolint: errcheck
146
-
147
- c.listener = l
148
- close(c.done)
149
-
150
- return c.run(ctx, l)
151
- }
152
-
153
- // LocalAddr returns the address of the local listener. This is by default
154
- // blocking and will only return if the proxy is invoked with the Run() method.
155
- func (c *Client) LocalAddr() (net.Addr, error) {
156
- <-c.done
157
-
158
- if c.listener == nil {
159
- return nil, errors.New("listener is not set")
160
-
161
- }
162
- return c.listener.Addr(), nil
163
- }
164
-
165
- func (c *Client) getListener() (net.Listener, error) {
166
- if strings.HasPrefix(c.localAddr, "unix://") {
167
- p := strings.TrimPrefix(c.localAddr, "unix://")
168
- if err := os.Remove(p); err != nil && !os.IsNotExist(err) {
169
- return nil, fmt.Errorf("failed to remove unix domain socket file %s, error: %s", p, err)
170
- }
171
- return net.Listen("unix", p)
172
- }
173
- return net.Listen("tcp", c.localAddr)
174
- }
175
-
176
- // run is an internal function for testing the Client proxy event loop for
177
- // handling TCP connections
178
- func (c *Client) run(ctx context.Context, l net.Listener) error {
179
- connSrc := make(chan Conn, 1)
180
- go func() {
181
- if err := c.listen(l, connSrc); err != nil {
182
- c.log.Error("listen to local address", zap.Error(err))
183
- }
184
- }()
185
-
186
- for {
187
- select {
188
- case <-ctx.Done():
189
- termTimeout := time.Second * 1
190
- c.log.Info("received context cancellation, waiting until timeout",
191
- zap.Duration("timeout", termTimeout))
192
-
193
- err := c.Shutdown(termTimeout)
194
- if err != nil {
195
- return fmt.Errorf("error during shutdown: %v", err)
196
- }
197
- return nil
198
- case conn := <-connSrc:
199
- go func(lc Conn) {
200
- // TODO(fatih): detach context from parent
201
- err := c.handleConn(ctx, lc.Conn, lc.Instance)
202
- if err != nil {
203
- c.log.Error("error proxying conns", zap.Error(err))
204
- }
205
- }(conn)
206
- }
207
- }
208
- }
209
-
210
- // listen listens to the client's localAddres and sends each incoming
211
- // connections to the given connSrc channel.
212
- func (c *Client) listen(l net.Listener, connSrc chan<- Conn) error {
213
- c.log.Info("listening remote DB instance",
214
- zap.String("local_addr", c.localAddr),
215
- zap.String("instance", c.instance),
216
- )
217
-
218
- for {
219
- start := time.Now()
220
- conn, err := l.Accept()
221
- if err != nil {
222
- if nerr, ok := err.(net.Error); ok && nerr.Temporary() {
223
- d := 10*time.Millisecond - time.Since(start)
224
- if d > 0 {
225
- time.Sleep(d)
226
- }
227
- continue
228
- }
229
- l.Close()
230
-
231
- return fmt.Errorf("error in accept for on %v: %w", c.localAddr, err)
232
- }
233
-
234
- c.log.Info("new connection", zap.String("conn_addr", l.Addr().String()))
235
-
236
- switch clientConn := conn.(type) {
237
- case *net.TCPConn:
238
- clientConn.SetKeepAlive(true) //nolint: errcheck
239
- clientConn.SetKeepAlivePeriod(1 * time.Minute) //nolint: errcheck
240
- }
241
-
242
- connSrc <- Conn{
243
- Conn: conn,
244
- Instance: c.instance,
245
- }
246
- }
247
- }
248
-
249
- func (c *Client) handleConn(ctx context.Context, conn net.Conn, instance string) error {
250
- log := c.log.With(zap.String("instance", instance))
251
- active := atomic.AddUint64(&c.connectionsCounter, 1)
252
-
253
- // Deferred decrement of ConnectionsCounter upon connection closing
254
- defer atomic.AddUint64(&c.connectionsCounter, ^uint64(0))
255
-
256
- if c.maxConnections > 0 && active > c.maxConnections {
257
- conn.Close()
258
- return fmt.Errorf("too many open connections (max %d)", c.maxConnections)
259
- }
260
-
261
- cfg, remoteAddr, err := c.clientCerts(ctx, instance)
262
- if err != nil {
263
- return fmt.Errorf("couldn't retrieve certs for instance: %q: %w", instance, err)
264
- }
265
-
266
- // TODO(fatih): implement refreshing certs
267
- // go p.refreshCertAfter(instance, timeToRefresh)
268
-
269
- // overwrite the remote address if the user explicitly set it
270
- if c.remoteAddr != "" {
271
- remoteAddr = c.remoteAddr
272
- }
273
-
274
- c.log.Info("connecting to remote server", zap.String("remote_addr", remoteAddr))
275
-
276
- var d net.Dialer
277
- remoteConn, err := d.DialContext(ctx, "tcp", remoteAddr)
278
- if err != nil {
279
- conn.Close()
280
- return fmt.Errorf("couldn't connect to %q: %v", remoteAddr, err)
281
- }
282
-
283
- type setKeepAliver interface {
284
- SetKeepAlive(keepalive bool) error
285
- SetKeepAlivePeriod(d time.Duration) error
286
- }
287
-
288
- if s, ok := conn.(setKeepAliver); ok {
289
- if err := s.SetKeepAlive(true); err != nil {
290
- log.Error("couldn't set KeepAlive to true", zap.Error(err))
291
- } else if err := s.SetKeepAlivePeriod(keepAlivePeriod); err != nil {
292
- log.Error("couldn't set KeepAlivePeriod", zap.Error(err), zap.Duration("keep_alive_period", keepAlivePeriod))
293
- }
294
- } else {
295
- log.Warn("KeepAlive not supported: long-running tcp connections may be killed by the OS.")
296
- }
297
-
298
- secureConn := tls.Client(remoteConn, cfg)
299
- if err := secureConn.Handshake(); err != nil {
300
- secureConn.Close()
301
- return fmt.Errorf("couldn't initiate TLS handshake to remote addr: %s", err)
302
- }
303
-
304
- // Hasta la vista, baby
305
- copyThenClose(
306
- secureConn,
307
- conn,
308
- "remote connection",
309
- "local connection on "+conn.LocalAddr().String(),
310
- )
311
- return nil
312
- }
313
-
314
- // clientCerts returns the TLS configuration needed for the TLS handshake and
315
- // connection
316
- func (c *Client) clientCerts(ctx context.Context, instance string) (*tls.Config, string, error) {
317
- cacheEntry, err := c.configCache.Get(instance)
318
- if err == nil {
319
- c.log.Info("using tls.Config from the cache", zap.String("instance", instance))
320
- return cacheEntry.cfg, cacheEntry.remoteAddr, nil
321
- }
322
-
323
- if err != errConfigNotFound {
324
- return nil, "", err // we don't handle non errConfigNotFound errors
325
- }
326
-
327
- s := strings.Split(instance, "/")
328
- if len(s) != 3 {
329
- return nil, "", fmt.Errorf("instance format is malformed, should be in form organization/dbname/branch, have: %q", instance)
330
- }
331
-
332
- cert, err := c.certSource.Cert(ctx, s[0], s[1], s[2])
333
- if err != nil {
334
- return nil, "", fmt.Errorf("couldn't retrieve certs from cert source: %s", err)
335
- }
336
-
337
- rootCertPool := x509.NewCertPool()
338
- rootCertPool.AddCert(cert.CACert)
339
-
340
- serverName := fmt.Sprintf("%s.%s.%s.%s", s[2], s[1], s[0], cert.RemoteAddr)
341
- fullAddr := fmt.Sprintf("%s:%d", serverName, cert.Ports.Proxy)
342
-
343
- cfg := &tls.Config{
344
- ServerName: serverName,
345
- Certificates: []tls.Certificate{cert.ClientCert},
346
- RootCAs: rootCertPool,
347
- // Set InsecureSkipVerify to skip the default validation we are
348
- // replacing. This will not disable VerifyConnection.
349
- InsecureSkipVerify: true,
350
- VerifyConnection: func(cs tls.ConnectionState) error {
351
- // For now, only verify the server's certificate chain.
352
- // We don't know yet what the server's FQDN will be.
353
- //
354
- // serverName := cs.ServerName
355
- // commonName := cs.PeerCertificates[0].Subject.CommonName
356
- // if commonName != serverName {
357
- // return fmt.Errorf("invalid certificate name %q, expected %q", commonName, serverName)
358
- // }
359
- opts := x509.VerifyOptions{
360
- Roots: rootCertPool,
361
- Intermediates: x509.NewCertPool(),
362
- }
363
- for _, cert := range cs.PeerCertificates[1:] {
364
- opts.Intermediates.AddCert(cert)
365
- }
366
- _, err := cs.PeerCertificates[0].Verify(opts)
367
- return err
368
- },
369
- }
370
-
371
- c.log.Info("adding tls.Config to the cache", zap.String("instance", instance))
372
- c.configCache.Add(instance, cfg, fullAddr)
373
- return cfg, fullAddr, nil
374
- }
375
-
376
- // Shutdown waits up to a given amount of time for all active connections to
377
- // close. Returns an error if there are still active connections after waiting
378
- // for the whole length of the timeout.
379
- func (c *Client) Shutdown(timeout time.Duration) error {
380
- term, ticker := time.After(timeout), time.NewTicker(100*time.Millisecond)
381
- defer ticker.Stop()
382
-
383
- for {
384
- select {
385
- case <-ticker.C:
386
- if atomic.LoadUint64(&c.connectionsCounter) > 0 {
387
- continue
388
- }
389
- c.log.Info("no connections to wait, bailing out")
390
- case <-term:
391
- }
392
- break
393
- }
394
-
395
- active := atomic.LoadUint64(&c.connectionsCounter)
396
- if active == 0 {
397
- return nil
398
- }
399
- return fmt.Errorf("%d active connections still exist after waiting for %v", active, timeout)
400
- }
401
-
402
- func copyThenClose(remote, local io.ReadWriteCloser, remoteDesc, localDesc string) {
403
- firstErr := make(chan error, 1)
404
-
405
- go func() {
406
- readErr, err := myCopy(remote, local)
407
- select {
408
- case firstErr <- err:
409
- if readErr && err == io.EOF {
410
- zap.L().Info("client closed connection",
411
- zap.String("local_desc", localDesc))
412
- } else {
413
- logError(localDesc, remoteDesc, readErr, err)
414
- }
415
- remote.Close()
416
- local.Close()
417
- default:
418
- }
419
- }()
420
-
421
- readErr, err := myCopy(local, remote)
422
- select {
423
- case firstErr <- err:
424
- if readErr && err == io.EOF {
425
- zap.L().Info("instance closed connection",
426
- zap.String("remote_desc", remoteDesc))
427
- } else {
428
- logError(remoteDesc, localDesc, readErr, err)
429
- }
430
- remote.Close()
431
- local.Close()
432
- default:
433
- // In this case, the other goroutine exited first and already printed its
434
- // error (and closed the things).
435
- }
436
- }
437
-
438
- func logError(readDesc, writeDesc string, readErr bool, err error) {
439
- var desc string
440
- if readErr {
441
- desc = "reading data from " + readDesc
442
- } else {
443
- desc = "writing data to " + writeDesc
444
- }
445
- zap.L().Error("copy error", zap.String("desc", desc), zap.Error(err))
446
- }
447
-
448
- // myCopy is similar to io.Copy, but reports whether the returned error was due
449
- // to a bad read or write. The returned error will never be nil
450
- func myCopy(dst io.Writer, src io.Reader) (readErr bool, err error) {
451
- buf := make([]byte, 4096)
452
- for {
453
- n, err := src.Read(buf)
454
- if n > 0 {
455
- if _, werr := dst.Write(buf[:n]); werr != nil {
456
- if err == nil {
457
- return false, werr
458
- }
459
- // Read and write error; just report read error (it happened first).
460
- return true, err
461
- }
462
- }
463
- if err != nil {
464
- return true, err
465
- }
466
- }
467
- }
@@ -1,73 +0,0 @@
1
- package proxy
2
-
3
- import (
4
- "crypto/tls"
5
- "errors"
6
- "sync"
7
- "time"
8
- )
9
-
10
- var errConfigNotFound = errors.New("TLS config not found")
11
-
12
- // expireTTL defines the time
13
- const expireTTL = 10 * time.Minute
14
-
15
- type cacheEntry struct {
16
- // cfg defines the TLS config we're caching
17
- cfg *tls.Config
18
- remoteAddr string
19
-
20
- // added holds the time the cfg was added to the cache
21
- added time.Time
22
- }
23
-
24
- type tlsCache struct {
25
- // configs holds the TLS config for each remote instance
26
- configs map[string]cacheEntry
27
- configsMu sync.Mutex // protects configs
28
-
29
- // nowFn returns the current local time, used during insertion of cache
30
- // entries. It's a function so we can use it for tests.
31
- nowFn func() time.Time
32
- }
33
-
34
- func newtlsCache() *tlsCache {
35
- return &tlsCache{
36
- configs: make(map[string]cacheEntry),
37
- nowFn: time.Now,
38
- }
39
- }
40
-
41
- // Add adds the given config and remote address for the given instance name
42
- func (t *tlsCache) Add(instance string, cfg *tls.Config, remoteAddr string) {
43
- t.configsMu.Lock()
44
- defer t.configsMu.Unlock()
45
-
46
- t.configs[instance] = cacheEntry{
47
- cfg: cfg,
48
- remoteAddr: remoteAddr,
49
- added: t.nowFn(),
50
- }
51
- }
52
-
53
- // Get retrieves the config for the given instance
54
- func (t *tlsCache) Get(instance string) (cacheEntry, error) {
55
- t.configsMu.Lock()
56
- defer t.configsMu.Unlock()
57
-
58
- e, ok := t.configs[instance]
59
- if !ok {
60
- return cacheEntry{}, errConfigNotFound
61
- }
62
-
63
- now := time.Now()
64
-
65
- // delete the config if it's expired. This will trigger the user to request
66
- // another TLS config.
67
- if e.added.Add(expireTTL).Before(now) {
68
- delete(t.configs, instance)
69
- return cacheEntry{}, errConfigNotFound
70
- }
71
-
72
- return e, nil
73
- }
@@ -1,19 +0,0 @@
1
- coverage:
2
- range: 80..100
3
- round: down
4
- precision: 2
5
-
6
- status:
7
- project: # measuring the overall project coverage
8
- default: # context, you can create multiple ones with custom titles
9
- enabled: yes # must be yes|true to enable this status
10
- target: 100 # specify the target coverage for each commit status
11
- # option: "auto" (must increase from parent commit or pull request base)
12
- # option: "X%" a static target percentage to hit
13
- if_not_found: success # if parent is not found report status as success, error, or failure
14
- if_ci_failed: error # if ci fails report status as success, error, or failure
15
-
16
- # Also update COVER_IGNORE_PKGS in the Makefile.
17
- ignore:
18
- - /internal/gen-atomicint/
19
- - /internal/gen-valuewrapper/
@@ -1,12 +0,0 @@
1
- /bin
2
- .DS_Store
3
- /vendor
4
- cover.html
5
- cover.out
6
- lint.log
7
-
8
- # Binaries
9
- *.test
10
-
11
- # Profiling output
12
- *.prof
@@ -1,27 +0,0 @@
1
- sudo: false
2
- language: go
3
- go_import_path: go.uber.org/atomic
4
-
5
- env:
6
- global:
7
- - GO111MODULE=on
8
-
9
- matrix:
10
- include:
11
- - go: oldstable
12
- - go: stable
13
- env: LINT=1
14
-
15
- cache:
16
- directories:
17
- - vendor
18
-
19
- before_install:
20
- - go version
21
-
22
- script:
23
- - test -z "$LINT" || make lint
24
- - make cover
25
-
26
- after_success:
27
- - bash <(curl -s https://codecov.io/bash)
@@ -1,76 +0,0 @@
1
- # Changelog
2
- All notable changes to this project will be documented in this file.
3
-
4
- The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
5
- and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
6
-
7
- ## [1.7.0] - 2020-09-14
8
- ### Added
9
- - Support JSON serialization and deserialization of primitive atomic types.
10
- - Support Text marshalling and unmarshalling for string atomics.
11
-
12
- ### Changed
13
- - Disallow incorrect comparison of atomic values in a non-atomic way.
14
-
15
- ### Removed
16
- - Remove dependency on `golang.org/x/{lint, tools}`.
17
-
18
- ## [1.6.0] - 2020-02-24
19
- ### Changed
20
- - Drop library dependency on `golang.org/x/{lint, tools}`.
21
-
22
- ## [1.5.1] - 2019-11-19
23
- - Fix bug where `Bool.CAS` and `Bool.Toggle` do work correctly together
24
- causing `CAS` to fail even though the old value matches.
25
-
26
- ## [1.5.0] - 2019-10-29
27
- ### Changed
28
- - With Go modules, only the `go.uber.org/atomic` import path is supported now.
29
- If you need to use the old import path, please add a `replace` directive to
30
- your `go.mod`.
31
-
32
- ## [1.4.0] - 2019-05-01
33
- ### Added
34
- - Add `atomic.Error` type for atomic operations on `error` values.
35
-
36
- ## [1.3.2] - 2018-05-02
37
- ### Added
38
- - Add `atomic.Duration` type for atomic operations on `time.Duration` values.
39
-
40
- ## [1.3.1] - 2017-11-14
41
- ### Fixed
42
- - Revert optimization for `atomic.String.Store("")` which caused data races.
43
-
44
- ## [1.3.0] - 2017-11-13
45
- ### Added
46
- - Add `atomic.Bool.CAS` for compare-and-swap semantics on bools.
47
-
48
- ### Changed
49
- - Optimize `atomic.String.Store("")` by avoiding an allocation.
50
-
51
- ## [1.2.0] - 2017-04-12
52
- ### Added
53
- - Shadow `atomic.Value` from `sync/atomic`.
54
-
55
- ## [1.1.0] - 2017-03-10
56
- ### Added
57
- - Add atomic `Float64` type.
58
-
59
- ### Changed
60
- - Support new `go.uber.org/atomic` import path.
61
-
62
- ## [1.0.0] - 2016-07-18
63
-
64
- - Initial release.
65
-
66
- [1.7.0]: https://github.com/uber-go/atomic/compare/v1.6.0...v1.7.0
67
- [1.6.0]: https://github.com/uber-go/atomic/compare/v1.5.1...v1.6.0
68
- [1.5.1]: https://github.com/uber-go/atomic/compare/v1.5.0...v1.5.1
69
- [1.5.0]: https://github.com/uber-go/atomic/compare/v1.4.0...v1.5.0
70
- [1.4.0]: https://github.com/uber-go/atomic/compare/v1.3.2...v1.4.0
71
- [1.3.2]: https://github.com/uber-go/atomic/compare/v1.3.1...v1.3.2
72
- [1.3.1]: https://github.com/uber-go/atomic/compare/v1.3.0...v1.3.1
73
- [1.3.0]: https://github.com/uber-go/atomic/compare/v1.2.0...v1.3.0
74
- [1.2.0]: https://github.com/uber-go/atomic/compare/v1.1.0...v1.2.0
75
- [1.1.0]: https://github.com/uber-go/atomic/compare/v1.0.0...v1.1.0
76
- [1.0.0]: https://github.com/uber-go/atomic/releases/tag/v1.0.0
@@ -1,19 +0,0 @@
1
- Copyright (c) 2016 Uber Technologies, Inc.
2
-
3
- Permission is hereby granted, free of charge, to any person obtaining a copy
4
- of this software and associated documentation files (the "Software"), to deal
5
- in the Software without restriction, including without limitation the rights
6
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7
- copies of the Software, and to permit persons to whom the Software is
8
- furnished to do so, subject to the following conditions:
9
-
10
- The above copyright notice and this permission notice shall be included in
11
- all copies or substantial portions of the Software.
12
-
13
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19
- THE SOFTWARE.