diff --git a/go.mod b/go.mod index 5aa721d..c0064bc 100644 --- a/go.mod +++ b/go.mod @@ -6,9 +6,11 @@ require ( bou.ke/monkey v1.0.2 github.com/DATA-DOG/go-sqlmock v1.5.0 // indirect github.com/centrifugal/centrifuge-go v0.6.5 // indirect + github.com/golang/protobuf v1.5.3 // indirect github.com/grafana/grafana-plugin-model v0.0.0-20200514130833-df1eb6bdf4c5 github.com/grafana/grafana-plugin-sdk-go v0.173.0 github.com/hashicorp/go-hclog v1.5.0 github.com/magefile/mage v1.15.0 // indirect github.com/vertica/vertica-sql-go v1.3.1 + google.golang.org/grpc v1.57.0 // indirect ) diff --git a/go.sum b/go.sum index b4f77c7..073adb9 100644 --- a/go.sum +++ b/go.sum @@ -790,12 +790,14 @@ github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= github.com/boombuler/barcode v1.0.1/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= +github.com/cenkalti/backoff/v4 v4.2.1 h1:y4OZtCnogmCPw98Zjyt5a6+QwPLGkiQsYW5oUqylYbM= github.com/cenkalti/backoff/v4 v4.2.1/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE= github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/census-instrumentation/opencensus-proto v0.3.0/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/census-instrumentation/opencensus-proto v0.4.1/go.mod h1:4T9NM4+4Vw91VeyqjLS6ao50K5bOcLKN6Q42XnYaRYw= github.com/centrifugal/centrifuge-go v0.6.5/go.mod h1:YW9BKhnEMOBPU7C/wfqdqzhIiF0xRd0R4sHW82a7sf8= github.com/centrifugal/protocol v0.3.4/go.mod h1:2YbBCaDwQHl37ErRdMrKSj18X2yVvpkQYtSX6aVbe5A= +github.com/cespare/xxhash v1.1.0 h1:a6HrQnmkObjyL+Gs60czilIUGqrzKutQD6XZog3p+ko= github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= github.com/cespare/xxhash/v2 v2.1.1 h1:6MnRN8NT7+YBpUIWxHtefFZOKTAPgGjpQSxqLNn0+qY= github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= @@ -859,6 +861,7 @@ github.com/envoyproxy/protoc-gen-validate v0.10.0/go.mod h1:DRjgyB0I43LtJapqN6Ni github.com/envoyproxy/protoc-gen-validate v0.10.1/go.mod h1:DRjgyB0I43LtJapqN6NiRwroiAU2PaFuvk/vjgh61ss= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= github.com/fatih/color v1.13.0/go.mod h1:kLAiJbzzSOZDVNGyDpeOxJ47H46qBXwg5ILebYFFOfk= +github.com/fatih/color v1.15.0 h1:kOqh6YHBtK8aywxGerMG2Eq3H6Qgoqeo13Bk2Mv/nBs= github.com/fatih/color v1.15.0/go.mod h1:0h5ZqXfHYED7Bhv2ZJamyIOUej9KtShiJESRwBDUSsw= github.com/fogleman/gg v1.2.1-0.20190220221249-0403632d5b90/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= github.com/fogleman/gg v1.3.0/go.mod h1:R/bRT+9gY/C5z7JzPU0zXsXHKM4/ayA+zqcVNZzPa1k= @@ -886,7 +889,9 @@ github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs= github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.2.4 h1:g01GSCwiDw2xSZfjJ2/T9M+S6pFdcNtFYsp+Y43HYDQ= github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-openapi/jsonpointer v0.19.5/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= @@ -1027,10 +1032,12 @@ github.com/grpc-ecosystem/go-grpc-middleware v1.4.0 h1:UH//fgunKIs4JdUbpDl1VZCDa github.com/grpc-ecosystem/go-grpc-middleware v1.4.0/go.mod h1:g5qyo/la0ALbONm6Vbp88Yd8NsDy6rZz+RcrMPxvld8= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 h1:Ovs26xHkKqVztRpIrF/92BcuyuQ/YW4NSIpoGtfXNho= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= +github.com/grpc-ecosystem/grpc-gateway v1.16.0 h1:gmcG1KaJ57LophUzW0Hy8NmPhnMZb4M0+kPpLofRdBo= github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= github.com/grpc-ecosystem/grpc-gateway/v2 v2.7.0/go.mod h1:hgWBS7lorOAVIJEQMi4ZsPv9hVvWI6+ch50m39Pf2Ks= github.com/grpc-ecosystem/grpc-gateway/v2 v2.11.3/go.mod h1:o//XUCC/F+yRGJoPO/VU0GSB0f8Nhgmxx0VIRUvaC0w= github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.0/go.mod h1:YN5jB8ie0yfIUg6VvR9Kz84aCaG7AsGZnLjhHbUqwPg= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.2 h1:dygLcbEBA+t/P7ck6a8AkXv6juQ4cK0RHBoh32jxhHM= github.com/grpc-ecosystem/grpc-gateway/v2 v2.16.2/go.mod h1:Ap9RLCIJVtgQg1/BBgVEfypOAySvvlcpcVQkSzJCH4Y= github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd h1:rNuUHR+CvK1IS89MMtcF0EpcVMZtjKfPRp4MEmt/aTs= github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI= @@ -1064,6 +1071,7 @@ github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCV github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= +github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU= github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk= @@ -1079,6 +1087,7 @@ github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/klauspost/asmfmt v1.3.2/go.mod h1:AG8TuvYojzulgDAMCnYn50l/5QV3Bs/tp6j0HLHbNSE= github.com/klauspost/compress v1.13.1/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8eO+e+Dq5Gzg= +github.com/klauspost/compress v1.15.9 h1:wKRjX6JRtDdrE9qwa4b/Cip7ACOshUI4smpCQanqjSY= github.com/klauspost/compress v1.15.9/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU= github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= @@ -1113,6 +1122,7 @@ github.com/mattetti/filebuffer v1.0.1/go.mod h1:YdMURNDOttIiruleeVr6f56OrMc+MydE github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= github.com/mattn/go-colorable v0.1.9/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4= +github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s= github.com/mattn/go-isatty v0.0.10/go.mod h1:qgIWMr58cqv1PHHyhnkY9lrL7etaEgOFcMEpPG5Rm84= @@ -1120,6 +1130,7 @@ github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Ky github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= +github.com/mattn/go-isatty v0.0.18 h1:DOKFKCQ7FNG2L1rbrmstDN4QVRdS89Nkh85u68Uwp98= github.com/mattn/go-isatty v0.0.18/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mattn/go-runewidth v0.0.7 h1:Ei8KR0497xHyKJPAv59M1dkC+rOZCMBJ+t3fZ+twI54= github.com/mattn/go-runewidth v0.0.7/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI= @@ -1142,9 +1153,11 @@ github.com/mitchellh/reflectwalk v1.0.1/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= +github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826/go.mod h1:TaXosZuwdSHYgviHp1DAtfrULt5eUgsSMsZf+YrPgl8= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= @@ -1163,6 +1176,7 @@ github.com/phpdave11/gofpdf v1.4.2/go.mod h1:zpO6xFn9yxo3YLyMvW8HcKWVdbNqgIfOOp2 github.com/phpdave11/gofpdi v1.0.12/go.mod h1:vBmVV0Do6hSBHC8uKUQ71JGW+ZGQq74llk/7bXwjDoI= github.com/phpdave11/gofpdi v1.0.13/go.mod h1:vBmVV0Do6hSBHC8uKUQ71JGW+ZGQq74llk/7bXwjDoI= github.com/pierrec/lz4/v4 v4.1.8/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= +github.com/pierrec/lz4/v4 v4.1.15 h1:MO0/ucJhngq7299dKLwIMtgTfbkoSPF6AoMYDd8Q4q0= github.com/pierrec/lz4/v4 v4.1.15/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= @@ -1280,19 +1294,30 @@ go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E= go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.42.0 h1:ZOLJc06r4CB42laIXg/7udr0pbZyuAihN10A/XuiQRY= go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.42.0/go.mod h1:5z+/ZWJQKXa9YT34fQNx5K8Hd1EoIhvtUygUQPqEOgQ= +go.opentelemetry.io/contrib/instrumentation/net/http/httptrace/otelhttptrace v0.42.0 h1:0vzgiFDsCh/jxRCR1xcRrtMoeCu2itXz/PsXst5P8rI= go.opentelemetry.io/contrib/instrumentation/net/http/httptrace/otelhttptrace v0.42.0/go.mod h1:y0vOY2OKFMOTvwxKfurStPayUUKGHlNeVqNneHmFXr0= +go.opentelemetry.io/contrib/propagators/jaeger v1.17.0 h1:Zbpbmwav32Ea5jSotpmkWEl3a6Xvd4tw/3xxGO1i05Y= go.opentelemetry.io/contrib/propagators/jaeger v1.17.0/go.mod h1:tcTUAlmO8nuInPDSBVfG+CP6Mzjy5+gNV4mPxMbL0IA= +go.opentelemetry.io/otel v1.16.0 h1:Z7GVAX/UkAXPKsy94IU+i6thsQS4nb7LviLpnaNeW8s= go.opentelemetry.io/otel v1.16.0/go.mod h1:vl0h9NUa1D5s1nv3A5vZOYWn8av4K8Ml6JDeHrT/bx4= +go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.16.0 h1:t4ZwRPU+emrcvM2e9DHd0Fsf0JTPVcbfa/BhTDF03d0= go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.16.0/go.mod h1:vLarbg68dH2Wa77g71zmKQqlQ8+8Rq3GRG31uc0WcWI= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.16.0 h1:cbsD4cUcviQGXdw8+bo5x2wazq10SKz8hEbtCRPcU78= go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.16.0/go.mod h1:JgXSGah17croqhJfhByOLVY719k1emAXC8MVhCIJlRs= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.16.0 h1:TVQp/bboR4mhZSav+MdgXB8FaRho1RC8UwVn3T0vjVc= go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.16.0/go.mod h1:I33vtIe0sR96wfrUcilIzLoA3mLHhRmz9S9Te0S3gDo= +go.opentelemetry.io/otel/metric v1.16.0 h1:RbrpwVG1Hfv85LgnZ7+txXioPDoh6EdbZHo26Q3hqOo= go.opentelemetry.io/otel/metric v1.16.0/go.mod h1:QE47cpOmkwipPiefDwo2wDzwJrlfxxNYodqc4xnGCo4= +go.opentelemetry.io/otel/sdk v1.16.0 h1:Z1Ok1YsijYL0CSJpHt4cS3wDDh7p572grzNrBMiMWgE= go.opentelemetry.io/otel/sdk v1.16.0/go.mod h1:tMsIuKXuuIWPBAOrH+eHtvhTL+SntFtXF9QD68aP6p4= +go.opentelemetry.io/otel/trace v1.16.0 h1:8JRpaObFoW0pxuVPapkgH8UhHQj+bJW8jJsCZEu5MQs= go.opentelemetry.io/otel/trace v1.16.0/go.mod h1:Yt9vYq1SdNz3xdjZZK7wcXv1qv2pwLkqr2QVwea0ef0= go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= go.opentelemetry.io/proto/otlp v0.15.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= +go.opentelemetry.io/proto/otlp v1.0.0 h1:T0TX0tmXU8a3CbNXzEKGeU5mIVOdf0oykP+u2lIVU/I= go.opentelemetry.io/proto/otlp v1.0.0/go.mod h1:Sy6pihPLfYHkr3NkUbEhGHFhINUSI/v80hjKIs5JXpM= go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= @@ -1935,6 +1960,7 @@ google.golang.org/genproto/googleapis/api v0.0.0-20230530153820-e85fd2cbaebc/go. google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig= google.golang.org/genproto/googleapis/api v0.0.0-20230706204954-ccb25ca9f130/go.mod h1:mPBs5jNgx2GuQGvFwUvVKqtn6HsUw9nP64BedgvqEsQ= google.golang.org/genproto/googleapis/api v0.0.0-20230726155614-23370e0ffb3e/go.mod h1:rsr7RhLuwsDKL7RmgDDCUc6yaGr1iqceVb5Wv6f6YvQ= +google.golang.org/genproto/googleapis/api v0.0.0-20230731193218-e0aa005b6bdf h1:xkVZ5FdZJF4U82Q/JS+DcZA83s/GRVL+QrFMlexk9Yo= google.golang.org/genproto/googleapis/api v0.0.0-20230731193218-e0aa005b6bdf/go.mod h1:5DZzOUPCLYL3mNkQ0ms0F3EuUNZ7py1Bqeq6sxzI7/Q= google.golang.org/genproto/googleapis/bytestream v0.0.0-20230530153820-e85fd2cbaebc/go.mod h1:ylj+BE99M198VPbBh6A8d9n3w8fChvyLK3wwBOjXBFA= google.golang.org/genproto/googleapis/rpc v0.0.0-20230525234015-3fc162c6f38a/go.mod h1:xURIpW9ES5+/GZhnV6beoEtxQrnkRGIfP5VQG2tCBLc= @@ -1945,6 +1971,7 @@ google.golang.org/genproto/googleapis/rpc v0.0.0-20230629202037-9506855d4529/go. google.golang.org/genproto/googleapis/rpc v0.0.0-20230706204954-ccb25ca9f130/go.mod h1:8mL13HKkDa+IuJ8yruA3ci0q+0vsUz4m//+ottjwS5o= google.golang.org/genproto/googleapis/rpc v0.0.0-20230726155614-23370e0ffb3e/go.mod h1:TUfxEVdsvPg18p6AslUXFoLdpED4oBnGwyqk3dV1XzM= google.golang.org/genproto/googleapis/rpc v0.0.0-20230731190214-cbb8c96f2d6d/go.mod h1:TUfxEVdsvPg18p6AslUXFoLdpED4oBnGwyqk3dV1XzM= +google.golang.org/genproto/googleapis/rpc v0.0.0-20230731193218-e0aa005b6bdf h1:guOdSPaeFgN+jEJwTo1dQ71hdBm+yKSCCKuTRkJzcVo= google.golang.org/genproto/googleapis/rpc v0.0.0-20230731193218-e0aa005b6bdf/go.mod h1:zBEcrKX2ZOcEkHWxBPAIvYUWOKKMIhYcmNiUIu2ji3I= google.golang.org/grpc v1.8.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw= google.golang.org/grpc v1.14.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw= @@ -2012,6 +2039,7 @@ google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqw google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8= google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= diff --git a/package.json b/package.json index 504f7aa..c00131a 100644 --- a/package.json +++ b/package.json @@ -19,59 +19,59 @@ "author": "Opentext", "license": "Apache-2.0", "devDependencies": { - "@babel/core": "^7.21.4", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/preset-typescript": "^7.13.0", - "@grafana/e2e": "9.5.3", - "@grafana/e2e-selectors": "9.5.3", - "@grafana/eslint-config": "^6.0.0", - "@grafana/experimental": "^1.1.0", - "@grafana/tsconfig": "^1.2.0-rc1", - "@swc/core": "^1.3.62", - "@swc/helpers": "^0.5.0", - "@swc/jest": "^0.2.26", - "@testing-library/jest-dom": "^5.16.5", - "@testing-library/react": "^12.1.4", - "@types/enzyme": "3.10.5", + "@babel/core": "^7.22.20", + "@babel/helper-compilation-targets": "^7.22.15", + "@babel/preset-typescript": "^7.22.15", + "@grafana/e2e": "10.1.2", + "@grafana/e2e-selectors": "10.1.2", + "@grafana/eslint-config": "^6.0.1", + "@grafana/experimental": "^1.7.2", + "@grafana/tsconfig": "^1.3.0-rc1", + "@swc/core": "^1.3.87", + "@swc/helpers": "^0.5.2", + "@swc/jest": "^0.2.29", + "@testing-library/jest-dom": "^6.1.3", + "@testing-library/react": "^14.0.0", + "@types/enzyme": "3.10.13", "@types/enzyme-adapter-react-16": "^1.0.6", - "@types/jest": "^29.5.0", - "@types/lodash": "^4.14.194", - "@types/node": "^18.15.11", - "@typescript-eslint/eslint-plugin": "^4.22.1", - "@typescript-eslint/parser": "^4.22.1", + "@types/jest": "^29.5.5", + "@types/lodash": "^4.14.198", + "@types/node": "^20.6.3", + "@typescript-eslint/eslint-plugin": "^6.7.2", + "@typescript-eslint/parser": "^6.7.2", "copy-webpack-plugin": "^11.0.0", "css-loader": "^6.7.3", "enzyme": "3.11.0", - "enzyme-adapter-react-16": "^1.15.6", + "enzyme-adapter-react-16": "^1.15.7", "enzyme-to-json": "^3.3.4", - "eslint": "^7.25.0", - "eslint-config-prettier": "^8.3.0", - "eslint-plugin-jsdoc": "^35.0.0", - "eslint-plugin-lodash": "^7.2.0", - "eslint-plugin-no-only-tests": "^2.6.0", - "eslint-plugin-prettier": "^3.4.0", - "eslint-plugin-react": "^7.23.2", - "eslint-plugin-react-hooks": "^4.2.0", + "eslint": "^8.49.0", + "eslint-config-prettier": "^9.0.0", + "eslint-plugin-jsdoc": "^46.8.2", + "eslint-plugin-lodash": "^7.4.0", + "eslint-plugin-no-only-tests": "^3.1.0", + "eslint-plugin-prettier": "^5.0.0", + "eslint-plugin-react": "^7.33.2", + "eslint-plugin-react-hooks": "^4.6.0", "eslint-webpack-plugin": "^4.0.1", "fork-ts-checker-webpack-plugin": "^8.0.0", - "glob": "^10.2.7", + "glob": "^10.3.5", "identity-obj-proxy": "3.0.0", - "jest": "^29.5.0", - "jest-environment-jsdom": "^29.5.0", - "jest-expo": "~27.0.1", + "jest": "^29.7.0", + "jest-environment-jsdom": "^29.7.0", + "jest-expo": "~49.0.0", "jest-serializer-enzyme": "^1.0.0", - "prettier": "^2.8.7", + "prettier": "^3.0.3", "react-autosuggest": "^10.1.0", "replace-in-file-webpack-plugin": "^1.0.6", - "sass": "1.63.2", - "sass-loader": "13.3.1", + "sass": "1.68.0", + "sass-loader": "13.3.2", "style-loader": "3.3.3", "swc-loader": "^0.2.3", - "ts-jest": "26.4.4", + "ts-jest": "29.1.1", "ts-node": "^10.9.1", "tsconfig-paths": "^4.2.0", "tslib": "2.5.3", - "typescript": "4.8.4", + "typescript": "5.2.2", "webpack": "^5.86.0", "webpack-cli": "^5.1.4", "webpack-livereload-plugin": "^3.0.2" @@ -84,23 +84,23 @@ }, "dependencies": { "@emotion/css": "^11.1.3", - "@grafana/data": "9.5.3", - "@grafana/runtime": "7.5.8", - "@grafana/ui": "7.5.8", + "@grafana/data": "10.1.2", + "@grafana/runtime": "10.1.2", + "@grafana/ui": "10.1.2", "@types/react-autosuggest": "^10.1.6", "@types/react-virtualized-auto-sizer": "^1.0.1", - "ace-builds": "^1.15.2", + "ace-builds": "^1.27.0", "brace": "^0.11.1", "grafana-data": "^2.0.1", - "react": "17.0.2", + "react": "18.2.0", "react-ace": "^10.1.0", "react-autosuggest": "^10.1.0", - "react-awesome-query-builder": "^5.4.1", - "react-dom": "17.0.2", - "react-monaco-editor": "^0.51.0", + "react-awesome-query-builder": "^5.4.2", + "react-dom": "18.2.0", + "react-monaco-editor": "^0.54.0", "react-use": "^17.4.0", - "react-virtualized-auto-sizer": "^1.0.7", - "tslib": "2.5.3", + "react-virtualized-auto-sizer": "^1.0.20", + "tslib": "2.6.2", "yarn": "^1.22.19" }, "packageManager": "yarn@1.22.19" diff --git a/pkg/datasource.go b/pkg/datasource.go index 169e046..b809821 100644 --- a/pkg/datasource.go +++ b/pkg/datasource.go @@ -75,7 +75,7 @@ type VerticaDatasource struct { // GetVerticaDb will return the vertica db connection // stored in the instance setting when the instance is created or update func (v *VerticaDatasource) GetVerticaDb(pluginContext backend.PluginContext) (*sql.DB, error) { - instance, err := v.im.Get(pluginContext) + instance, err := v.im.Get(context.Background(), pluginContext) if err != nil { @@ -86,8 +86,6 @@ func (v *VerticaDatasource) GetVerticaDb(pluginContext backend.PluginContext) (* return instanceSetting.Db, nil } return nil, nil //this is added to avoid syntax error but this line will never gets executed - return nil, nil //this is added to avoid syntax error but this line will never gets executed - } type configArgs struct { diff --git a/src/ConfigEditor.test.tsx b/src/ConfigEditor.test.tsx index 20ca75c..ec9d48e 100644 --- a/src/ConfigEditor.test.tsx +++ b/src/ConfigEditor.test.tsx @@ -7,6 +7,7 @@ import Adapter from 'enzyme-adapter-react-16'; configure({ adapter: new Adapter() }); // setting up the props verifying Rendering of config screen const setup = (propOverrides?: object) => { + const props: Props = { options: { id: 11, @@ -17,12 +18,10 @@ const setup = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -42,6 +41,7 @@ const setup = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -60,12 +60,10 @@ const setupForHostname = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -85,6 +83,7 @@ const setupForHostname = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -103,12 +102,10 @@ const setupForDatabasename = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -129,6 +126,7 @@ const setupForDatabasename = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -147,12 +145,10 @@ const setupForUsername = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -173,6 +169,7 @@ const setupForUsername = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -191,12 +188,10 @@ const setupForPassword = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -216,6 +211,7 @@ const setupForPassword = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -234,12 +230,10 @@ const setupForSSLMode = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -259,6 +253,7 @@ const setupForSSLMode = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -315,12 +310,10 @@ const setupForVerticaConnections = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -340,6 +333,7 @@ const setupForVerticaConnections = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -359,12 +353,10 @@ const setUpBackUpServerNode = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -384,6 +376,7 @@ const setUpBackUpServerNode = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; @@ -403,12 +396,10 @@ const setUpUseBackServer = (propOverrides?: object) => { typeLogoUrl: '', access: 'proxy', url: '', - password: '', user: '', database: '', basicAuth: false, basicAuthUser: '', - basicAuthPassword: '', withCredentials: false, isDefault: false, jsonData: { @@ -428,6 +419,7 @@ const setUpUseBackServer = (propOverrides?: object) => { }, version: 3, readOnly: false, + uid: '' }, onOptionsChange: jest.fn(), }; diff --git a/src/PartListSection.tsx b/src/PartListSection.tsx index d33dc13..98b4136 100644 --- a/src/PartListSection.tsx +++ b/src/PartListSection.tsx @@ -5,12 +5,15 @@ import { toSelectableValue } from './toSelectableValue'; import { AddButton } from './AddButton'; import { unwrap } from './unwrap'; +// eslint-disable-next-line @typescript-eslint/array-type export type PartParams = Array<{ value: string; options: (() => Promise>) | null; }>; + type Props = { + // eslint-disable-next-line @typescript-eslint/array-type parts: Array<{ name: string; params: PartParams; @@ -133,7 +136,7 @@ const Part = ({ name, params, onChange, onRemove }: PartProps): JSX.Element => { > ( {params.map((p, i) => { - const results = new Promise>>((resolve) => resolve([])); + const results = new Promise[]>((resolve) => resolve([])); const { value, options } = p; const isLast = i === params.length - 1; const loadOptions = diff --git a/src/QueryEditor.tsx b/src/QueryEditor.tsx index 618d17f..6c4ca80 100644 --- a/src/QueryEditor.tsx +++ b/src/QueryEditor.tsx @@ -204,7 +204,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const label = type.split('|')[0]; const value = type.split('|')[1]; const partType = type.split('|')[2]; - let defaultParams: Array = []; + let defaultParams: any[] = []; switch (value) { case 'column': defaultParams = ['value']; @@ -292,7 +292,7 @@ export const QueryEditor = (props: Props): JSX.Element => { // handler when WHERE section part is added const handleWhereParamsAdd = (type: string) => { const clonedQuery = cloneDeep(query); - let defaultParams: Array = []; + let defaultParams: any[] = []; let partName = ''; switch (type) { case 'macro': @@ -338,7 +338,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const handleGroupParamsAdd = (type: string, data: any = { label: '', value: '', type: '' }) => { // const clonedQuery = cloneDeep(query); const clonedQuery = cloneDeep(query); - let defaultParams: Array = []; + let defaultParams: any[] = []; let partName = ''; switch (type) { case 'time': @@ -374,7 +374,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const getSchemaOptions = () => { const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildSchemaQuery()); const result = response.map((res: any) => { @@ -389,7 +389,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const getTableOptions = () => { const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildTableQuery()); const result = response.map((res: any) => { @@ -404,7 +404,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const getTimeColumnOptions = () => { const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise[]>((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildColumnQuery('time')); const result = response.map((res: any) => { @@ -419,7 +419,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const getMetricColumnOptions = () => { const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise[]>((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildColumnQuery('metric')); const result = response.map((res: any) => { @@ -434,7 +434,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const getColumnOptions = useCallback(async () => { const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildColumnQuery('value')); const result = response.map((res: any) => { @@ -447,7 +447,7 @@ export const QueryEditor = (props: Props): JSX.Element => { // method to fetch all the columns selected in the SELECT section and TIME section const getSelectedColumnOptions = useCallback(() => { - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(() => { const result: any = []; result.push(query.timeColumn); @@ -466,7 +466,7 @@ export const QueryEditor = (props: Props): JSX.Element => { // method to fetch all the group columns for the selected table const getGroupByOptions = () => { const queryModel = new QueryModel(query, getTemplateSrv()); - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(async () => { const response = await getSelectedColumnOptions(); const options = []; @@ -486,7 +486,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const { datasource } = props; const queryModel = new QueryModel(query, getTemplateSrv()); const metaBuilder = new MetaQuery(query, queryModel); - return new Promise>>((resolve) => { + return new Promise((resolve) => { setTimeout(async () => { const response = await datasource.metricFindQuery(metaBuilder.buildColumnQuery('')); const result = response.map((res: any) => { @@ -504,7 +504,7 @@ export const QueryEditor = (props: Props): JSX.Element => { query.select.map((item) => { const data: any = []; item.map((row) => { - const params: Array<{ value: string; options: (() => Promise>) | null }> = []; + const params: any[] = []; row.params.map((param, paramIndex) => { if (row.type === 'column') { params.push({ @@ -555,7 +555,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const whereParts = useMemo(() => { const results: any = []; query.where?.map((part) => { - const params: Array<{ value: string; options: (() => Promise>) | null }> = []; + const params: any[] = []; let partName = ''; part.params.map((param, index) => { if (part.type === 'expression') { @@ -600,7 +600,7 @@ export const QueryEditor = (props: Props): JSX.Element => { const results: any = []; query.group && query.group.map((part) => { - const params: Array<{ value: string; options: (() => Promise>) | null }> = []; + const params: any[] = []; let partName = ''; part.params.map((param, index) => { if (part.type === 'time') { @@ -670,10 +670,8 @@ export const QueryEditor = (props: Props): JSX.Element => { enableSnippets: true, }} value={queryValue} - portalOrigin="vertica" readOnly={hide} onBlur={onBlur} - onRunQuery={onRunQuery} onChange={onQueryTextChange} /> diff --git a/src/datasource.ts b/src/datasource.ts index 42fa28c..b402990 100644 --- a/src/datasource.ts +++ b/src/datasource.ts @@ -87,7 +87,7 @@ export class DataSource extends DataSourceWithBackend; name?: string; } @@ -22,8 +23,10 @@ export interface MyQuery extends DataQuery { rawSql?: string; queryText?: string; hide: boolean; + } +// eslint-disable-next-line @typescript-eslint/array-type export type PartParams = Array<{ value: string; options: (() => Promise>) | null; diff --git a/webpack.config.ts b/webpack.config.ts index 7f5d535..a5ebd4a 100644 --- a/webpack.config.ts +++ b/webpack.config.ts @@ -14,4 +14,4 @@ const config = async (env): Promise => { }); }; -export default config; \ No newline at end of file +export default config;