planetscale 0.2.0 → 0.3.3

Sign up to get free protection for your applications and to get access to all the features.
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.