planetscale 0.1.0
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.
- checksums.yaml +7 -0
- data/.github/workflows/ci.yml +24 -0
- data/.github/workflows/gem-push.yml +38 -0
- data/.github/workflows/licensed.yml +43 -0
- data/.gitignore +10 -0
- data/.licensed.yml +9 -0
- data/.licenses/go/github.com/armon/circbuf.dep.yml +31 -0
- data/.licenses/go/github.com/gorilla/mux.dep.yml +41 -0
- data/.licenses/go/github.com/hashicorp/go-cleanhttp.dep.yml +375 -0
- data/.licenses/go/github.com/mitchellh/go-homedir.dep.yml +32 -0
- data/.licenses/go/github.com/pkg/errors.dep.yml +36 -0
- data/.licenses/go/github.com/planetscale/planetscale-go/planetscale.dep.yml +160 -0
- data/.licenses/go/github.com/planetscale/sql-proxy/proxy.dep.yml +180 -0
- data/.licenses/go/go.uber.org/atomic.dep.yml +31 -0
- data/.licenses/go/go.uber.org/multierr.dep.yml +30 -0
- data/.licenses/go/go.uber.org/zap.dep.yml +30 -0
- data/.licenses/go/go.uber.org/zap/buffer.dep.yml +30 -0
- data/.licenses/go/go.uber.org/zap/internal/bufferpool.dep.yml +30 -0
- data/.licenses/go/go.uber.org/zap/internal/color.dep.yml +30 -0
- data/.licenses/go/go.uber.org/zap/internal/exit.dep.yml +31 -0
- data/.licenses/go/go.uber.org/zap/zapcore.dep.yml +31 -0
- data/.licenses/go/golang.org/x/net/context/ctxhttp.dep.yml +63 -0
- data/.licenses/go/golang.org/x/oauth2.dep.yml +44 -0
- data/.licenses/go/golang.org/x/oauth2/internal.dep.yml +38 -0
- data/.ruby_version +1 -0
- data/Gemfile +8 -0
- data/LICENSE +201 -0
- data/README.md +88 -0
- data/Rakefile +10 -0
- data/bin/console +15 -0
- data/bin/setup +17 -0
- data/controller.go +255 -0
- data/go.mod +16 -0
- data/go.sum +428 -0
- data/lib/generators/planetscale/install_generator.rb +58 -0
- data/lib/planetscale.rb +137 -0
- data/lib/planetscale/version.rb +5 -0
- data/planetscale.gemspec +44 -0
- data/proxy.go +128 -0
- data/vendor/github.com/armon/circbuf/.gitignore +22 -0
- data/vendor/github.com/armon/circbuf/LICENSE +20 -0
- data/vendor/github.com/armon/circbuf/README.md +28 -0
- data/vendor/github.com/armon/circbuf/circbuf.go +92 -0
- data/vendor/github.com/armon/circbuf/go.mod +1 -0
- data/vendor/github.com/golang/protobuf/AUTHORS +3 -0
- data/vendor/github.com/golang/protobuf/CONTRIBUTORS +3 -0
- data/vendor/github.com/golang/protobuf/LICENSE +28 -0
- data/vendor/github.com/golang/protobuf/proto/buffer.go +324 -0
- data/vendor/github.com/golang/protobuf/proto/defaults.go +63 -0
- data/vendor/github.com/golang/protobuf/proto/deprecated.go +113 -0
- data/vendor/github.com/golang/protobuf/proto/discard.go +58 -0
- data/vendor/github.com/golang/protobuf/proto/extensions.go +356 -0
- data/vendor/github.com/golang/protobuf/proto/properties.go +306 -0
- data/vendor/github.com/golang/protobuf/proto/proto.go +167 -0
- data/vendor/github.com/golang/protobuf/proto/registry.go +317 -0
- data/vendor/github.com/golang/protobuf/proto/text_decode.go +801 -0
- data/vendor/github.com/golang/protobuf/proto/text_encode.go +560 -0
- data/vendor/github.com/golang/protobuf/proto/wire.go +78 -0
- data/vendor/github.com/golang/protobuf/proto/wrappers.go +34 -0
- data/vendor/github.com/gorilla/mux/AUTHORS +8 -0
- data/vendor/github.com/gorilla/mux/LICENSE +27 -0
- data/vendor/github.com/gorilla/mux/README.md +805 -0
- data/vendor/github.com/gorilla/mux/doc.go +306 -0
- data/vendor/github.com/gorilla/mux/go.mod +3 -0
- data/vendor/github.com/gorilla/mux/middleware.go +74 -0
- data/vendor/github.com/gorilla/mux/mux.go +606 -0
- data/vendor/github.com/gorilla/mux/regexp.go +388 -0
- data/vendor/github.com/gorilla/mux/route.go +736 -0
- data/vendor/github.com/gorilla/mux/test_helpers.go +19 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/LICENSE +363 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/README.md +30 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/cleanhttp.go +58 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/doc.go +20 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/go.mod +3 -0
- data/vendor/github.com/hashicorp/go-cleanhttp/handlers.go +48 -0
- data/vendor/github.com/mitchellh/go-homedir/LICENSE +21 -0
- data/vendor/github.com/mitchellh/go-homedir/README.md +14 -0
- data/vendor/github.com/mitchellh/go-homedir/go.mod +1 -0
- data/vendor/github.com/mitchellh/go-homedir/homedir.go +167 -0
- data/vendor/github.com/pkg/errors/.gitignore +24 -0
- data/vendor/github.com/pkg/errors/.travis.yml +10 -0
- data/vendor/github.com/pkg/errors/LICENSE +23 -0
- data/vendor/github.com/pkg/errors/Makefile +44 -0
- data/vendor/github.com/pkg/errors/README.md +59 -0
- data/vendor/github.com/pkg/errors/appveyor.yml +32 -0
- data/vendor/github.com/pkg/errors/errors.go +288 -0
- data/vendor/github.com/pkg/errors/go113.go +38 -0
- data/vendor/github.com/pkg/errors/stack.go +177 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/backups.go +139 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/branches.go +258 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/certs.go +142 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/client.go +305 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/databases.go +131 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/deploy_requests.go +368 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/organizations.go +78 -0
- data/vendor/github.com/planetscale/planetscale-go/planetscale/service_tokens.go +163 -0
- data/vendor/github.com/planetscale/sql-proxy/proxy/client.go +467 -0
- data/vendor/github.com/planetscale/sql-proxy/proxy/tls_cache.go +73 -0
- data/vendor/go.uber.org/atomic/.codecov.yml +19 -0
- data/vendor/go.uber.org/atomic/.gitignore +12 -0
- data/vendor/go.uber.org/atomic/.travis.yml +27 -0
- data/vendor/go.uber.org/atomic/CHANGELOG.md +76 -0
- data/vendor/go.uber.org/atomic/LICENSE.txt +19 -0
- data/vendor/go.uber.org/atomic/Makefile +78 -0
- data/vendor/go.uber.org/atomic/README.md +63 -0
- data/vendor/go.uber.org/atomic/bool.go +81 -0
- data/vendor/go.uber.org/atomic/bool_ext.go +53 -0
- data/vendor/go.uber.org/atomic/doc.go +23 -0
- data/vendor/go.uber.org/atomic/duration.go +82 -0
- data/vendor/go.uber.org/atomic/duration_ext.go +40 -0
- data/vendor/go.uber.org/atomic/error.go +51 -0
- data/vendor/go.uber.org/atomic/error_ext.go +39 -0
- data/vendor/go.uber.org/atomic/float64.go +76 -0
- data/vendor/go.uber.org/atomic/float64_ext.go +47 -0
- data/vendor/go.uber.org/atomic/gen.go +26 -0
- data/vendor/go.uber.org/atomic/go.mod +8 -0
- data/vendor/go.uber.org/atomic/go.sum +9 -0
- data/vendor/go.uber.org/atomic/int32.go +102 -0
- data/vendor/go.uber.org/atomic/int64.go +102 -0
- data/vendor/go.uber.org/atomic/nocmp.go +35 -0
- data/vendor/go.uber.org/atomic/string.go +54 -0
- data/vendor/go.uber.org/atomic/string_ext.go +43 -0
- data/vendor/go.uber.org/atomic/uint32.go +102 -0
- data/vendor/go.uber.org/atomic/uint64.go +102 -0
- data/vendor/go.uber.org/atomic/value.go +31 -0
- data/vendor/go.uber.org/multierr/.codecov.yml +15 -0
- data/vendor/go.uber.org/multierr/.gitignore +4 -0
- data/vendor/go.uber.org/multierr/.travis.yml +23 -0
- data/vendor/go.uber.org/multierr/CHANGELOG.md +60 -0
- data/vendor/go.uber.org/multierr/LICENSE.txt +19 -0
- data/vendor/go.uber.org/multierr/Makefile +42 -0
- data/vendor/go.uber.org/multierr/README.md +23 -0
- data/vendor/go.uber.org/multierr/error.go +449 -0
- data/vendor/go.uber.org/multierr/glide.yaml +8 -0
- data/vendor/go.uber.org/multierr/go.mod +8 -0
- data/vendor/go.uber.org/multierr/go.sum +11 -0
- data/vendor/go.uber.org/multierr/go113.go +52 -0
- data/vendor/go.uber.org/zap/.codecov.yml +17 -0
- data/vendor/go.uber.org/zap/.gitignore +32 -0
- data/vendor/go.uber.org/zap/.readme.tmpl +109 -0
- data/vendor/go.uber.org/zap/.travis.yml +23 -0
- data/vendor/go.uber.org/zap/CHANGELOG.md +432 -0
- data/vendor/go.uber.org/zap/CODE_OF_CONDUCT.md +75 -0
- data/vendor/go.uber.org/zap/CONTRIBUTING.md +81 -0
- data/vendor/go.uber.org/zap/FAQ.md +156 -0
- data/vendor/go.uber.org/zap/LICENSE.txt +19 -0
- data/vendor/go.uber.org/zap/Makefile +63 -0
- data/vendor/go.uber.org/zap/README.md +134 -0
- data/vendor/go.uber.org/zap/array.go +320 -0
- data/vendor/go.uber.org/zap/buffer/buffer.go +123 -0
- data/vendor/go.uber.org/zap/buffer/pool.go +49 -0
- data/vendor/go.uber.org/zap/checklicense.sh +17 -0
- data/vendor/go.uber.org/zap/config.go +264 -0
- data/vendor/go.uber.org/zap/doc.go +113 -0
- data/vendor/go.uber.org/zap/encoder.go +79 -0
- data/vendor/go.uber.org/zap/error.go +80 -0
- data/vendor/go.uber.org/zap/field.go +539 -0
- data/vendor/go.uber.org/zap/flag.go +39 -0
- data/vendor/go.uber.org/zap/glide.yaml +34 -0
- data/vendor/go.uber.org/zap/global.go +168 -0
- data/vendor/go.uber.org/zap/global_go112.go +26 -0
- data/vendor/go.uber.org/zap/global_prego112.go +26 -0
- data/vendor/go.uber.org/zap/go.mod +13 -0
- data/vendor/go.uber.org/zap/go.sum +56 -0
- data/vendor/go.uber.org/zap/http_handler.go +81 -0
- data/vendor/go.uber.org/zap/internal/bufferpool/bufferpool.go +31 -0
- data/vendor/go.uber.org/zap/internal/color/color.go +44 -0
- data/vendor/go.uber.org/zap/internal/exit/exit.go +64 -0
- data/vendor/go.uber.org/zap/level.go +132 -0
- data/vendor/go.uber.org/zap/logger.go +344 -0
- data/vendor/go.uber.org/zap/options.go +140 -0
- data/vendor/go.uber.org/zap/sink.go +161 -0
- data/vendor/go.uber.org/zap/stacktrace.go +85 -0
- data/vendor/go.uber.org/zap/sugar.go +304 -0
- data/vendor/go.uber.org/zap/time.go +27 -0
- data/vendor/go.uber.org/zap/writer.go +99 -0
- data/vendor/go.uber.org/zap/zapcore/console_encoder.go +161 -0
- data/vendor/go.uber.org/zap/zapcore/core.go +113 -0
- data/vendor/go.uber.org/zap/zapcore/doc.go +24 -0
- data/vendor/go.uber.org/zap/zapcore/encoder.go +443 -0
- data/vendor/go.uber.org/zap/zapcore/entry.go +264 -0
- data/vendor/go.uber.org/zap/zapcore/error.go +115 -0
- data/vendor/go.uber.org/zap/zapcore/field.go +227 -0
- data/vendor/go.uber.org/zap/zapcore/hook.go +68 -0
- data/vendor/go.uber.org/zap/zapcore/increase_level.go +66 -0
- data/vendor/go.uber.org/zap/zapcore/json_encoder.go +534 -0
- data/vendor/go.uber.org/zap/zapcore/level.go +175 -0
- data/vendor/go.uber.org/zap/zapcore/level_strings.go +46 -0
- data/vendor/go.uber.org/zap/zapcore/marshaler.go +61 -0
- data/vendor/go.uber.org/zap/zapcore/memory_encoder.go +179 -0
- data/vendor/go.uber.org/zap/zapcore/sampler.go +208 -0
- data/vendor/go.uber.org/zap/zapcore/tee.go +81 -0
- data/vendor/go.uber.org/zap/zapcore/write_syncer.go +123 -0
- data/vendor/golang.org/x/net/AUTHORS +3 -0
- data/vendor/golang.org/x/net/CONTRIBUTORS +3 -0
- data/vendor/golang.org/x/net/LICENSE +27 -0
- data/vendor/golang.org/x/net/PATENTS +22 -0
- data/vendor/golang.org/x/net/context/context.go +56 -0
- data/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +71 -0
- data/vendor/golang.org/x/net/context/go17.go +73 -0
- data/vendor/golang.org/x/net/context/go19.go +21 -0
- data/vendor/golang.org/x/net/context/pre_go17.go +301 -0
- data/vendor/golang.org/x/net/context/pre_go19.go +110 -0
- data/vendor/golang.org/x/oauth2/.travis.yml +13 -0
- data/vendor/golang.org/x/oauth2/AUTHORS +3 -0
- data/vendor/golang.org/x/oauth2/CONTRIBUTING.md +26 -0
- data/vendor/golang.org/x/oauth2/CONTRIBUTORS +3 -0
- data/vendor/golang.org/x/oauth2/LICENSE +27 -0
- data/vendor/golang.org/x/oauth2/README.md +36 -0
- data/vendor/golang.org/x/oauth2/go.mod +9 -0
- data/vendor/golang.org/x/oauth2/go.sum +361 -0
- data/vendor/golang.org/x/oauth2/internal/client_appengine.go +14 -0
- data/vendor/golang.org/x/oauth2/internal/doc.go +6 -0
- data/vendor/golang.org/x/oauth2/internal/oauth2.go +37 -0
- data/vendor/golang.org/x/oauth2/internal/token.go +294 -0
- data/vendor/golang.org/x/oauth2/internal/transport.go +33 -0
- data/vendor/golang.org/x/oauth2/oauth2.go +381 -0
- data/vendor/golang.org/x/oauth2/token.go +178 -0
- data/vendor/golang.org/x/oauth2/transport.go +89 -0
- data/vendor/google.golang.org/appengine/LICENSE +202 -0
- data/vendor/google.golang.org/appengine/internal/api.go +678 -0
- data/vendor/google.golang.org/appengine/internal/api_classic.go +169 -0
- data/vendor/google.golang.org/appengine/internal/api_common.go +123 -0
- data/vendor/google.golang.org/appengine/internal/app_id.go +28 -0
- data/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +308 -0
- data/vendor/google.golang.org/appengine/internal/base/api_base.proto +33 -0
- data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +4367 -0
- data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +551 -0
- data/vendor/google.golang.org/appengine/internal/identity.go +55 -0
- data/vendor/google.golang.org/appengine/internal/identity_classic.go +61 -0
- data/vendor/google.golang.org/appengine/internal/identity_flex.go +11 -0
- data/vendor/google.golang.org/appengine/internal/identity_vm.go +134 -0
- data/vendor/google.golang.org/appengine/internal/internal.go +110 -0
- data/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +1313 -0
- data/vendor/google.golang.org/appengine/internal/log/log_service.proto +150 -0
- data/vendor/google.golang.org/appengine/internal/main.go +16 -0
- data/vendor/google.golang.org/appengine/internal/main_common.go +7 -0
- data/vendor/google.golang.org/appengine/internal/main_vm.go +69 -0
- data/vendor/google.golang.org/appengine/internal/metadata.go +60 -0
- data/vendor/google.golang.org/appengine/internal/net.go +56 -0
- data/vendor/google.golang.org/appengine/internal/regen.sh +40 -0
- data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +361 -0
- data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +44 -0
- data/vendor/google.golang.org/appengine/internal/transaction.go +115 -0
- data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.pb.go +527 -0
- data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.proto +64 -0
- data/vendor/google.golang.org/appengine/urlfetch/urlfetch.go +210 -0
- data/vendor/google.golang.org/protobuf/AUTHORS +3 -0
- data/vendor/google.golang.org/protobuf/CONTRIBUTORS +3 -0
- data/vendor/google.golang.org/protobuf/LICENSE +27 -0
- data/vendor/google.golang.org/protobuf/PATENTS +22 -0
- data/vendor/google.golang.org/protobuf/encoding/prototext/decode.go +773 -0
- data/vendor/google.golang.org/protobuf/encoding/prototext/doc.go +7 -0
- data/vendor/google.golang.org/protobuf/encoding/prototext/encode.go +371 -0
- data/vendor/google.golang.org/protobuf/encoding/protowire/wire.go +538 -0
- data/vendor/google.golang.org/protobuf/internal/descfmt/stringer.go +318 -0
- data/vendor/google.golang.org/protobuf/internal/descopts/options.go +29 -0
- data/vendor/google.golang.org/protobuf/internal/detrand/rand.go +69 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/defval/default.go +213 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/messageset/messageset.go +241 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/tag/tag.go +207 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode.go +665 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_number.go +190 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_string.go +161 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_token.go +373 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/doc.go +29 -0
- data/vendor/google.golang.org/protobuf/internal/encoding/text/encode.go +265 -0
- data/vendor/google.golang.org/protobuf/internal/errors/errors.go +89 -0
- data/vendor/google.golang.org/protobuf/internal/errors/is_go112.go +39 -0
- data/vendor/google.golang.org/protobuf/internal/errors/is_go113.go +12 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/build.go +158 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc.go +631 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_init.go +471 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_lazy.go +704 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list.go +450 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list_gen.go +356 -0
- data/vendor/google.golang.org/protobuf/internal/filedesc/placeholder.go +107 -0
- data/vendor/google.golang.org/protobuf/internal/filetype/build.go +297 -0
- data/vendor/google.golang.org/protobuf/internal/flags/flags.go +24 -0
- data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_disable.go +9 -0
- data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_enable.go +9 -0
- data/vendor/google.golang.org/protobuf/internal/genid/any_gen.go +34 -0
- data/vendor/google.golang.org/protobuf/internal/genid/api_gen.go +106 -0
- data/vendor/google.golang.org/protobuf/internal/genid/descriptor_gen.go +829 -0
- data/vendor/google.golang.org/protobuf/internal/genid/doc.go +11 -0
- data/vendor/google.golang.org/protobuf/internal/genid/duration_gen.go +34 -0
- data/vendor/google.golang.org/protobuf/internal/genid/empty_gen.go +19 -0
- data/vendor/google.golang.org/protobuf/internal/genid/field_mask_gen.go +31 -0
- data/vendor/google.golang.org/protobuf/internal/genid/goname.go +25 -0
- data/vendor/google.golang.org/protobuf/internal/genid/map_entry.go +16 -0
- data/vendor/google.golang.org/protobuf/internal/genid/source_context_gen.go +31 -0
- data/vendor/google.golang.org/protobuf/internal/genid/struct_gen.go +116 -0
- data/vendor/google.golang.org/protobuf/internal/genid/timestamp_gen.go +34 -0
- data/vendor/google.golang.org/protobuf/internal/genid/type_gen.go +184 -0
- data/vendor/google.golang.org/protobuf/internal/genid/wrappers.go +13 -0
- data/vendor/google.golang.org/protobuf/internal/genid/wrappers_gen.go +175 -0
- data/vendor/google.golang.org/protobuf/internal/impl/api_export.go +177 -0
- data/vendor/google.golang.org/protobuf/internal/impl/checkinit.go +141 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_extension.go +223 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_field.go +830 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_gen.go +5637 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map.go +388 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go111.go +37 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go112.go +11 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_message.go +217 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_messageset.go +123 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_reflect.go +209 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_tables.go +557 -0
- data/vendor/google.golang.org/protobuf/internal/impl/codec_unsafe.go +17 -0
- data/vendor/google.golang.org/protobuf/internal/impl/convert.go +496 -0
- data/vendor/google.golang.org/protobuf/internal/impl/convert_list.go +141 -0
- data/vendor/google.golang.org/protobuf/internal/impl/convert_map.go +121 -0
- data/vendor/google.golang.org/protobuf/internal/impl/decode.go +276 -0
- data/vendor/google.golang.org/protobuf/internal/impl/encode.go +201 -0
- data/vendor/google.golang.org/protobuf/internal/impl/enum.go +21 -0
- data/vendor/google.golang.org/protobuf/internal/impl/extension.go +156 -0
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_enum.go +219 -0
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_export.go +92 -0
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_extension.go +176 -0
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_file.go +81 -0
- data/vendor/google.golang.org/protobuf/internal/impl/legacy_message.go +558 -0
- data/vendor/google.golang.org/protobuf/internal/impl/merge.go +176 -0
- data/vendor/google.golang.org/protobuf/internal/impl/merge_gen.go +209 -0
- data/vendor/google.golang.org/protobuf/internal/impl/message.go +276 -0
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect.go +465 -0
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_field.go +543 -0
- data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_gen.go +249 -0
- data/vendor/google.golang.org/protobuf/internal/impl/pointer_reflect.go +178 -0
- data/vendor/google.golang.org/protobuf/internal/impl/pointer_unsafe.go +174 -0
- data/vendor/google.golang.org/protobuf/internal/impl/validate.go +576 -0
- data/vendor/google.golang.org/protobuf/internal/impl/weak.go +74 -0
- data/vendor/google.golang.org/protobuf/internal/order/order.go +89 -0
- data/vendor/google.golang.org/protobuf/internal/order/range.go +115 -0
- data/vendor/google.golang.org/protobuf/internal/pragma/pragma.go +29 -0
- data/vendor/google.golang.org/protobuf/internal/set/ints.go +58 -0
- data/vendor/google.golang.org/protobuf/internal/strs/strings.go +196 -0
- data/vendor/google.golang.org/protobuf/internal/strs/strings_pure.go +27 -0
- data/vendor/google.golang.org/protobuf/internal/strs/strings_unsafe.go +94 -0
- data/vendor/google.golang.org/protobuf/internal/version/version.go +79 -0
- data/vendor/google.golang.org/protobuf/proto/checkinit.go +71 -0
- data/vendor/google.golang.org/protobuf/proto/decode.go +278 -0
- data/vendor/google.golang.org/protobuf/proto/decode_gen.go +603 -0
- data/vendor/google.golang.org/protobuf/proto/doc.go +94 -0
- data/vendor/google.golang.org/protobuf/proto/encode.go +319 -0
- data/vendor/google.golang.org/protobuf/proto/encode_gen.go +97 -0
- data/vendor/google.golang.org/protobuf/proto/equal.go +167 -0
- data/vendor/google.golang.org/protobuf/proto/extension.go +92 -0
- data/vendor/google.golang.org/protobuf/proto/merge.go +139 -0
- data/vendor/google.golang.org/protobuf/proto/messageset.go +93 -0
- data/vendor/google.golang.org/protobuf/proto/proto.go +43 -0
- data/vendor/google.golang.org/protobuf/proto/proto_methods.go +19 -0
- data/vendor/google.golang.org/protobuf/proto/proto_reflect.go +19 -0
- data/vendor/google.golang.org/protobuf/proto/reset.go +43 -0
- data/vendor/google.golang.org/protobuf/proto/size.go +97 -0
- data/vendor/google.golang.org/protobuf/proto/size_gen.go +55 -0
- data/vendor/google.golang.org/protobuf/proto/wrappers.go +29 -0
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc.go +276 -0
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_init.go +248 -0
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_resolve.go +286 -0
- data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_validate.go +374 -0
- data/vendor/google.golang.org/protobuf/reflect/protodesc/proto.go +252 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/methods.go +77 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/proto.go +504 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/source.go +128 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/source_gen.go +461 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/type.go +665 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value.go +285 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_pure.go +59 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_union.go +411 -0
- data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_unsafe.go +98 -0
- data/vendor/google.golang.org/protobuf/reflect/protoregistry/registry.go +869 -0
- data/vendor/google.golang.org/protobuf/runtime/protoiface/legacy.go +15 -0
- data/vendor/google.golang.org/protobuf/runtime/protoiface/methods.go +167 -0
- data/vendor/google.golang.org/protobuf/runtime/protoimpl/impl.go +44 -0
- data/vendor/google.golang.org/protobuf/runtime/protoimpl/version.go +56 -0
- data/vendor/google.golang.org/protobuf/types/descriptorpb/descriptor.pb.go +4039 -0
- data/vendor/modules.txt +79 -0
- metadata +495 -0
|
@@ -0,0 +1,68 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
// Copyright (c) 2020 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 "fmt"
|
|
24
|
+
|
|
25
|
+
type levelFilterCore struct {
|
|
26
|
+
core Core
|
|
27
|
+
level LevelEnabler
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// NewIncreaseLevelCore creates a core that can be used to increase the level of
|
|
31
|
+
// an existing Core. It cannot be used to decrease the logging level, as it acts
|
|
32
|
+
// as a filter before calling the underlying core. If level decreases the log level,
|
|
33
|
+
// an error is returned.
|
|
34
|
+
func NewIncreaseLevelCore(core Core, level LevelEnabler) (Core, error) {
|
|
35
|
+
for l := _maxLevel; l >= _minLevel; l-- {
|
|
36
|
+
if !core.Enabled(l) && level.Enabled(l) {
|
|
37
|
+
return nil, fmt.Errorf("invalid increase level, as level %q is allowed by increased level, but not by existing core", l)
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return &levelFilterCore{core, level}, nil
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
func (c *levelFilterCore) Enabled(lvl Level) bool {
|
|
45
|
+
return c.level.Enabled(lvl)
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
func (c *levelFilterCore) With(fields []Field) Core {
|
|
49
|
+
return &levelFilterCore{c.core.With(fields), c.level}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
func (c *levelFilterCore) Check(ent Entry, ce *CheckedEntry) *CheckedEntry {
|
|
53
|
+
if !c.Enabled(ent.Level) {
|
|
54
|
+
return ce
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return c.core.Check(ent, ce)
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
func (c *levelFilterCore) Write(ent Entry, fields []Field) error {
|
|
61
|
+
return c.core.Write(ent, fields)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
func (c *levelFilterCore) Sync() error {
|
|
65
|
+
return c.core.Sync()
|
|
66
|
+
}
|
|
@@ -0,0 +1,534 @@
|
|
|
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
|
+
"encoding/base64"
|
|
25
|
+
"encoding/json"
|
|
26
|
+
"math"
|
|
27
|
+
"sync"
|
|
28
|
+
"time"
|
|
29
|
+
"unicode/utf8"
|
|
30
|
+
|
|
31
|
+
"go.uber.org/zap/buffer"
|
|
32
|
+
"go.uber.org/zap/internal/bufferpool"
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
// For JSON-escaping; see jsonEncoder.safeAddString below.
|
|
36
|
+
const _hex = "0123456789abcdef"
|
|
37
|
+
|
|
38
|
+
var _jsonPool = sync.Pool{New: func() interface{} {
|
|
39
|
+
return &jsonEncoder{}
|
|
40
|
+
}}
|
|
41
|
+
|
|
42
|
+
func getJSONEncoder() *jsonEncoder {
|
|
43
|
+
return _jsonPool.Get().(*jsonEncoder)
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
func putJSONEncoder(enc *jsonEncoder) {
|
|
47
|
+
if enc.reflectBuf != nil {
|
|
48
|
+
enc.reflectBuf.Free()
|
|
49
|
+
}
|
|
50
|
+
enc.EncoderConfig = nil
|
|
51
|
+
enc.buf = nil
|
|
52
|
+
enc.spaced = false
|
|
53
|
+
enc.openNamespaces = 0
|
|
54
|
+
enc.reflectBuf = nil
|
|
55
|
+
enc.reflectEnc = nil
|
|
56
|
+
_jsonPool.Put(enc)
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
type jsonEncoder struct {
|
|
60
|
+
*EncoderConfig
|
|
61
|
+
buf *buffer.Buffer
|
|
62
|
+
spaced bool // include spaces after colons and commas
|
|
63
|
+
openNamespaces int
|
|
64
|
+
|
|
65
|
+
// for encoding generic values by reflection
|
|
66
|
+
reflectBuf *buffer.Buffer
|
|
67
|
+
reflectEnc *json.Encoder
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// NewJSONEncoder creates a fast, low-allocation JSON encoder. The encoder
|
|
71
|
+
// appropriately escapes all field keys and values.
|
|
72
|
+
//
|
|
73
|
+
// Note that the encoder doesn't deduplicate keys, so it's possible to produce
|
|
74
|
+
// a message like
|
|
75
|
+
// {"foo":"bar","foo":"baz"}
|
|
76
|
+
// This is permitted by the JSON specification, but not encouraged. Many
|
|
77
|
+
// libraries will ignore duplicate key-value pairs (typically keeping the last
|
|
78
|
+
// pair) when unmarshaling, but users should attempt to avoid adding duplicate
|
|
79
|
+
// keys.
|
|
80
|
+
func NewJSONEncoder(cfg EncoderConfig) Encoder {
|
|
81
|
+
return newJSONEncoder(cfg, false)
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
func newJSONEncoder(cfg EncoderConfig, spaced bool) *jsonEncoder {
|
|
85
|
+
return &jsonEncoder{
|
|
86
|
+
EncoderConfig: &cfg,
|
|
87
|
+
buf: bufferpool.Get(),
|
|
88
|
+
spaced: spaced,
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
func (enc *jsonEncoder) AddArray(key string, arr ArrayMarshaler) error {
|
|
93
|
+
enc.addKey(key)
|
|
94
|
+
return enc.AppendArray(arr)
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
func (enc *jsonEncoder) AddObject(key string, obj ObjectMarshaler) error {
|
|
98
|
+
enc.addKey(key)
|
|
99
|
+
return enc.AppendObject(obj)
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
func (enc *jsonEncoder) AddBinary(key string, val []byte) {
|
|
103
|
+
enc.AddString(key, base64.StdEncoding.EncodeToString(val))
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
func (enc *jsonEncoder) AddByteString(key string, val []byte) {
|
|
107
|
+
enc.addKey(key)
|
|
108
|
+
enc.AppendByteString(val)
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
func (enc *jsonEncoder) AddBool(key string, val bool) {
|
|
112
|
+
enc.addKey(key)
|
|
113
|
+
enc.AppendBool(val)
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
func (enc *jsonEncoder) AddComplex128(key string, val complex128) {
|
|
117
|
+
enc.addKey(key)
|
|
118
|
+
enc.AppendComplex128(val)
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
func (enc *jsonEncoder) AddDuration(key string, val time.Duration) {
|
|
122
|
+
enc.addKey(key)
|
|
123
|
+
enc.AppendDuration(val)
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
func (enc *jsonEncoder) AddFloat64(key string, val float64) {
|
|
127
|
+
enc.addKey(key)
|
|
128
|
+
enc.AppendFloat64(val)
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
func (enc *jsonEncoder) AddInt64(key string, val int64) {
|
|
132
|
+
enc.addKey(key)
|
|
133
|
+
enc.AppendInt64(val)
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
func (enc *jsonEncoder) resetReflectBuf() {
|
|
137
|
+
if enc.reflectBuf == nil {
|
|
138
|
+
enc.reflectBuf = bufferpool.Get()
|
|
139
|
+
enc.reflectEnc = json.NewEncoder(enc.reflectBuf)
|
|
140
|
+
|
|
141
|
+
// For consistency with our custom JSON encoder.
|
|
142
|
+
enc.reflectEnc.SetEscapeHTML(false)
|
|
143
|
+
} else {
|
|
144
|
+
enc.reflectBuf.Reset()
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
var nullLiteralBytes = []byte("null")
|
|
149
|
+
|
|
150
|
+
// Only invoke the standard JSON encoder if there is actually something to
|
|
151
|
+
// encode; otherwise write JSON null literal directly.
|
|
152
|
+
func (enc *jsonEncoder) encodeReflected(obj interface{}) ([]byte, error) {
|
|
153
|
+
if obj == nil {
|
|
154
|
+
return nullLiteralBytes, nil
|
|
155
|
+
}
|
|
156
|
+
enc.resetReflectBuf()
|
|
157
|
+
if err := enc.reflectEnc.Encode(obj); err != nil {
|
|
158
|
+
return nil, err
|
|
159
|
+
}
|
|
160
|
+
enc.reflectBuf.TrimNewline()
|
|
161
|
+
return enc.reflectBuf.Bytes(), nil
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
func (enc *jsonEncoder) AddReflected(key string, obj interface{}) error {
|
|
165
|
+
valueBytes, err := enc.encodeReflected(obj)
|
|
166
|
+
if err != nil {
|
|
167
|
+
return err
|
|
168
|
+
}
|
|
169
|
+
enc.addKey(key)
|
|
170
|
+
_, err = enc.buf.Write(valueBytes)
|
|
171
|
+
return err
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
func (enc *jsonEncoder) OpenNamespace(key string) {
|
|
175
|
+
enc.addKey(key)
|
|
176
|
+
enc.buf.AppendByte('{')
|
|
177
|
+
enc.openNamespaces++
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
func (enc *jsonEncoder) AddString(key, val string) {
|
|
181
|
+
enc.addKey(key)
|
|
182
|
+
enc.AppendString(val)
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
func (enc *jsonEncoder) AddTime(key string, val time.Time) {
|
|
186
|
+
enc.addKey(key)
|
|
187
|
+
enc.AppendTime(val)
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
func (enc *jsonEncoder) AddUint64(key string, val uint64) {
|
|
191
|
+
enc.addKey(key)
|
|
192
|
+
enc.AppendUint64(val)
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
func (enc *jsonEncoder) AppendArray(arr ArrayMarshaler) error {
|
|
196
|
+
enc.addElementSeparator()
|
|
197
|
+
enc.buf.AppendByte('[')
|
|
198
|
+
err := arr.MarshalLogArray(enc)
|
|
199
|
+
enc.buf.AppendByte(']')
|
|
200
|
+
return err
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
func (enc *jsonEncoder) AppendObject(obj ObjectMarshaler) error {
|
|
204
|
+
enc.addElementSeparator()
|
|
205
|
+
enc.buf.AppendByte('{')
|
|
206
|
+
err := obj.MarshalLogObject(enc)
|
|
207
|
+
enc.buf.AppendByte('}')
|
|
208
|
+
return err
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
func (enc *jsonEncoder) AppendBool(val bool) {
|
|
212
|
+
enc.addElementSeparator()
|
|
213
|
+
enc.buf.AppendBool(val)
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
func (enc *jsonEncoder) AppendByteString(val []byte) {
|
|
217
|
+
enc.addElementSeparator()
|
|
218
|
+
enc.buf.AppendByte('"')
|
|
219
|
+
enc.safeAddByteString(val)
|
|
220
|
+
enc.buf.AppendByte('"')
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
func (enc *jsonEncoder) AppendComplex128(val complex128) {
|
|
224
|
+
enc.addElementSeparator()
|
|
225
|
+
// Cast to a platform-independent, fixed-size type.
|
|
226
|
+
r, i := float64(real(val)), float64(imag(val))
|
|
227
|
+
enc.buf.AppendByte('"')
|
|
228
|
+
// Because we're always in a quoted string, we can use strconv without
|
|
229
|
+
// special-casing NaN and +/-Inf.
|
|
230
|
+
enc.buf.AppendFloat(r, 64)
|
|
231
|
+
enc.buf.AppendByte('+')
|
|
232
|
+
enc.buf.AppendFloat(i, 64)
|
|
233
|
+
enc.buf.AppendByte('i')
|
|
234
|
+
enc.buf.AppendByte('"')
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
func (enc *jsonEncoder) AppendDuration(val time.Duration) {
|
|
238
|
+
cur := enc.buf.Len()
|
|
239
|
+
if e := enc.EncodeDuration; e != nil {
|
|
240
|
+
e(val, enc)
|
|
241
|
+
}
|
|
242
|
+
if cur == enc.buf.Len() {
|
|
243
|
+
// User-supplied EncodeDuration is a no-op. Fall back to nanoseconds to keep
|
|
244
|
+
// JSON valid.
|
|
245
|
+
enc.AppendInt64(int64(val))
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
func (enc *jsonEncoder) AppendInt64(val int64) {
|
|
250
|
+
enc.addElementSeparator()
|
|
251
|
+
enc.buf.AppendInt(val)
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
func (enc *jsonEncoder) AppendReflected(val interface{}) error {
|
|
255
|
+
valueBytes, err := enc.encodeReflected(val)
|
|
256
|
+
if err != nil {
|
|
257
|
+
return err
|
|
258
|
+
}
|
|
259
|
+
enc.addElementSeparator()
|
|
260
|
+
_, err = enc.buf.Write(valueBytes)
|
|
261
|
+
return err
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
func (enc *jsonEncoder) AppendString(val string) {
|
|
265
|
+
enc.addElementSeparator()
|
|
266
|
+
enc.buf.AppendByte('"')
|
|
267
|
+
enc.safeAddString(val)
|
|
268
|
+
enc.buf.AppendByte('"')
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
func (enc *jsonEncoder) AppendTimeLayout(time time.Time, layout string) {
|
|
272
|
+
enc.addElementSeparator()
|
|
273
|
+
enc.buf.AppendByte('"')
|
|
274
|
+
enc.buf.AppendTime(time, layout)
|
|
275
|
+
enc.buf.AppendByte('"')
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
func (enc *jsonEncoder) AppendTime(val time.Time) {
|
|
279
|
+
cur := enc.buf.Len()
|
|
280
|
+
if e := enc.EncodeTime; e != nil {
|
|
281
|
+
e(val, enc)
|
|
282
|
+
}
|
|
283
|
+
if cur == enc.buf.Len() {
|
|
284
|
+
// User-supplied EncodeTime is a no-op. Fall back to nanos since epoch to keep
|
|
285
|
+
// output JSON valid.
|
|
286
|
+
enc.AppendInt64(val.UnixNano())
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
func (enc *jsonEncoder) AppendUint64(val uint64) {
|
|
291
|
+
enc.addElementSeparator()
|
|
292
|
+
enc.buf.AppendUint(val)
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
func (enc *jsonEncoder) AddComplex64(k string, v complex64) { enc.AddComplex128(k, complex128(v)) }
|
|
296
|
+
func (enc *jsonEncoder) AddFloat32(k string, v float32) { enc.AddFloat64(k, float64(v)) }
|
|
297
|
+
func (enc *jsonEncoder) AddInt(k string, v int) { enc.AddInt64(k, int64(v)) }
|
|
298
|
+
func (enc *jsonEncoder) AddInt32(k string, v int32) { enc.AddInt64(k, int64(v)) }
|
|
299
|
+
func (enc *jsonEncoder) AddInt16(k string, v int16) { enc.AddInt64(k, int64(v)) }
|
|
300
|
+
func (enc *jsonEncoder) AddInt8(k string, v int8) { enc.AddInt64(k, int64(v)) }
|
|
301
|
+
func (enc *jsonEncoder) AddUint(k string, v uint) { enc.AddUint64(k, uint64(v)) }
|
|
302
|
+
func (enc *jsonEncoder) AddUint32(k string, v uint32) { enc.AddUint64(k, uint64(v)) }
|
|
303
|
+
func (enc *jsonEncoder) AddUint16(k string, v uint16) { enc.AddUint64(k, uint64(v)) }
|
|
304
|
+
func (enc *jsonEncoder) AddUint8(k string, v uint8) { enc.AddUint64(k, uint64(v)) }
|
|
305
|
+
func (enc *jsonEncoder) AddUintptr(k string, v uintptr) { enc.AddUint64(k, uint64(v)) }
|
|
306
|
+
func (enc *jsonEncoder) AppendComplex64(v complex64) { enc.AppendComplex128(complex128(v)) }
|
|
307
|
+
func (enc *jsonEncoder) AppendFloat64(v float64) { enc.appendFloat(v, 64) }
|
|
308
|
+
func (enc *jsonEncoder) AppendFloat32(v float32) { enc.appendFloat(float64(v), 32) }
|
|
309
|
+
func (enc *jsonEncoder) AppendInt(v int) { enc.AppendInt64(int64(v)) }
|
|
310
|
+
func (enc *jsonEncoder) AppendInt32(v int32) { enc.AppendInt64(int64(v)) }
|
|
311
|
+
func (enc *jsonEncoder) AppendInt16(v int16) { enc.AppendInt64(int64(v)) }
|
|
312
|
+
func (enc *jsonEncoder) AppendInt8(v int8) { enc.AppendInt64(int64(v)) }
|
|
313
|
+
func (enc *jsonEncoder) AppendUint(v uint) { enc.AppendUint64(uint64(v)) }
|
|
314
|
+
func (enc *jsonEncoder) AppendUint32(v uint32) { enc.AppendUint64(uint64(v)) }
|
|
315
|
+
func (enc *jsonEncoder) AppendUint16(v uint16) { enc.AppendUint64(uint64(v)) }
|
|
316
|
+
func (enc *jsonEncoder) AppendUint8(v uint8) { enc.AppendUint64(uint64(v)) }
|
|
317
|
+
func (enc *jsonEncoder) AppendUintptr(v uintptr) { enc.AppendUint64(uint64(v)) }
|
|
318
|
+
|
|
319
|
+
func (enc *jsonEncoder) Clone() Encoder {
|
|
320
|
+
clone := enc.clone()
|
|
321
|
+
clone.buf.Write(enc.buf.Bytes())
|
|
322
|
+
return clone
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
func (enc *jsonEncoder) clone() *jsonEncoder {
|
|
326
|
+
clone := getJSONEncoder()
|
|
327
|
+
clone.EncoderConfig = enc.EncoderConfig
|
|
328
|
+
clone.spaced = enc.spaced
|
|
329
|
+
clone.openNamespaces = enc.openNamespaces
|
|
330
|
+
clone.buf = bufferpool.Get()
|
|
331
|
+
return clone
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
func (enc *jsonEncoder) EncodeEntry(ent Entry, fields []Field) (*buffer.Buffer, error) {
|
|
335
|
+
final := enc.clone()
|
|
336
|
+
final.buf.AppendByte('{')
|
|
337
|
+
|
|
338
|
+
if final.LevelKey != "" {
|
|
339
|
+
final.addKey(final.LevelKey)
|
|
340
|
+
cur := final.buf.Len()
|
|
341
|
+
final.EncodeLevel(ent.Level, final)
|
|
342
|
+
if cur == final.buf.Len() {
|
|
343
|
+
// User-supplied EncodeLevel was a no-op. Fall back to strings to keep
|
|
344
|
+
// output JSON valid.
|
|
345
|
+
final.AppendString(ent.Level.String())
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
if final.TimeKey != "" {
|
|
349
|
+
final.AddTime(final.TimeKey, ent.Time)
|
|
350
|
+
}
|
|
351
|
+
if ent.LoggerName != "" && final.NameKey != "" {
|
|
352
|
+
final.addKey(final.NameKey)
|
|
353
|
+
cur := final.buf.Len()
|
|
354
|
+
nameEncoder := final.EncodeName
|
|
355
|
+
|
|
356
|
+
// if no name encoder provided, fall back to FullNameEncoder for backwards
|
|
357
|
+
// compatibility
|
|
358
|
+
if nameEncoder == nil {
|
|
359
|
+
nameEncoder = FullNameEncoder
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
nameEncoder(ent.LoggerName, final)
|
|
363
|
+
if cur == final.buf.Len() {
|
|
364
|
+
// User-supplied EncodeName was a no-op. Fall back to strings to
|
|
365
|
+
// keep output JSON valid.
|
|
366
|
+
final.AppendString(ent.LoggerName)
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
if ent.Caller.Defined {
|
|
370
|
+
if final.CallerKey != "" {
|
|
371
|
+
final.addKey(final.CallerKey)
|
|
372
|
+
cur := final.buf.Len()
|
|
373
|
+
final.EncodeCaller(ent.Caller, final)
|
|
374
|
+
if cur == final.buf.Len() {
|
|
375
|
+
// User-supplied EncodeCaller was a no-op. Fall back to strings to
|
|
376
|
+
// keep output JSON valid.
|
|
377
|
+
final.AppendString(ent.Caller.String())
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
if final.FunctionKey != "" {
|
|
381
|
+
final.addKey(final.FunctionKey)
|
|
382
|
+
final.AppendString(ent.Caller.Function)
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
if final.MessageKey != "" {
|
|
386
|
+
final.addKey(enc.MessageKey)
|
|
387
|
+
final.AppendString(ent.Message)
|
|
388
|
+
}
|
|
389
|
+
if enc.buf.Len() > 0 {
|
|
390
|
+
final.addElementSeparator()
|
|
391
|
+
final.buf.Write(enc.buf.Bytes())
|
|
392
|
+
}
|
|
393
|
+
addFields(final, fields)
|
|
394
|
+
final.closeOpenNamespaces()
|
|
395
|
+
if ent.Stack != "" && final.StacktraceKey != "" {
|
|
396
|
+
final.AddString(final.StacktraceKey, ent.Stack)
|
|
397
|
+
}
|
|
398
|
+
final.buf.AppendByte('}')
|
|
399
|
+
if final.LineEnding != "" {
|
|
400
|
+
final.buf.AppendString(final.LineEnding)
|
|
401
|
+
} else {
|
|
402
|
+
final.buf.AppendString(DefaultLineEnding)
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
ret := final.buf
|
|
406
|
+
putJSONEncoder(final)
|
|
407
|
+
return ret, nil
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
func (enc *jsonEncoder) truncate() {
|
|
411
|
+
enc.buf.Reset()
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
func (enc *jsonEncoder) closeOpenNamespaces() {
|
|
415
|
+
for i := 0; i < enc.openNamespaces; i++ {
|
|
416
|
+
enc.buf.AppendByte('}')
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
func (enc *jsonEncoder) addKey(key string) {
|
|
421
|
+
enc.addElementSeparator()
|
|
422
|
+
enc.buf.AppendByte('"')
|
|
423
|
+
enc.safeAddString(key)
|
|
424
|
+
enc.buf.AppendByte('"')
|
|
425
|
+
enc.buf.AppendByte(':')
|
|
426
|
+
if enc.spaced {
|
|
427
|
+
enc.buf.AppendByte(' ')
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
func (enc *jsonEncoder) addElementSeparator() {
|
|
432
|
+
last := enc.buf.Len() - 1
|
|
433
|
+
if last < 0 {
|
|
434
|
+
return
|
|
435
|
+
}
|
|
436
|
+
switch enc.buf.Bytes()[last] {
|
|
437
|
+
case '{', '[', ':', ',', ' ':
|
|
438
|
+
return
|
|
439
|
+
default:
|
|
440
|
+
enc.buf.AppendByte(',')
|
|
441
|
+
if enc.spaced {
|
|
442
|
+
enc.buf.AppendByte(' ')
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
func (enc *jsonEncoder) appendFloat(val float64, bitSize int) {
|
|
448
|
+
enc.addElementSeparator()
|
|
449
|
+
switch {
|
|
450
|
+
case math.IsNaN(val):
|
|
451
|
+
enc.buf.AppendString(`"NaN"`)
|
|
452
|
+
case math.IsInf(val, 1):
|
|
453
|
+
enc.buf.AppendString(`"+Inf"`)
|
|
454
|
+
case math.IsInf(val, -1):
|
|
455
|
+
enc.buf.AppendString(`"-Inf"`)
|
|
456
|
+
default:
|
|
457
|
+
enc.buf.AppendFloat(val, bitSize)
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
|
|
461
|
+
// safeAddString JSON-escapes a string and appends it to the internal buffer.
|
|
462
|
+
// Unlike the standard library's encoder, it doesn't attempt to protect the
|
|
463
|
+
// user from browser vulnerabilities or JSONP-related problems.
|
|
464
|
+
func (enc *jsonEncoder) safeAddString(s string) {
|
|
465
|
+
for i := 0; i < len(s); {
|
|
466
|
+
if enc.tryAddRuneSelf(s[i]) {
|
|
467
|
+
i++
|
|
468
|
+
continue
|
|
469
|
+
}
|
|
470
|
+
r, size := utf8.DecodeRuneInString(s[i:])
|
|
471
|
+
if enc.tryAddRuneError(r, size) {
|
|
472
|
+
i++
|
|
473
|
+
continue
|
|
474
|
+
}
|
|
475
|
+
enc.buf.AppendString(s[i : i+size])
|
|
476
|
+
i += size
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
|
|
480
|
+
// safeAddByteString is no-alloc equivalent of safeAddString(string(s)) for s []byte.
|
|
481
|
+
func (enc *jsonEncoder) safeAddByteString(s []byte) {
|
|
482
|
+
for i := 0; i < len(s); {
|
|
483
|
+
if enc.tryAddRuneSelf(s[i]) {
|
|
484
|
+
i++
|
|
485
|
+
continue
|
|
486
|
+
}
|
|
487
|
+
r, size := utf8.DecodeRune(s[i:])
|
|
488
|
+
if enc.tryAddRuneError(r, size) {
|
|
489
|
+
i++
|
|
490
|
+
continue
|
|
491
|
+
}
|
|
492
|
+
enc.buf.Write(s[i : i+size])
|
|
493
|
+
i += size
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
|
|
497
|
+
// tryAddRuneSelf appends b if it is valid UTF-8 character represented in a single byte.
|
|
498
|
+
func (enc *jsonEncoder) tryAddRuneSelf(b byte) bool {
|
|
499
|
+
if b >= utf8.RuneSelf {
|
|
500
|
+
return false
|
|
501
|
+
}
|
|
502
|
+
if 0x20 <= b && b != '\\' && b != '"' {
|
|
503
|
+
enc.buf.AppendByte(b)
|
|
504
|
+
return true
|
|
505
|
+
}
|
|
506
|
+
switch b {
|
|
507
|
+
case '\\', '"':
|
|
508
|
+
enc.buf.AppendByte('\\')
|
|
509
|
+
enc.buf.AppendByte(b)
|
|
510
|
+
case '\n':
|
|
511
|
+
enc.buf.AppendByte('\\')
|
|
512
|
+
enc.buf.AppendByte('n')
|
|
513
|
+
case '\r':
|
|
514
|
+
enc.buf.AppendByte('\\')
|
|
515
|
+
enc.buf.AppendByte('r')
|
|
516
|
+
case '\t':
|
|
517
|
+
enc.buf.AppendByte('\\')
|
|
518
|
+
enc.buf.AppendByte('t')
|
|
519
|
+
default:
|
|
520
|
+
// Encode bytes < 0x20, except for the escape sequences above.
|
|
521
|
+
enc.buf.AppendString(`\u00`)
|
|
522
|
+
enc.buf.AppendByte(_hex[b>>4])
|
|
523
|
+
enc.buf.AppendByte(_hex[b&0xF])
|
|
524
|
+
}
|
|
525
|
+
return true
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
func (enc *jsonEncoder) tryAddRuneError(r rune, size int) bool {
|
|
529
|
+
if r == utf8.RuneError && size == 1 {
|
|
530
|
+
enc.buf.AppendString(`\ufffd`)
|
|
531
|
+
return true
|
|
532
|
+
}
|
|
533
|
+
return false
|
|
534
|
+
}
|