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