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,264 +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.
20
-
21
- package zapcore
22
-
23
- import (
24
- "fmt"
25
- "runtime"
26
- "strings"
27
- "sync"
28
- "time"
29
-
30
- "go.uber.org/zap/internal/bufferpool"
31
- "go.uber.org/zap/internal/exit"
32
-
33
- "go.uber.org/multierr"
34
- )
35
-
36
- var (
37
- _cePool = sync.Pool{New: func() interface{} {
38
- // Pre-allocate some space for cores.
39
- return &CheckedEntry{
40
- cores: make([]Core, 4),
41
- }
42
- }}
43
- )
44
-
45
- func getCheckedEntry() *CheckedEntry {
46
- ce := _cePool.Get().(*CheckedEntry)
47
- ce.reset()
48
- return ce
49
- }
50
-
51
- func putCheckedEntry(ce *CheckedEntry) {
52
- if ce == nil {
53
- return
54
- }
55
- _cePool.Put(ce)
56
- }
57
-
58
- // NewEntryCaller makes an EntryCaller from the return signature of
59
- // runtime.Caller.
60
- func NewEntryCaller(pc uintptr, file string, line int, ok bool) EntryCaller {
61
- if !ok {
62
- return EntryCaller{}
63
- }
64
- return EntryCaller{
65
- PC: pc,
66
- File: file,
67
- Line: line,
68
- Defined: true,
69
- }
70
- }
71
-
72
- // EntryCaller represents the caller of a logging function.
73
- type EntryCaller struct {
74
- Defined bool
75
- PC uintptr
76
- File string
77
- Line int
78
- Function string
79
- }
80
-
81
- // String returns the full path and line number of the caller.
82
- func (ec EntryCaller) String() string {
83
- return ec.FullPath()
84
- }
85
-
86
- // FullPath returns a /full/path/to/package/file:line description of the
87
- // caller.
88
- func (ec EntryCaller) FullPath() string {
89
- if !ec.Defined {
90
- return "undefined"
91
- }
92
- buf := bufferpool.Get()
93
- buf.AppendString(ec.File)
94
- buf.AppendByte(':')
95
- buf.AppendInt(int64(ec.Line))
96
- caller := buf.String()
97
- buf.Free()
98
- return caller
99
- }
100
-
101
- // TrimmedPath returns a package/file:line description of the caller,
102
- // preserving only the leaf directory name and file name.
103
- func (ec EntryCaller) TrimmedPath() string {
104
- if !ec.Defined {
105
- return "undefined"
106
- }
107
- // nb. To make sure we trim the path correctly on Windows too, we
108
- // counter-intuitively need to use '/' and *not* os.PathSeparator here,
109
- // because the path given originates from Go stdlib, specifically
110
- // runtime.Caller() which (as of Mar/17) returns forward slashes even on
111
- // Windows.
112
- //
113
- // See https://github.com/golang/go/issues/3335
114
- // and https://github.com/golang/go/issues/18151
115
- //
116
- // for discussion on the issue on Go side.
117
- //
118
- // Find the last separator.
119
- //
120
- idx := strings.LastIndexByte(ec.File, '/')
121
- if idx == -1 {
122
- return ec.FullPath()
123
- }
124
- // Find the penultimate separator.
125
- idx = strings.LastIndexByte(ec.File[:idx], '/')
126
- if idx == -1 {
127
- return ec.FullPath()
128
- }
129
- buf := bufferpool.Get()
130
- // Keep everything after the penultimate separator.
131
- buf.AppendString(ec.File[idx+1:])
132
- buf.AppendByte(':')
133
- buf.AppendInt(int64(ec.Line))
134
- caller := buf.String()
135
- buf.Free()
136
- return caller
137
- }
138
-
139
- // An Entry represents a complete log message. The entry's structured context
140
- // is already serialized, but the log level, time, message, and call site
141
- // information are available for inspection and modification. Any fields left
142
- // empty will be omitted when encoding.
143
- //
144
- // Entries are pooled, so any functions that accept them MUST be careful not to
145
- // retain references to them.
146
- type Entry struct {
147
- Level Level
148
- Time time.Time
149
- LoggerName string
150
- Message string
151
- Caller EntryCaller
152
- Stack string
153
- }
154
-
155
- // CheckWriteAction indicates what action to take after a log entry is
156
- // processed. Actions are ordered in increasing severity.
157
- type CheckWriteAction uint8
158
-
159
- const (
160
- // WriteThenNoop indicates that nothing special needs to be done. It's the
161
- // default behavior.
162
- WriteThenNoop CheckWriteAction = iota
163
- // WriteThenGoexit runs runtime.Goexit after Write.
164
- WriteThenGoexit
165
- // WriteThenPanic causes a panic after Write.
166
- WriteThenPanic
167
- // WriteThenFatal causes a fatal os.Exit after Write.
168
- WriteThenFatal
169
- )
170
-
171
- // CheckedEntry is an Entry together with a collection of Cores that have
172
- // already agreed to log it.
173
- //
174
- // CheckedEntry references should be created by calling AddCore or Should on a
175
- // nil *CheckedEntry. References are returned to a pool after Write, and MUST
176
- // NOT be retained after calling their Write method.
177
- type CheckedEntry struct {
178
- Entry
179
- ErrorOutput WriteSyncer
180
- dirty bool // best-effort detection of pool misuse
181
- should CheckWriteAction
182
- cores []Core
183
- }
184
-
185
- func (ce *CheckedEntry) reset() {
186
- ce.Entry = Entry{}
187
- ce.ErrorOutput = nil
188
- ce.dirty = false
189
- ce.should = WriteThenNoop
190
- for i := range ce.cores {
191
- // don't keep references to cores
192
- ce.cores[i] = nil
193
- }
194
- ce.cores = ce.cores[:0]
195
- }
196
-
197
- // Write writes the entry to the stored Cores, returns any errors, and returns
198
- // the CheckedEntry reference to a pool for immediate re-use. Finally, it
199
- // executes any required CheckWriteAction.
200
- func (ce *CheckedEntry) Write(fields ...Field) {
201
- if ce == nil {
202
- return
203
- }
204
-
205
- if ce.dirty {
206
- if ce.ErrorOutput != nil {
207
- // Make a best effort to detect unsafe re-use of this CheckedEntry.
208
- // If the entry is dirty, log an internal error; because the
209
- // CheckedEntry is being used after it was returned to the pool,
210
- // the message may be an amalgamation from multiple call sites.
211
- fmt.Fprintf(ce.ErrorOutput, "%v Unsafe CheckedEntry re-use near Entry %+v.\n", time.Now(), ce.Entry)
212
- ce.ErrorOutput.Sync()
213
- }
214
- return
215
- }
216
- ce.dirty = true
217
-
218
- var err error
219
- for i := range ce.cores {
220
- err = multierr.Append(err, ce.cores[i].Write(ce.Entry, fields))
221
- }
222
- if ce.ErrorOutput != nil {
223
- if err != nil {
224
- fmt.Fprintf(ce.ErrorOutput, "%v write error: %v\n", time.Now(), err)
225
- ce.ErrorOutput.Sync()
226
- }
227
- }
228
-
229
- should, msg := ce.should, ce.Message
230
- putCheckedEntry(ce)
231
-
232
- switch should {
233
- case WriteThenPanic:
234
- panic(msg)
235
- case WriteThenFatal:
236
- exit.Exit()
237
- case WriteThenGoexit:
238
- runtime.Goexit()
239
- }
240
- }
241
-
242
- // AddCore adds a Core that has agreed to log this CheckedEntry. It's intended to be
243
- // used by Core.Check implementations, and is safe to call on nil CheckedEntry
244
- // references.
245
- func (ce *CheckedEntry) AddCore(ent Entry, core Core) *CheckedEntry {
246
- if ce == nil {
247
- ce = getCheckedEntry()
248
- ce.Entry = ent
249
- }
250
- ce.cores = append(ce.cores, core)
251
- return ce
252
- }
253
-
254
- // Should sets this CheckedEntry's CheckWriteAction, which controls whether a
255
- // Core will panic or fatal after writing this log entry. Like AddCore, it's
256
- // safe to call on nil CheckedEntry references.
257
- func (ce *CheckedEntry) Should(ent Entry, should CheckWriteAction) *CheckedEntry {
258
- if ce == nil {
259
- ce = getCheckedEntry()
260
- ce.Entry = ent
261
- }
262
- ce.should = should
263
- return ce
264
- }
@@ -1,115 +0,0 @@
1
- // Copyright (c) 2017 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.
20
-
21
- package zapcore
22
-
23
- import (
24
- "fmt"
25
- "sync"
26
- )
27
-
28
- // Encodes the given error into fields of an object. A field with the given
29
- // name is added for the error message.
30
- //
31
- // If the error implements fmt.Formatter, a field with the name ${key}Verbose
32
- // is also added with the full verbose error message.
33
- //
34
- // Finally, if the error implements errorGroup (from go.uber.org/multierr) or
35
- // causer (from github.com/pkg/errors), a ${key}Causes field is added with an
36
- // array of objects containing the errors this error was comprised of.
37
- //
38
- // {
39
- // "error": err.Error(),
40
- // "errorVerbose": fmt.Sprintf("%+v", err),
41
- // "errorCauses": [
42
- // ...
43
- // ],
44
- // }
45
- func encodeError(key string, err error, enc ObjectEncoder) error {
46
- basic := err.Error()
47
- enc.AddString(key, basic)
48
-
49
- switch e := err.(type) {
50
- case errorGroup:
51
- return enc.AddArray(key+"Causes", errArray(e.Errors()))
52
- case fmt.Formatter:
53
- verbose := fmt.Sprintf("%+v", e)
54
- if verbose != basic {
55
- // This is a rich error type, like those produced by
56
- // github.com/pkg/errors.
57
- enc.AddString(key+"Verbose", verbose)
58
- }
59
- }
60
- return nil
61
- }
62
-
63
- type errorGroup interface {
64
- // Provides read-only access to the underlying list of errors, preferably
65
- // without causing any allocs.
66
- Errors() []error
67
- }
68
-
69
- // Note that errArry and errArrayElem are very similar to the version
70
- // implemented in the top-level error.go file. We can't re-use this because
71
- // that would require exporting errArray as part of the zapcore API.
72
-
73
- // Encodes a list of errors using the standard error encoding logic.
74
- type errArray []error
75
-
76
- func (errs errArray) MarshalLogArray(arr ArrayEncoder) error {
77
- for i := range errs {
78
- if errs[i] == nil {
79
- continue
80
- }
81
-
82
- el := newErrArrayElem(errs[i])
83
- arr.AppendObject(el)
84
- el.Free()
85
- }
86
- return nil
87
- }
88
-
89
- var _errArrayElemPool = sync.Pool{New: func() interface{} {
90
- return &errArrayElem{}
91
- }}
92
-
93
- // Encodes any error into a {"error": ...} re-using the same errors logic.
94
- //
95
- // May be passed in place of an array to build a single-element array.
96
- type errArrayElem struct{ err error }
97
-
98
- func newErrArrayElem(err error) *errArrayElem {
99
- e := _errArrayElemPool.Get().(*errArrayElem)
100
- e.err = err
101
- return e
102
- }
103
-
104
- func (e *errArrayElem) MarshalLogArray(arr ArrayEncoder) error {
105
- return arr.AppendObject(e)
106
- }
107
-
108
- func (e *errArrayElem) MarshalLogObject(enc ObjectEncoder) error {
109
- return encodeError("error", e.err, enc)
110
- }
111
-
112
- func (e *errArrayElem) Free() {
113
- e.err = nil
114
- _errArrayElemPool.Put(e)
115
- }
@@ -1,227 +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.
20
-
21
- package zapcore
22
-
23
- import (
24
- "bytes"
25
- "fmt"
26
- "math"
27
- "reflect"
28
- "time"
29
- )
30
-
31
- // A FieldType indicates which member of the Field union struct should be used
32
- // and how it should be serialized.
33
- type FieldType uint8
34
-
35
- const (
36
- // UnknownType is the default field type. Attempting to add it to an encoder will panic.
37
- UnknownType FieldType = iota
38
- // ArrayMarshalerType indicates that the field carries an ArrayMarshaler.
39
- ArrayMarshalerType
40
- // ObjectMarshalerType indicates that the field carries an ObjectMarshaler.
41
- ObjectMarshalerType
42
- // BinaryType indicates that the field carries an opaque binary blob.
43
- BinaryType
44
- // BoolType indicates that the field carries a bool.
45
- BoolType
46
- // ByteStringType indicates that the field carries UTF-8 encoded bytes.
47
- ByteStringType
48
- // Complex128Type indicates that the field carries a complex128.
49
- Complex128Type
50
- // Complex64Type indicates that the field carries a complex128.
51
- Complex64Type
52
- // DurationType indicates that the field carries a time.Duration.
53
- DurationType
54
- // Float64Type indicates that the field carries a float64.
55
- Float64Type
56
- // Float32Type indicates that the field carries a float32.
57
- Float32Type
58
- // Int64Type indicates that the field carries an int64.
59
- Int64Type
60
- // Int32Type indicates that the field carries an int32.
61
- Int32Type
62
- // Int16Type indicates that the field carries an int16.
63
- Int16Type
64
- // Int8Type indicates that the field carries an int8.
65
- Int8Type
66
- // StringType indicates that the field carries a string.
67
- StringType
68
- // TimeType indicates that the field carries a time.Time that is
69
- // representable by a UnixNano() stored as an int64.
70
- TimeType
71
- // TimeFullType indicates that the field carries a time.Time stored as-is.
72
- TimeFullType
73
- // Uint64Type indicates that the field carries a uint64.
74
- Uint64Type
75
- // Uint32Type indicates that the field carries a uint32.
76
- Uint32Type
77
- // Uint16Type indicates that the field carries a uint16.
78
- Uint16Type
79
- // Uint8Type indicates that the field carries a uint8.
80
- Uint8Type
81
- // UintptrType indicates that the field carries a uintptr.
82
- UintptrType
83
- // ReflectType indicates that the field carries an interface{}, which should
84
- // be serialized using reflection.
85
- ReflectType
86
- // NamespaceType signals the beginning of an isolated namespace. All
87
- // subsequent fields should be added to the new namespace.
88
- NamespaceType
89
- // StringerType indicates that the field carries a fmt.Stringer.
90
- StringerType
91
- // ErrorType indicates that the field carries an error.
92
- ErrorType
93
- // SkipType indicates that the field is a no-op.
94
- SkipType
95
- )
96
-
97
- // A Field is a marshaling operation used to add a key-value pair to a logger's
98
- // context. Most fields are lazily marshaled, so it's inexpensive to add fields
99
- // to disabled debug-level log statements.
100
- type Field struct {
101
- Key string
102
- Type FieldType
103
- Integer int64
104
- String string
105
- Interface interface{}
106
- }
107
-
108
- // AddTo exports a field through the ObjectEncoder interface. It's primarily
109
- // useful to library authors, and shouldn't be necessary in most applications.
110
- func (f Field) AddTo(enc ObjectEncoder) {
111
- var err error
112
-
113
- switch f.Type {
114
- case ArrayMarshalerType:
115
- err = enc.AddArray(f.Key, f.Interface.(ArrayMarshaler))
116
- case ObjectMarshalerType:
117
- err = enc.AddObject(f.Key, f.Interface.(ObjectMarshaler))
118
- case BinaryType:
119
- enc.AddBinary(f.Key, f.Interface.([]byte))
120
- case BoolType:
121
- enc.AddBool(f.Key, f.Integer == 1)
122
- case ByteStringType:
123
- enc.AddByteString(f.Key, f.Interface.([]byte))
124
- case Complex128Type:
125
- enc.AddComplex128(f.Key, f.Interface.(complex128))
126
- case Complex64Type:
127
- enc.AddComplex64(f.Key, f.Interface.(complex64))
128
- case DurationType:
129
- enc.AddDuration(f.Key, time.Duration(f.Integer))
130
- case Float64Type:
131
- enc.AddFloat64(f.Key, math.Float64frombits(uint64(f.Integer)))
132
- case Float32Type:
133
- enc.AddFloat32(f.Key, math.Float32frombits(uint32(f.Integer)))
134
- case Int64Type:
135
- enc.AddInt64(f.Key, f.Integer)
136
- case Int32Type:
137
- enc.AddInt32(f.Key, int32(f.Integer))
138
- case Int16Type:
139
- enc.AddInt16(f.Key, int16(f.Integer))
140
- case Int8Type:
141
- enc.AddInt8(f.Key, int8(f.Integer))
142
- case StringType:
143
- enc.AddString(f.Key, f.String)
144
- case TimeType:
145
- if f.Interface != nil {
146
- enc.AddTime(f.Key, time.Unix(0, f.Integer).In(f.Interface.(*time.Location)))
147
- } else {
148
- // Fall back to UTC if location is nil.
149
- enc.AddTime(f.Key, time.Unix(0, f.Integer))
150
- }
151
- case TimeFullType:
152
- enc.AddTime(f.Key, f.Interface.(time.Time))
153
- case Uint64Type:
154
- enc.AddUint64(f.Key, uint64(f.Integer))
155
- case Uint32Type:
156
- enc.AddUint32(f.Key, uint32(f.Integer))
157
- case Uint16Type:
158
- enc.AddUint16(f.Key, uint16(f.Integer))
159
- case Uint8Type:
160
- enc.AddUint8(f.Key, uint8(f.Integer))
161
- case UintptrType:
162
- enc.AddUintptr(f.Key, uintptr(f.Integer))
163
- case ReflectType:
164
- err = enc.AddReflected(f.Key, f.Interface)
165
- case NamespaceType:
166
- enc.OpenNamespace(f.Key)
167
- case StringerType:
168
- err = encodeStringer(f.Key, f.Interface, enc)
169
- case ErrorType:
170
- encodeError(f.Key, f.Interface.(error), enc)
171
- case SkipType:
172
- break
173
- default:
174
- panic(fmt.Sprintf("unknown field type: %v", f))
175
- }
176
-
177
- if err != nil {
178
- enc.AddString(fmt.Sprintf("%sError", f.Key), err.Error())
179
- }
180
- }
181
-
182
- // Equals returns whether two fields are equal. For non-primitive types such as
183
- // errors, marshalers, or reflect types, it uses reflect.DeepEqual.
184
- func (f Field) Equals(other Field) bool {
185
- if f.Type != other.Type {
186
- return false
187
- }
188
- if f.Key != other.Key {
189
- return false
190
- }
191
-
192
- switch f.Type {
193
- case BinaryType, ByteStringType:
194
- return bytes.Equal(f.Interface.([]byte), other.Interface.([]byte))
195
- case ArrayMarshalerType, ObjectMarshalerType, ErrorType, ReflectType:
196
- return reflect.DeepEqual(f.Interface, other.Interface)
197
- default:
198
- return f == other
199
- }
200
- }
201
-
202
- func addFields(enc ObjectEncoder, fields []Field) {
203
- for i := range fields {
204
- fields[i].AddTo(enc)
205
- }
206
- }
207
-
208
- func encodeStringer(key string, stringer interface{}, enc ObjectEncoder) (retErr error) {
209
- // Try to capture panics (from nil references or otherwise) when calling
210
- // the String() method, similar to https://golang.org/src/fmt/print.go#L540
211
- defer func() {
212
- if err := recover(); err != nil {
213
- // If it's a nil pointer, just say "<nil>". The likeliest causes are a
214
- // Stringer that fails to guard against nil or a nil pointer for a
215
- // value receiver, and in either case, "<nil>" is a nice result.
216
- if v := reflect.ValueOf(stringer); v.Kind() == reflect.Ptr && v.IsNil() {
217
- enc.AddString(key, "<nil>")
218
- return
219
- }
220
-
221
- retErr = fmt.Errorf("PANIC=%v", err)
222
- }
223
- }()
224
-
225
- enc.AddString(key, stringer.(fmt.Stringer).String())
226
- return nil
227
- }
@@ -1,68 +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.
20
-
21
- package zapcore
22
-
23
- import "go.uber.org/multierr"
24
-
25
- type hooked struct {
26
- Core
27
- funcs []func(Entry) error
28
- }
29
-
30
- // RegisterHooks wraps a Core and runs a collection of user-defined callback
31
- // hooks each time a message is logged. Execution of the callbacks is blocking.
32
- //
33
- // This offers users an easy way to register simple callbacks (e.g., metrics
34
- // collection) without implementing the full Core interface.
35
- func RegisterHooks(core Core, hooks ...func(Entry) error) Core {
36
- funcs := append([]func(Entry) error{}, hooks...)
37
- return &hooked{
38
- Core: core,
39
- funcs: funcs,
40
- }
41
- }
42
-
43
- func (h *hooked) Check(ent Entry, ce *CheckedEntry) *CheckedEntry {
44
- // Let the wrapped Core decide whether to log this message or not. This
45
- // also gives the downstream a chance to register itself directly with the
46
- // CheckedEntry.
47
- if downstream := h.Core.Check(ent, ce); downstream != nil {
48
- return downstream.AddCore(ent, h)
49
- }
50
- return ce
51
- }
52
-
53
- func (h *hooked) With(fields []Field) Core {
54
- return &hooked{
55
- Core: h.Core.With(fields),
56
- funcs: h.funcs,
57
- }
58
- }
59
-
60
- func (h *hooked) Write(ent Entry, _ []Field) error {
61
- // Since our downstream had a chance to register itself directly with the
62
- // CheckedMessage, we don't need to call it here.
63
- var err error
64
- for i := range h.funcs {
65
- err = multierr.Append(err, h.funcs[i](ent))
66
- }
67
- return err
68
- }