From 24afc6306e31182aca2f422087da149b47ae13d0 Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 27 Nov 2023 18:06:06 +0000 Subject: [PATCH 01/12] Adding enclave restricted flags --- dockerfiles/enclave.Dockerfile | 23 +- go.sum | 299 -------------------------- go/common/flag/flag.go | 168 +++++++++++++++ go/common/flag/flag_test.go | 68 ++++++ go/enclave/container/cli.go | 76 ++----- go/enclave/container/cli_test.go | 95 -------- go/enclave/container/test.toml | 15 -- go/enclave/main/enclave-test.json | 23 ++ go/enclave/main/enclave.json | 30 +++ testnet/docker-compose.local.yml | 2 + testnet/testnet-local-build_images.sh | 2 +- 11 files changed, 328 insertions(+), 473 deletions(-) create mode 100644 go/common/flag/flag.go create mode 100644 go/common/flag/flag_test.go delete mode 100644 go/enclave/container/cli_test.go delete mode 100644 go/enclave/container/test.toml create mode 100644 go/enclave/main/enclave-test.json diff --git a/dockerfiles/enclave.Dockerfile b/dockerfiles/enclave.Dockerfile index 0dbbf2c675..26b452c760 100644 --- a/dockerfiles/enclave.Dockerfile +++ b/dockerfiles/enclave.Dockerfile @@ -4,6 +4,13 @@ # deploy = copies over only the enclave executable without the source # in a lightweight base image specialized for deployment and prepares the /data/ folder. +# Final container folder structure: +# /home/obscuro/data contains working files for the enclave +# /home/obscuro/go-obscuro/go/enclave/main contains the executable for the enclave +# + +ARG RESTRICTEDMODE + FROM ghcr.io/edgelesssys/ego-dev:v1.3.0 AS build-base # setup container data structure @@ -26,13 +33,19 @@ WORKDIR /home/obscuro/go-obscuro/go/enclave/main RUN --mount=type=cache,target=/root/.cache/go-build \ ego-go build +# New build stage for compiling the enclave with restricted flags mode +FROM build-enclave as build-enclave-restrictedmode-true # Sign the enclave executable -RUN ego sign main +RUN ego sign enclave.json + +# New build stage for compiling the enclave without restricted flags mode +FROM build-enclave as build-enclave-restrictedmode-false +# Sign the enclave executable +RUN ego sign enclave-test.json + +# Tag the restricted mode as the current build +FROM build-enclave-restrictedmode-${RESTRICTEDMODE} as build-enclave -# Final container folder structure: -# /home/obscuro/data contains working files for the enclave -# /home/obscuro/go-obscuro/go/enclave/main contains the executable for the enclave -# # Trigger a new build stage and use the smaller ego version: FROM ghcr.io/edgelesssys/ego-deploy:v1.3.0 diff --git a/go.sum b/go.sum index d789698b79..2a2657a0c5 100644 --- a/go.sum +++ b/go.sum @@ -1,151 +1,19 @@ cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= -cloud.google.com/go v0.110.0/go.mod h1:SJnCLqQ0FCFGSZMUNUf84MV3Aia54kn7pi8st7tMzaY= -cloud.google.com/go/accessapproval v1.6.0/go.mod h1:R0EiYnwV5fsRFiKZkPHr6mwyk2wxUJ30nL4j2pcFY2E= -cloud.google.com/go/accesscontextmanager v1.6.0/go.mod h1:8XCvZWfYw3K/ji0iVnp+6pu7huxoQTLmxAbVjbloTtM= -cloud.google.com/go/aiplatform v1.35.0/go.mod h1:7MFT/vCaOyZT/4IIFfxH4ErVg/4ku6lKv3w0+tFTgXQ= -cloud.google.com/go/analytics v0.18.0/go.mod h1:ZkeHGQlcIPkw0R/GW+boWHhCOR43xz9RN/jn7WcqfIE= -cloud.google.com/go/apigateway v1.5.0/go.mod h1:GpnZR3Q4rR7LVu5951qfXPJCHquZt02jf7xQx7kpqN8= -cloud.google.com/go/apigeeconnect v1.5.0/go.mod h1:KFaCqvBRU6idyhSNyn3vlHXc8VMDJdRmwDF6JyFRqZ8= -cloud.google.com/go/apigeeregistry v0.5.0/go.mod h1:YR5+s0BVNZfVOUkMa5pAR2xGd0A473vA5M7j247o1wM= -cloud.google.com/go/apikeys v0.5.0/go.mod h1:5aQfwY4D+ewMMWScd3hm2en3hCj+BROlyrt3ytS7KLI= -cloud.google.com/go/appengine v1.6.0/go.mod h1:hg6i0J/BD2cKmDJbaFSYHFyZkgBEfQrDg/X0V5fJn84= -cloud.google.com/go/area120 v0.7.1/go.mod h1:j84i4E1RboTWjKtZVWXPqvK5VHQFJRF2c1Nm69pWm9k= -cloud.google.com/go/artifactregistry v1.11.2/go.mod h1:nLZns771ZGAwVLzTX/7Al6R9ehma4WUEhZGWV6CeQNQ= -cloud.google.com/go/asset v1.11.1/go.mod h1:fSwLhbRvC9p9CXQHJ3BgFeQNM4c9x10lqlrdEUYXlJo= -cloud.google.com/go/assuredworkloads v1.10.0/go.mod h1:kwdUQuXcedVdsIaKgKTp9t0UJkE5+PAVNhdQm4ZVq2E= -cloud.google.com/go/automl v1.12.0/go.mod h1:tWDcHDp86aMIuHmyvjuKeeHEGq76lD7ZqfGLN6B0NuU= -cloud.google.com/go/baremetalsolution v0.5.0/go.mod h1:dXGxEkmR9BMwxhzBhV0AioD0ULBmuLZI8CdwalUxuss= -cloud.google.com/go/batch v0.7.0/go.mod h1:vLZN95s6teRUqRQ4s3RLDsH8PvboqBK+rn1oevL159g= -cloud.google.com/go/beyondcorp v0.4.0/go.mod h1:3ApA0mbhHx6YImmuubf5pyW8srKnCEPON32/5hj+RmM= -cloud.google.com/go/bigquery v1.48.0/go.mod h1:QAwSz+ipNgfL5jxiaK7weyOhzdoAy1zFm0Nf1fysJac= -cloud.google.com/go/billing v1.12.0/go.mod h1:yKrZio/eu+okO/2McZEbch17O5CB5NpZhhXG6Z766ss= -cloud.google.com/go/binaryauthorization v1.5.0/go.mod h1:OSe4OU1nN/VswXKRBmciKpo9LulY41gch5c68htf3/Q= -cloud.google.com/go/certificatemanager v1.6.0/go.mod h1:3Hh64rCKjRAX8dXgRAyOcY5vQ/fE1sh8o+Mdd6KPgY8= -cloud.google.com/go/channel v1.11.0/go.mod h1:IdtI0uWGqhEeatSB62VOoJ8FSUhJ9/+iGkJVqp74CGE= -cloud.google.com/go/cloudbuild v1.7.0/go.mod h1:zb5tWh2XI6lR9zQmsm1VRA+7OCuve5d8S+zJUul8KTg= -cloud.google.com/go/clouddms v1.5.0/go.mod h1:QSxQnhikCLUw13iAbffF2CZxAER3xDGNHjsTAkQJcQA= -cloud.google.com/go/cloudtasks v1.9.0/go.mod h1:w+EyLsVkLWHcOaqNEyvcKAsWp9p29dL6uL9Nst1cI7Y= -cloud.google.com/go/compute v1.18.0/go.mod h1:1X7yHxec2Ga+Ss6jPyjxRxpu2uu7PLgsOVXvgU0yacs= -cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA= -cloud.google.com/go/contactcenterinsights v1.6.0/go.mod h1:IIDlT6CLcDoyv79kDv8iWxMSTZhLxSCofVV5W6YFM/w= -cloud.google.com/go/container v1.13.1/go.mod h1:6wgbMPeQRw9rSnKBCAJXnds3Pzj03C4JHamr8asWKy4= -cloud.google.com/go/containeranalysis v0.7.0/go.mod h1:9aUL+/vZ55P2CXfuZjS4UjQ9AgXoSw8Ts6lemfmxBxI= -cloud.google.com/go/datacatalog v1.12.0/go.mod h1:CWae8rFkfp6LzLumKOnmVh4+Zle4A3NXLzVJ1d1mRm0= -cloud.google.com/go/dataflow v0.8.0/go.mod h1:Rcf5YgTKPtQyYz8bLYhFoIV/vP39eL7fWNcSOyFfLJE= -cloud.google.com/go/dataform v0.6.0/go.mod h1:QPflImQy33e29VuapFdf19oPbE4aYTJxr31OAPV+ulA= -cloud.google.com/go/datafusion v1.6.0/go.mod h1:WBsMF8F1RhSXvVM8rCV3AeyWVxcC2xY6vith3iw3S+8= -cloud.google.com/go/datalabeling v0.7.0/go.mod h1:WPQb1y08RJbmpM3ww0CSUAGweL0SxByuW2E+FU+wXcM= -cloud.google.com/go/dataplex v1.5.2/go.mod h1:cVMgQHsmfRoI5KFYq4JtIBEUbYwc3c7tXmIDhRmNNVQ= -cloud.google.com/go/dataproc v1.12.0/go.mod h1:zrF3aX0uV3ikkMz6z4uBbIKyhRITnxvr4i3IjKsKrw4= -cloud.google.com/go/dataqna v0.7.0/go.mod h1:Lx9OcIIeqCrw1a6KdO3/5KMP1wAmTc0slZWwP12Qq3c= -cloud.google.com/go/datastore v1.10.0/go.mod h1:PC5UzAmDEkAmkfaknstTYbNpgE49HAgW2J1gcgUfmdM= -cloud.google.com/go/datastream v1.6.0/go.mod h1:6LQSuswqLa7S4rPAOZFVjHIG3wJIjZcZrw8JDEDJuIs= -cloud.google.com/go/deploy v1.6.0/go.mod h1:f9PTHehG/DjCom3QH0cntOVRm93uGBDt2vKzAPwpXQI= -cloud.google.com/go/dialogflow v1.31.0/go.mod h1:cuoUccuL1Z+HADhyIA7dci3N5zUssgpBJmCzI6fNRB4= -cloud.google.com/go/dlp v1.9.0/go.mod h1:qdgmqgTyReTz5/YNSSuueR8pl7hO0o9bQ39ZhtgkWp4= -cloud.google.com/go/documentai v1.16.0/go.mod h1:o0o0DLTEZ+YnJZ+J4wNfTxmDVyrkzFvttBXXtYRMHkM= -cloud.google.com/go/domains v0.8.0/go.mod h1:M9i3MMDzGFXsydri9/vW+EWz9sWb4I6WyHqdlAk0idE= -cloud.google.com/go/edgecontainer v0.3.0/go.mod h1:FLDpP4nykgwwIfcLt6zInhprzw0lEi2P1fjO6Ie0qbc= -cloud.google.com/go/errorreporting v0.3.0/go.mod h1:xsP2yaAp+OAW4OIm60An2bbLpqIhKXdWR/tawvl7QzU= -cloud.google.com/go/essentialcontacts v1.5.0/go.mod h1:ay29Z4zODTuwliK7SnX8E86aUF2CTzdNtvv42niCX0M= -cloud.google.com/go/eventarc v1.10.0/go.mod h1:u3R35tmZ9HvswGRBnF48IlYgYeBcPUCjkr4BTdem2Kw= -cloud.google.com/go/filestore v1.5.0/go.mod h1:FqBXDWBp4YLHqRnVGveOkHDf8svj9r5+mUDLupOWEDs= -cloud.google.com/go/firestore v1.9.0/go.mod h1:HMkjKHNTtRyZNiMzu7YAsLr9K3X2udY2AMwDaMEQiiE= -cloud.google.com/go/functions v1.10.0/go.mod h1:0D3hEOe3DbEvCXtYOZHQZmD+SzYsi1YbI7dGvHfldXw= -cloud.google.com/go/gaming v1.9.0/go.mod h1:Fc7kEmCObylSWLO334NcO+O9QMDyz+TKC4v1D7X+Bc0= -cloud.google.com/go/gkebackup v0.4.0/go.mod h1:byAyBGUwYGEEww7xsbnUTBHIYcOPy/PgUWUtOeRm9Vg= -cloud.google.com/go/gkeconnect v0.7.0/go.mod h1:SNfmVqPkaEi3bF/B3CNZOAYPYdg7sU+obZ+QTky2Myw= -cloud.google.com/go/gkehub v0.11.0/go.mod h1:JOWHlmN+GHyIbuWQPl47/C2RFhnFKH38jH9Ascu3n0E= -cloud.google.com/go/gkemulticloud v0.5.0/go.mod h1:W0JDkiyi3Tqh0TJr//y19wyb1yf8llHVto2Htf2Ja3Y= -cloud.google.com/go/gsuiteaddons v1.5.0/go.mod h1:TFCClYLd64Eaa12sFVmUyG62tk4mdIsI7pAnSXRkcFo= -cloud.google.com/go/iam v0.12.0/go.mod h1:knyHGviacl11zrtZUoDuYpDgLjvr28sLQaG0YB2GYAY= -cloud.google.com/go/iap v1.6.0/go.mod h1:NSuvI9C/j7UdjGjIde7t7HBz+QTwBcapPE07+sSRcLk= -cloud.google.com/go/ids v1.3.0/go.mod h1:JBdTYwANikFKaDP6LtW5JAi4gubs57SVNQjemdt6xV4= -cloud.google.com/go/iot v1.5.0/go.mod h1:mpz5259PDl3XJthEmh9+ap0affn/MqNSP4My77Qql9o= -cloud.google.com/go/kms v1.9.0/go.mod h1:qb1tPTgfF9RQP8e1wq4cLFErVuTJv7UsSC915J8dh3w= -cloud.google.com/go/language v1.9.0/go.mod h1:Ns15WooPM5Ad/5no/0n81yUetis74g3zrbeJBE+ptUY= -cloud.google.com/go/lifesciences v0.8.0/go.mod h1:lFxiEOMqII6XggGbOnKiyZ7IBwoIqA84ClvoezaA/bo= -cloud.google.com/go/logging v1.7.0/go.mod h1:3xjP2CjkM3ZkO73aj4ASA5wRPGGCRrPIAeNqVNkzY8M= -cloud.google.com/go/longrunning v0.4.1/go.mod h1:4iWDqhBZ70CvZ6BfETbvam3T8FMvLK+eFj0E6AaRQTo= -cloud.google.com/go/managedidentities v1.5.0/go.mod h1:+dWcZ0JlUmpuxpIDfyP5pP5y0bLdRwOS4Lp7gMni/LA= -cloud.google.com/go/maps v0.6.0/go.mod h1:o6DAMMfb+aINHz/p/jbcY+mYeXBoZoxTfdSQ8VAJaCw= -cloud.google.com/go/mediatranslation v0.7.0/go.mod h1:LCnB/gZr90ONOIQLgSXagp8XUW1ODs2UmUMvcgMfI2I= -cloud.google.com/go/memcache v1.9.0/go.mod h1:8oEyzXCu+zo9RzlEaEjHl4KkgjlNDaXbCQeQWlzNFJM= -cloud.google.com/go/metastore v1.10.0/go.mod h1:fPEnH3g4JJAk+gMRnrAnoqyv2lpUCqJPWOodSaf45Eo= -cloud.google.com/go/monitoring v1.12.0/go.mod h1:yx8Jj2fZNEkL/GYZyTLS4ZtZEZN8WtDEiEqG4kLK50w= -cloud.google.com/go/networkconnectivity v1.10.0/go.mod h1:UP4O4sWXJG13AqrTdQCD9TnLGEbtNRqjuaaA7bNjF5E= -cloud.google.com/go/networkmanagement v1.6.0/go.mod h1:5pKPqyXjB/sgtvB5xqOemumoQNB7y95Q7S+4rjSOPYY= -cloud.google.com/go/networksecurity v0.7.0/go.mod h1:mAnzoxx/8TBSyXEeESMy9OOYwo1v+gZ5eMRnsT5bC8k= -cloud.google.com/go/notebooks v1.7.0/go.mod h1:PVlaDGfJgj1fl1S3dUwhFMXFgfYGhYQt2164xOMONmE= -cloud.google.com/go/optimization v1.3.1/go.mod h1:IvUSefKiwd1a5p0RgHDbWCIbDFgKuEdB+fPPuP0IDLI= -cloud.google.com/go/orchestration v1.6.0/go.mod h1:M62Bevp7pkxStDfFfTuCOaXgaaqRAga1yKyoMtEoWPQ= -cloud.google.com/go/orgpolicy v1.10.0/go.mod h1:w1fo8b7rRqlXlIJbVhOMPrwVljyuW5mqssvBtU18ONc= -cloud.google.com/go/osconfig v1.11.0/go.mod h1:aDICxrur2ogRd9zY5ytBLV89KEgT2MKB2L/n6x1ooPw= -cloud.google.com/go/oslogin v1.9.0/go.mod h1:HNavntnH8nzrn8JCTT5fj18FuJLFJc4NaZJtBnQtKFs= -cloud.google.com/go/phishingprotection v0.7.0/go.mod h1:8qJI4QKHoda/sb/7/YmMQ2omRLSLYSu9bU0EKCNI+Lk= -cloud.google.com/go/policytroubleshooter v1.5.0/go.mod h1:Rz1WfV+1oIpPdN2VvvuboLVRsB1Hclg3CKQ53j9l8vw= -cloud.google.com/go/privatecatalog v0.7.0/go.mod h1:2s5ssIFO69F5csTXcwBP7NPFTZvps26xGzvQ2PQaBYg= -cloud.google.com/go/pubsub v1.28.0/go.mod h1:vuXFpwaVoIPQMGXqRyUQigu/AX1S3IWugR9xznmcXX8= -cloud.google.com/go/pubsublite v1.6.0/go.mod h1:1eFCS0U11xlOuMFV/0iBqw3zP12kddMeCbj/F3FSj9k= -cloud.google.com/go/recaptchaenterprise/v2 v2.6.0/go.mod h1:RPauz9jeLtB3JVzg6nCbe12qNoaa8pXc4d/YukAmcnA= -cloud.google.com/go/recommendationengine v0.7.0/go.mod h1:1reUcE3GIu6MeBz/h5xZJqNLuuVjNg1lmWMPyjatzac= -cloud.google.com/go/recommender v1.9.0/go.mod h1:PnSsnZY7q+VL1uax2JWkt/UegHssxjUVVCrX52CuEmQ= -cloud.google.com/go/redis v1.11.0/go.mod h1:/X6eicana+BWcUda5PpwZC48o37SiFVTFSs0fWAJ7uQ= -cloud.google.com/go/resourcemanager v1.5.0/go.mod h1:eQoXNAiAvCf5PXxWxXjhKQoTMaUSNrEfg+6qdf/wots= -cloud.google.com/go/resourcesettings v1.5.0/go.mod h1:+xJF7QSG6undsQDfsCJyqWXyBwUoJLhetkRMDRnIoXA= -cloud.google.com/go/retail v1.12.0/go.mod h1:UMkelN/0Z8XvKymXFbD4EhFJlYKRx1FGhQkVPU5kF14= -cloud.google.com/go/run v0.8.0/go.mod h1:VniEnuBwqjigv0A7ONfQUaEItaiCRVujlMqerPPiktM= -cloud.google.com/go/scheduler v1.8.0/go.mod h1:TCET+Y5Gp1YgHT8py4nlg2Sew8nUHMqcpousDgXJVQc= -cloud.google.com/go/secretmanager v1.10.0/go.mod h1:MfnrdvKMPNra9aZtQFvBcvRU54hbPD8/HayQdlUgJpU= -cloud.google.com/go/security v1.12.0/go.mod h1:rV6EhrpbNHrrxqlvW0BWAIawFWq3X90SduMJdFwtLB8= -cloud.google.com/go/securitycenter v1.18.1/go.mod h1:0/25gAzCM/9OL9vVx4ChPeM/+DlfGQJDwBy/UC8AKK0= -cloud.google.com/go/servicecontrol v1.11.0/go.mod h1:kFmTzYzTUIuZs0ycVqRHNaNhgR+UMUpw9n02l/pY+mc= -cloud.google.com/go/servicedirectory v1.8.0/go.mod h1:srXodfhY1GFIPvltunswqXpVxFPpZjf8nkKQT7XcXaY= -cloud.google.com/go/servicemanagement v1.6.0/go.mod h1:aWns7EeeCOtGEX4OvZUWCCJONRZeFKiptqKf1D0l/Jc= -cloud.google.com/go/serviceusage v1.5.0/go.mod h1:w8U1JvqUqwJNPEOTQjrMHkw3IaIFLoLsPLvsE3xueec= -cloud.google.com/go/shell v1.6.0/go.mod h1:oHO8QACS90luWgxP3N9iZVuEiSF84zNyLytb+qE2f9A= -cloud.google.com/go/spanner v1.44.0/go.mod h1:G8XIgYdOK+Fbcpbs7p2fiprDw4CaZX63whnSMLVBxjk= -cloud.google.com/go/speech v1.14.1/go.mod h1:gEosVRPJ9waG7zqqnsHpYTOoAS4KouMRLDFMekpJ0J0= -cloud.google.com/go/storagetransfer v1.7.0/go.mod h1:8Giuj1QNb1kfLAiWM1bN6dHzfdlDAVC9rv9abHot2W4= -cloud.google.com/go/talent v1.5.0/go.mod h1:G+ODMj9bsasAEJkQSzO2uHQWXHHXUomArjWQQYkqK6c= -cloud.google.com/go/texttospeech v1.6.0/go.mod h1:YmwmFT8pj1aBblQOI3TfKmwibnsfvhIBzPXcW4EBovc= -cloud.google.com/go/tpu v1.5.0/go.mod h1:8zVo1rYDFuW2l4yZVY0R0fb/v44xLh3llq7RuV61fPM= -cloud.google.com/go/trace v1.8.0/go.mod h1:zH7vcsbAhklH8hWFig58HvxcxyQbaIqMarMg9hn5ECA= -cloud.google.com/go/translate v1.6.0/go.mod h1:lMGRudH1pu7I3n3PETiOB2507gf3HnfLV8qlkHZEyos= -cloud.google.com/go/video v1.13.0/go.mod h1:ulzkYlYgCp15N2AokzKjy7MQ9ejuynOJdf1tR5lGthk= -cloud.google.com/go/videointelligence v1.10.0/go.mod h1:LHZngX1liVtUhZvi2uNS0VQuOzNi2TkY1OakiuoUOjU= -cloud.google.com/go/vision/v2 v2.6.0/go.mod h1:158Hes0MvOS9Z/bDMSFpjwsUrZ5fPrdwuyyvKSGAGMY= -cloud.google.com/go/vmmigration v1.5.0/go.mod h1:E4YQ8q7/4W9gobHjQg4JJSgXXSgY21nA5r8swQV+Xxc= -cloud.google.com/go/vmwareengine v0.2.2/go.mod h1:sKdctNJxb3KLZkE/6Oui94iw/xs9PRNC2wnNLXsHvH8= -cloud.google.com/go/vpcaccess v1.6.0/go.mod h1:wX2ILaNhe7TlVa4vC5xce1bCnqE3AeH27RV31lnmZes= -cloud.google.com/go/webrisk v1.8.0/go.mod h1:oJPDuamzHXgUc+b8SiHRcVInZQuybnvEW72PqTc7sSg= -cloud.google.com/go/websecurityscanner v1.5.0/go.mod h1:Y6xdCPy81yi0SQnDY1xdNTNpfY1oAgXUlcfN3B3eSng= -cloud.google.com/go/workflows v1.10.0/go.mod h1:fZ8LmRmZQWacon9UCX1r/g/DfAXx5VcPALq2CxzdePw= -github.com/AdaLogics/go-fuzz-headers v0.0.0-20230106234847-43070de90fa1/go.mod h1:VzwV+t+dZ9j/H867F1M2ziD+yLHtB46oM35FxxMJ4d0= -github.com/AdamKorcz/go-118-fuzz-build v0.0.0-20221215162035-5330a85ea652/go.mod h1:OahwfttHWG6eJ0clwcfBAHoDI6X/LV/15hx/wlMZSrU= github.com/AndreasBriese/bbloom v0.0.0-20190306092124-e2d15f34fcf9/go.mod h1:bOvUY6CB00SOBii9/FifXqc0awNKxLFCL/+pkDPuyl8= -github.com/Azure/azure-sdk-for-go/sdk/azcore v0.21.1/go.mod h1:fBF9PQNqB8scdgpZ3ufzaLntG0AG7C1WjPMsiFOmfHM= -github.com/Azure/azure-sdk-for-go/sdk/internal v0.8.3/go.mod h1:KLF4gFr6DcKFZwSuH8w8yEK6DpFl3LP5rhdvAb7Yz5I= -github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v0.3.0/go.mod h1:tPaiy8S5bQ+S5sOiDlINkp7+Ef339+Nz5L5XO+cnOHo= github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161 h1:L/gRVlceqvL25UVaW/CKtUDjefjrs0SPonmDGUVOYP0= github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak= -github.com/BurntSushi/toml v1.2.1/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= github.com/CloudyKit/fastprinter v0.0.0-20200109182630-33d98a066a53/go.mod h1:+3IMCy2vIlbG1XG/0ggNQv0SvxCAIpPM5b1nCz56Xno= github.com/CloudyKit/jet/v3 v3.0.0/go.mod h1:HKQPgSJmdK8hdoAbKUUWajkHyHo4RaU5rMdUywE7VMo= -github.com/CloudyKit/jet/v6 v6.1.0/go.mod h1:d3ypHeIRNo2+XyqnGA8s+aphtcVpjP5hPwP/Lzo7Ro4= github.com/DataDog/zstd v1.5.2 h1:vUG4lAyuPCXO0TLbXvPv7EB7cNK1QV/luu55UHLrrn8= github.com/DataDog/zstd v1.5.2/go.mod h1:g4AWEaM3yOg3HYfnJ3YIawPnVdXJh9QME85blwSAmyw= -github.com/HdrHistogram/hdrhistogram-go v1.1.2/go.mod h1:yDgFjdqOqDEKOvasDdhWNXYg9BVp4O+o5f6V/ehm6Oo= github.com/Joker/hpp v1.0.0/go.mod h1:8x5n+M1Hp5hC0g8okX3sR3vFQwynaX/UgSOM9MeBKzY= github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0= github.com/Microsoft/go-winio v0.6.1 h1:9/kr64B9VUZrLm5YYwbGtUJnMgqWVOdUAXu6Migciow= github.com/Microsoft/go-winio v0.6.1/go.mod h1:LRdKpFKfdobln8UmuiYcKPot9D2v6svN5+sAH+4kjUM= -github.com/Microsoft/hcsshim v0.10.0-rc.8/go.mod h1:OEthFdQv/AD2RAdzR6Mm1N1KPCztGKDurW1Z8b8VGMM= github.com/Shopify/goreferrer v0.0.0-20181106222321-ec9c9a553398/go.mod h1:a1uqRtAwp2Xwc6WNPJEufxJ7fx3npB4UV/JOLmbu5I0= -github.com/Shopify/goreferrer v0.0.0-20220729165902-8cddb4f5de06/go.mod h1:7erjKLwalezA0k99cWs5L11HWOAPNjdUZ6RxH1BXbbM= github.com/Shopify/sarama v1.19.0/go.mod h1:FVkBWblsNy7DGZRfXLU0O9RCGt5g3g3yEuWXgklEdEo= github.com/Shopify/toxiproxy v2.1.4+incompatible/go.mod h1:OXgGpZ6Cli1/URJOF1DMxUHB2q5Ap20/P/eIdh4G0pI= github.com/StackExchange/wmi v0.0.0-20180116203802-5d049714c4a6 h1:fLjPD/aNc3UIOA6tDi6QXUemppXK3P9BI7mr2hd6gx8= @@ -160,7 +28,6 @@ github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuy github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= -github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho= github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= github.com/allegro/bigcache v1.2.1 h1:hg1sY1raCwic3Vnsvje6TT7/pnZba83LeFck5NrFKSc= github.com/allegro/bigcache v1.2.1/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM= @@ -178,16 +45,6 @@ github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6l github.com/aws/aws-lambda-go v1.13.3/go.mod h1:4UKl9IzQMoD+QF79YdCuzCwp8VbmG4VAQwij/eHl5CU= github.com/aws/aws-sdk-go v1.27.0/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= -github.com/aws/aws-sdk-go-v2 v1.2.0/go.mod h1:zEQs02YRBw1DjK0PoJv3ygDYOFTre1ejlJWl8FwAuQo= -github.com/aws/aws-sdk-go-v2/config v1.1.1/go.mod h1:0XsVy9lBI/BCXm+2Tuvt39YmdHwS5unDQmxZOYe8F5Y= -github.com/aws/aws-sdk-go-v2/credentials v1.1.1/go.mod h1:mM2iIjwl7LULWtS6JCACyInboHirisUUdkBPoTHMOUo= -github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.0.2/go.mod h1:3hGg3PpiEjHnrkrlasTfxFqUsZ2GCk/fMUn4CbKgSkM= -github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.0.2/go.mod h1:45MfaXZ0cNbeuT0KQ1XJylq8A6+OpVV2E5kvY/Kq+u8= -github.com/aws/aws-sdk-go-v2/service/route53 v1.1.1/go.mod h1:rLiOUrPLW/Er5kRcQ7NkwbjlijluLsrIbu/iyl35RO4= -github.com/aws/aws-sdk-go-v2/service/sso v1.1.1/go.mod h1:SuZJxklHxLAXgLTc1iFXbEWkXs7QRTQpCLGaKIprQW0= -github.com/aws/aws-sdk-go-v2/service/sts v1.1.1/go.mod h1:Wi0EBZwiz/K44YliU0EKxqTCJGUfYTWXrrBwkq736bM= -github.com/aws/smithy-go v1.1.0/go.mod h1:EzMw8dbp/YJL4A5/sbhGddag+NPT7q084agLbB9LgIw= -github.com/aymerick/douceur v0.2.0/go.mod h1:wlT5vV2O3h55X9m7iVYN0TBM0NH/MmbLnd30/FjWUq4= github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible/go.mod h1:osfaiScAUVup+UC9Nfq76eWqDhXlp+4UYaA8uhTBO6g= github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= @@ -196,13 +53,11 @@ github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6r github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= github.com/bits-and-blooms/bitset v1.7.0 h1:YjAGVd3XmtK9ktAbX8Zg2g2PwLIMjGREZJHlV4j7NEo= github.com/bits-and-blooms/bitset v1.7.0/go.mod h1:gIdJ4wp64HaoK2YrL1Q5/N7Y16edYb8uY+O0FJTyyDA= -github.com/blang/semver/v4 v4.0.0/go.mod h1:IbckMUScFkM3pff0VJDNKRiT6TG/YpiHIM2yvyW5YoQ= github.com/btcsuite/btcd v0.20.1-beta/go.mod h1:wVuoA8VJLEcwgqHBwHmzLRazpKxTv13Px/pDuV7OomQ= github.com/btcsuite/btcd v0.22.0-beta h1:LTDpDKUM5EeOFBPM8IXpinEcmZ6FWfNZbE3lfrfdnWo= github.com/btcsuite/btcd v0.22.0-beta/go.mod h1:9n5ntfhhHQBIhUvlhDvD3Qg6fRUj4jkN0VB8L8svzOA= github.com/btcsuite/btcd/btcec/v2 v2.3.2 h1:5n0X6hX0Zk+6omWcihdYvdAlGf2DfasC0GMf7DClJ3U= github.com/btcsuite/btcd/btcec/v2 v2.3.2/go.mod h1:zYzJ8etWJQIv1Ogk7OzpWjowwOdXY1W/17j2MW85J04= -github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc= github.com/btcsuite/btclog v0.0.0-20170628155309-84c8d2346e9f/go.mod h1:TdznJufoqS23FtqVCzL0ZqgP5MqXbb4fg/WgDys70nA= github.com/btcsuite/btcutil v0.0.0-20190425235716-9e5f4b9a998d/go.mod h1:+5NJ2+qvTyV9exUAL/rxXi3DcLg2Ts+ymUAY5y4NvMg= github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce/go.mod h1:0DVlHczLPewLcPGEIeUEzfOJhqGPQ0mJJRDBtD307+o= @@ -218,24 +73,17 @@ github.com/bytedance/sonic v1.9.1 h1:6iJ6NqdoxCDr6mbY8h18oSO+cShGSMRGCEo7F2h0x8s github.com/bytedance/sonic v1.9.1/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ= github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM= -github.com/cenkalti/backoff/v4 v4.2.0/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.4.1/go.mod h1:4T9NM4+4Vw91VeyqjLS6ao50K5bOcLKN6Q42XnYaRYw= github.com/cespare/cp v0.1.0 h1:SE+dxFebS7Iik5LK0tsi1k9ZCxEaFX4AjQmoyA+1dJk= -github.com/cespare/cp v0.1.0/go.mod h1:SOGHArjBr4JWaSDEVpWpo/hNg6RoKrls6Oh40hiwW+s= github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44= github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY= github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 h1:qSGYFH7+jGhDF8vLC+iwCD4WpbV1EBDSzWkJODFLams= github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= -github.com/cilium/ebpf v0.9.1/go.mod h1:+OhNOIXx/Fnu1IE8bJz2dzOA+VSfyTfdNUVdlQnxUFY= github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4dUb/I5gc9Hdhagfvm9+RyrPryS/auMzxE= github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= -github.com/cloudflare/cloudflare-go v0.14.0/go.mod h1:EnwdgGMaFOruiPZRFSgn+TsQ3hQ7C/YWzIGLeu5c304= github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= -github.com/cncf/udpa/go v0.0.0-20220112060539-c52dc94e7fbe/go.mod h1:6pvJx4me5XPnfI9Z40ddWsdw2W/uZgQLFXToKeRcDiI= -github.com/cncf/xds/go v0.0.0-20230105202645-06c439db220b/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8= github.com/cockroachdb/datadriven v1.0.2 h1:H9MtNqVoVhvd9nCBwOyDjUEdZCREqbIdCJD93PBm/jA= github.com/cockroachdb/datadriven v1.0.2/go.mod h1:a9RdTaap04u637JoCzcUoIcDmvwSUtcUFtT/C3kJlTU= @@ -248,51 +96,27 @@ github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811 h1:ytcWPaNPhNoG github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811/go.mod h1:Nb5lgvnQ2+oGlE/EyZy4+2/CxRh9KfvCXnag1vtpxVM= github.com/cockroachdb/redact v1.1.3 h1:AKZds10rFSIj7qADf0g46UixK8NNLwWTNdCIGS5wfSQ= github.com/cockroachdb/redact v1.1.3/go.mod h1:BVNblN9mBWFyMyqK1k3AAiSxhvhfK2oOZZ2lK+dpvRg= -github.com/cockroachdb/sentry-go v0.6.1-cockroachdb.2/go.mod h1:8BT+cPK6xvFOcRlk0R8eg+OTkcqI6baNH4xAkpiYVvQ= github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI= github.com/codegangsta/inject v0.0.0-20150114235600-33e0aa1cb7c0/go.mod h1:4Zcjuz89kmFXt9morQgcfYZAYZ5n8WHjt81YYWIwtTM= github.com/consensys/bavard v0.1.13 h1:oLhMLOFGTLdlda/kma4VOJazblc7IM5y5QPd2A/YjhQ= github.com/consensys/bavard v0.1.13/go.mod h1:9ItSMtA/dXMAiL7BG6bqW2m3NdSEObYWoH223nGHukI= github.com/consensys/gnark-crypto v0.10.0 h1:zRh22SR7o4K35SoNqouS9J/TKHTyU2QWaj5ldehyXtA= github.com/consensys/gnark-crypto v0.10.0/go.mod h1:Iq/P3HHl0ElSjsg2E1gsMwhAyxnxoKK5nVyZKd+/KhU= -github.com/container-orchestrated-devices/container-device-interface v0.5.4/go.mod h1:DjE95rfPiiSmG7uVXtg0z6MnPm/Lx4wxKCIts0ZE0vg= -github.com/containerd/aufs v1.0.0/go.mod h1:kL5kd6KM5TzQjR79jljyi4olc1Vrx6XBlcyj3gNv2PU= -github.com/containerd/btrfs/v2 v2.0.0/go.mod h1:swkD/7j9HApWpzl8OHfrHNxppPd9l44DFZdF94BUj9k= -github.com/containerd/cgroups v1.1.0/go.mod h1:6ppBcbh/NOOUU+dMKrykgaBnK9lCIBxHqJDGwsa1mIw= -github.com/containerd/cgroups/v3 v3.0.2/go.mod h1:JUgITrzdFqp42uI2ryGA+ge0ap/nxzYgkGmIcetmErE= -github.com/containerd/console v1.0.3/go.mod h1:7LqA/THxQ86k76b8c/EMSiaJ3h1eZkMkXar0TQ1gf3U= github.com/containerd/containerd v1.7.3 h1:cKwYKkP1eTj54bP3wCdXXBymmKRQMrWjkLSWZZJDa8o= github.com/containerd/containerd v1.7.3/go.mod h1:32FOM4/O0RkNg7AjQj3hDzN9cUGtu+HMvaKUNiqCZB8= -github.com/containerd/continuity v0.4.1/go.mod h1:F6PTNCKepoxEaXLQp3wDAjygEnImnZ/7o4JzpodfroQ= -github.com/containerd/fifo v1.1.0/go.mod h1:bmC4NWMbXlt2EZ0Hc7Fx7QzTFxgPID13eH0Qu+MAb2o= -github.com/containerd/go-cni v1.1.9/go.mod h1:XYrZJ1d5W6E2VOvjffL3IZq0Dz6bsVlERHbekNK90PM= -github.com/containerd/go-runc v1.0.0/go.mod h1:cNU0ZbCgCQVZK4lgG3P+9tn9/PaJNmoDXPpoJhDR+Ok= -github.com/containerd/imgcrypt v1.1.7/go.mod h1:FD8gqIcX5aTotCtOmjeCsi3A1dHmTZpnMISGKSczt4k= -github.com/containerd/nri v0.3.0/go.mod h1:Zw9q2lP16sdg0zYybemZ9yTDy8g7fPCIB3KXOGlggXI= -github.com/containerd/ttrpc v1.2.2/go.mod h1:sIT6l32Ph/H9cvnJsfXM5drIVzTr5A2flTf1G5tYZak= -github.com/containerd/typeurl v1.0.2/go.mod h1:9trJWW2sRlGub4wZJRTW83VtbOLS6hwcDZXTn6oPz9s= -github.com/containerd/typeurl/v2 v2.1.1/go.mod h1:IDp2JFvbwZ31H8dQbEIY7sDl2L3o3HZj1hsSQlywkQ0= -github.com/containerd/zfs v1.1.0/go.mod h1:oZF9wBnrnQjpWLaPKEinrx3TQ9a+W/RJO7Zb41d8YLE= -github.com/containernetworking/cni v1.1.2/go.mod h1:sDpYKmGVENF3s6uvMvGgldDWeG8dMxakj/u+i9ht9vw= -github.com/containernetworking/plugins v1.2.0/go.mod h1:/VjX4uHecW5vVimFa1wkG4s+r/s9qIfPdqlLF4TW8c4= -github.com/containers/ocicrypt v1.1.6/go.mod h1:WgjxPWdTJMqYMjf3M6cuIFFA1/MpyyhIM99YInA+Rvc= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= github.com/coreos/go-systemd v0.0.0-20180511133405-39ca1b05acc7/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= -github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE= github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/cpuguy83/go-md2man/v2 v2.0.2 h1:p1EgwI/C7NhT0JmVkwCD2ZBK8j4aeHQX2pMHHBfMQ6w= github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= -github.com/crate-crypto/go-ipa v0.0.0-20230601170251-1830d0757c80/go.mod h1:gzbVz57IDJgQ9rLQwfSk696JGWof8ftznEL9GoAv3NI= github.com/crate-crypto/go-kzg-4844 v0.3.0 h1:UBlWE0CgyFqqzTI+IFyCzA7A3Zw4iip6uzRv5NIXG0A= github.com/crate-crypto/go-kzg-4844 v0.3.0/go.mod h1:SBP7ikXEgDnUPONgm33HtuDZEDtWa3L4QtN1ocJSEQ4= github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= -github.com/creack/pty v1.1.18/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4= -github.com/cyphar/filepath-securejoin v0.2.3/go.mod h1:aPGpWjXOXUn2NCNjFvBE6aRxGGx79pTxQpKOJNYHHl4= github.com/davecgh/go-spew v0.0.0-20161028175848-04cdfd42973b/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v0.0.0-20171005155431-ecdeabc65495/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -301,26 +125,20 @@ github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs github.com/deckarep/golang-set/v2 v2.1.0 h1:g47V4Or+DUdzbs8FxCCmgb6VYd+ptPAngjM6dtGktsI= github.com/deckarep/golang-set/v2 v2.1.0/go.mod h1:VAky9rY/yGXJOLEDv3OMci+7wtDpOF4IN+y82NBOac4= github.com/decred/dcrd/crypto/blake256 v1.0.1 h1:7PltbUIQB7u/FfZ39+DGa/ShuMyJ5ilcvdfma9wOH6Y= -github.com/decred/dcrd/crypto/blake256 v1.0.1/go.mod h1:2OfgNZ5wDpcsFmHmCK5gZTPcCXqlm2ArzUIkw9czNJo= github.com/decred/dcrd/dcrec/secp256k1/v4 v4.2.0 h1:8UrgZ3GkP4i/CLijOJx79Yu+etlyjdBU4sfcs2WYQMs= github.com/decred/dcrd/dcrec/secp256k1/v4 v4.2.0/go.mod h1:v57UDF4pDQJcEfFUCRop3lJL149eHGSe9Jvczhzjo/0= github.com/decred/dcrd/lru v1.0.0/go.mod h1:mxKOwFd7lFjN2GZYsiz/ecgqR6kkYAl+0pz0tEMk218= -github.com/deepmap/oapi-codegen v1.8.2/go.mod h1:YLgSKSDv/bZQB7N4ws6luhozi3cEdRktEqrX88CvjIw= github.com/dgraph-io/badger v1.6.0/go.mod h1:zwt7syl517jmP8s94KqSxTlM6IMsdhYy6psNgSztDR4= github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ= github.com/dgryski/go-farm v0.0.0-20190423205320-6a90982ecee2/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw= -github.com/dlclark/regexp2 v1.7.0/go.mod h1:DHkYz0B9wPfa6wondMfaivmHpzrQ3v9q8cnmRbL6yW8= github.com/docker/distribution v2.8.1+incompatible h1:Q50tZOPR6T/hjNsyc9g8/syEs6bk8XXApsHjKukMl68= github.com/docker/distribution v2.8.1+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w= github.com/docker/docker v20.10.3-0.20220224222438-c78f6963a1c0+incompatible h1:Ptj2To+ezU/mCBUKdYXBQ2r3/2EJojAlOZrsgprF+is= github.com/docker/docker v20.10.3-0.20220224222438-c78f6963a1c0+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk= github.com/docker/go-connections v0.4.0 h1:El9xVISelRB7BuFusrZozjnkIM5YnzCViNKohAFqRJQ= github.com/docker/go-connections v0.4.0/go.mod h1:Gbd7IOopHjR8Iph03tsViu4nIes5XhDvyHbTtUxmeec= -github.com/docker/go-events v0.0.0-20190806004212-e31b211e4f1c/go.mod h1:Uw6UezgYA44ePAFQYUehOuCzmy5zmg/+nl2ZfMWGkpA= -github.com/docker/go-metrics v0.0.1/go.mod h1:cG1hvH2utMXtqgqqYE9plW6lDxS3/5ayHzueweSI3Vw= github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4= github.com/docker/go-units v0.5.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk= -github.com/dop251/goja v0.0.0-20230605162241-28ee0ee714f3/go.mod h1:QMWlm50DNe14hD7t24KEqZuUdC9sOTy8W6XbCU1mlw4= github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5mFgVsvEsIPBvNs= @@ -334,14 +152,11 @@ github.com/eko/gocache/lib/v4 v4.1.2 h1:cX54GhJJsfc5jvCEaPW8595h9Pq6bbNfkv0o/669 github.com/eko/gocache/lib/v4 v4.1.2/go.mod h1:FqyrANKct257VFHVVs11m6V2syGobOmHycQCyRSMwu0= github.com/eko/gocache/store/bigcache/v4 v4.1.2 h1:8uMDpgxTG7BvyLHBFqL3Ao809bVrXfrWqo7v6ALiwTw= github.com/eko/gocache/store/bigcache/v4 v4.1.2/go.mod h1:Lut5Sk/yI835w02tmwx4ecezYQo445L5sdICsk1zgho= -github.com/emicklei/go-restful/v3 v3.10.1/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= github.com/envoyproxy/go-control-plane v0.6.9/go.mod h1:SBwIajubJHhxtWwsL9s8ss4safvEdbitLhGGK48rN6g= github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= -github.com/envoyproxy/go-control-plane v0.10.3/go.mod h1:fJJn/j26vwOu972OllsvAgJJM//w9BV6Fxbg2LuVd34= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= -github.com/envoyproxy/protoc-gen-validate v0.9.1/go.mod h1:OKNgG7TCp5pF4d6XftA0++PMirau2/yoOwVac3AbF2w= github.com/etcd-io/bbolt v1.3.3/go.mod h1:ZF2nL25h33cCyBtcyWeZ2/I3HQOfTP+0PIEvHjkjCrw= github.com/ethereum/c-kzg-4844 v0.3.1 h1:sR65+68+WdnMKxseNWxSJuAv2tsUrihTpVBTfM/U5Zg= github.com/ethereum/c-kzg-4844 v0.3.1/go.mod h1:VewdlzQmpT5QSrVhbBuGoCdFJkpaJlO1aQputP83wc0= @@ -350,10 +165,8 @@ github.com/ethereum/go-ethereum v1.12.2/go.mod h1:1cRAEV+rp/xX0zraSCBnu9Py3HQ+ge github.com/fasthttp-contrib/websocket v0.0.0-20160511215533-1f3b11f56072/go.mod h1:duJ4Jxv5lDcvg4QuQr0oowTf7dz4/CR8NtyCooz9HL8= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M= -github.com/fjl/gencodec v0.0.0-20230517082657-f9840df7b83e/go.mod h1:AzA8Lj6YtixmJWL+wkKoBGsLWy9gFrAzi4g+5bCKwpY= github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5 h1:FtmdgXiUlNeRsoNMFlKLDt+S+6hbjVMEW6RGQ7aUf7c= github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5/go.mod h1:VvhXpOYNQvB+uIk2RvXzuaQtkQJzzIx6lSBe1xv7hi0= -github.com/flosch/pongo2/v4 v4.0.2/go.mod h1:B5ObFANs/36VwxxlgKpdchIJHMvHB562PW+BWPhwZD8= github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4= github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= @@ -362,15 +175,12 @@ github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4 github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw= github.com/gabriel-vasile/mimetype v1.4.2 h1:w5qFW6JKBz9Y393Y4q372O9A7cUSequkh1Q7OhCmWKU= github.com/gabriel-vasile/mimetype v1.4.2/go.mod h1:zApsH/mKG4w07erKIaJPFiX0Tsq9BFQgN3qGY5GnNgA= -github.com/garslo/gogen v0.0.0-20170306192744-1d203ffc1f61/go.mod h1:Q0X6pkwTILDlzrGEckF6HKjXe48EgsY/l7K7vhY4MW8= github.com/gavv/httpexpect v2.0.0+incompatible/go.mod h1:x+9tiU1YnrOvnB725RkpoLv1M62hOWzwo5OXotisrKc= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff h1:tY80oXqGNY4FhTFhk+o9oFHGINQ/+vhlm8HFzi6znCI= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff/go.mod h1:x7DCsMOv1taUwEWCzT4cmDeAkigA5/QCwUodaVOe8Ww= -github.com/gballet/go-verkle v0.0.0-20230607174250-df487255f46b/go.mod h1:CDncRYVRSDqwakm282WEkjfaAj1hxU/v5RXxk5nXOiI= github.com/getsentry/sentry-go v0.12.0/go.mod h1:NSap0JBYWzHND8oMbyi0+XZhUalc1TBdRL1M71JZW2c= github.com/getsentry/sentry-go v0.18.0 h1:MtBW5H9QgdcJabtZcuJG80BMOwaBpkRDZkxRkNC1sN0= github.com/getsentry/sentry-go v0.18.0/go.mod h1:Kgon4Mby+FJ7ZWHFUAZgVaIa8sxHtnRJRLTXZr51aKQ= -github.com/ghemawat/stream v0.0.0-20171120220530-696b145b53b9/go.mod h1:106OIgooyS7OzLDOpUGgm9fA3bQENb/cFSyyBmMoJDs= github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= github.com/gin-contrib/cors v1.4.0 h1:oJ6gwtUl3lqV0WEIwM/LxPF1QZ5qe2lGWdY2+bz7y0g= github.com/gin-contrib/cors v1.4.0/go.mod h1:bs9pNM0x/UsmHPBWT2xZz9ROh8xYjYkiURUfmBoMlcs= @@ -384,25 +194,20 @@ github.com/gin-gonic/gin v1.9.1/go.mod h1:hPrL7YrpYKXt5YId3A/Tnip5kqbEAP+KLuI3SU github.com/go-check/check v0.0.0-20180628173108-788fd7840127/go.mod h1:9ES+weclKsC9YodN5RgxqK/VD9HM9JsCSh7rNhMZE98= github.com/go-errors/errors v1.0.1/go.mod h1:f4zRHt4oKfwPJE5k8C9vpYG+aDHdBFUsgrm6/TyX73Q= github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA= -github.com/go-errors/errors v1.4.2/go.mod h1:sIVyrIiJhuEF+Pj9Ebtd6P/rEYROXFi3BopGUQ5a5Og= github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= github.com/go-kit/kit v0.10.0 h1:dXFJfIHVvUcpSgDOV+Ne6t7jXri8Tfv2uOLHUZ2XNuo= github.com/go-kit/kit v0.10.0/go.mod h1:xUsJbQ/Fp4kEt7AFgCuvyX4a71u8h9jB8tj/ORgOZ7o= -github.com/go-kit/log v0.2.1/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0= github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= github.com/go-logfmt/logfmt v0.5.1 h1:otpy5pqBCBZ1ng9RQ0dPu4PN7ba75Y/aA+UpowDyNVA= github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs= -github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= -github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-martini/martini v0.0.0-20170121215854-22fa46961aab/go.mod h1:/P9AEU963A2AYjv4d1V5eVL1CQbEJq6aCNHDDjibzu8= github.com/go-ole/go-ole v1.2.1 h1:2lOsA72HgjxAuMlKpFiCbHTvu44PIVkZ5hqm3RSdI/E= github.com/go-ole/go-ole v1.2.1/go.mod h1:7FAglXiTm7HKlQRDeOQ6ZNUHidzCWXuZWq/1dTyBNF8= github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= -github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.14.0/go.mod h1:sawfccIbzZTqEDETgFXqTho0QybSa7l++s0DH+LDiLs= github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= @@ -412,7 +217,6 @@ github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91 github.com/go-playground/validator/v10 v10.10.0/go.mod h1:74x4gJWsvQexRdW8Pn3dXSGrTK4nAUsbPlLADvpJkos= github.com/go-playground/validator/v10 v10.14.0 h1:vgvQWe3XCz3gIeFDm/HnTIbj6UGmg/+t63MyGU2n5js= github.com/go-playground/validator/v10 v10.14.0/go.mod h1:9iXMNT7sEkjXb0I+enO7QXmzG6QCsPWY4zveKFVRSyU= -github.com/go-sourcemap/sourcemap v2.1.3+incompatible/go.mod h1:F8jJfvm2KbVjc5NqelyYJmf/v5J0dwNLS2mL4sNA1Jg= github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= github.com/go-sql-driver/mysql v1.4.1 h1:g24URVg0OFbNUTx9qqY1IRZ9D9z3iPyi5zKhQZpNwpA= github.com/go-sql-driver/mysql v1.4.1/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= @@ -425,7 +229,6 @@ github.com/gobwas/ws v1.0.2/go.mod h1:szmBTxLgaFppYjEmNtny/v3w89xOydFnnZMcgRRu/E github.com/goccy/go-json v0.9.7/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= -github.com/godbus/dbus/v5 v5.1.0/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= github.com/gofrs/flock v0.8.1 h1:+gYjHKf32LDeiEEFhQaotPbLuUXjY5ZqxKgXy7n59aw= github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU= github.com/gogo/googleapis v0.0.0-20180223154316-0cd9801be74a/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFGgqEef3s= @@ -442,10 +245,8 @@ github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzq github.com/golang-jwt/jwt/v4 v4.3.0 h1:kHL1vqdqWNfATmA0FNMdmZNMyZI1U6O31X4rlIPoBog= github.com/golang-jwt/jwt/v4 v4.3.0/go.mod h1:/xlHOz8bRuivTWchD4jCa+NbatV+wEUSzwAxVc6locg= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= -github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4= github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= -github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= github.com/golang/mock v1.6.0 h1:ErTB+efbowRARo13NNdxyJji2egdxLGQhRaY+DUumQc= github.com/golang/mock v1.6.0/go.mod h1:p6yTPP+5HYm5mzsMV8JkE6ZKdX+/wYM6Hr+LicevLPs= @@ -479,11 +280,8 @@ github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= -github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= -github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= -github.com/google/pprof v0.0.0-20230207041349-798e818bf904/go.mod h1:uglQLonpP8qtYCYyzA+8c/9qtqgA3qsXGYqCPKARAFg= github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/subcommands v1.2.0/go.mod h1:ZjhPrFU+Olkh9WazFPsl27BQ4UPiG37m3yTrtFlrHVk= github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= @@ -492,7 +290,6 @@ github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I= github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= github.com/gorilla/context v1.1.1/go.mod h1:kBGZzfjB9CEq2AlWe17Uuf7NDRt0dE0s8S51q0aT7Yg= -github.com/gorilla/css v1.0.0/go.mod h1:Dn721qIggHpt4+EFCcTLTU/vk5ySda2ReITrtgBl60c= github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= github.com/gorilla/mux v1.7.3 h1:gnP5JzjVOuiZD07fKKToCAOjS0yOpj/qPETTXCCS6hw= github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= @@ -500,23 +297,18 @@ github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY github.com/gorilla/websocket v1.4.1/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc= github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= -github.com/graph-gophers/graphql-go v1.3.0/go.mod h1:9CQHMSxwO4MprSdzoIEobiHpoLtHm77vfxsvsIN5Vuc= github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= -github.com/grpc-ecosystem/go-grpc-middleware v1.3.0/go.mod h1:z0ButlSOZa5vEBq9m2m2hlwIgKw+rp3sdCBRoJY+30Y= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= github.com/grpc-ecosystem/grpc-gateway v1.9.5/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.7.0/go.mod h1:hgWBS7lorOAVIJEQMi4ZsPv9hVvWI6+ch50m39Pf2Ks= github.com/hashicorp/consul/api v1.3.0/go.mod h1:MmDNSzIMUjNpY/mQ398R4bk2FnqQLoPndWW5VkKPlCE= github.com/hashicorp/consul/sdk v0.3.0/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8= github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= -github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= github.com/hashicorp/go-bexpr v0.1.10 h1:9kuI5PFotCboP3dkDYFr/wi0gg0QVbSNz5oFRpxn4uE= github.com/hashicorp/go-bexpr v0.1.10/go.mod h1:oxlubA2vC/gFVfX1A6JGp7ls7uCDlfJn732ehYYg+g0= github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM= github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk= -github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM= github.com/hashicorp/go-rootcerts v1.0.0/go.mod h1:K6zTfqpRlCUIjkwsN4Z+hiSfzSTQa6eBIzfwKfwNnHU= github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU= github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4= @@ -543,30 +335,20 @@ github.com/huin/goupnp v1.0.3 h1:N8No57ls+MnjlB+JPiCVSOyy/ot7MJTqlo7rn+NYSqQ= github.com/huin/goupnp v1.0.3/go.mod h1:ZxNlw5WqJj6wSsRK5+YfflQGXYfccj5VgQsMNixHM7Y= github.com/huin/goutil v0.0.0-20170803182201-1ca381bf3150/go.mod h1:PpLOETDnJ0o3iZrZfqZzyLl6l7F3c6L1oWn7OICBi6o= github.com/hydrogen18/memlistener v0.0.0-20200120041712-dcc25e7acd91/go.mod h1:qEIFzExnS6016fRpRfxrExeVn2gbClQA99gQhnIcdhE= -github.com/imdario/mergo v0.3.13/go.mod h1:4lJ1jqUDcsbIECGy0RUJAXNIhg+6ocWgb1ALK2O4oXg= github.com/imkira/go-interpol v1.1.0/go.mod h1:z0h2/2T3XF8kyEPpRgJ3kmNv+C43p+I/CoI+jC3w2iA= github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= -github.com/influxdata/influxdb-client-go/v2 v2.4.0/go.mod h1:vLNHdxTJkIf2mSLvGrpj8TCcISApPoXkaxP8g9uRlW8= github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo= -github.com/influxdata/influxdb1-client v0.0.0-20220302092344-a9ab5670611c/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo= -github.com/influxdata/line-protocol v0.0.0-20210311194329-9aa0e372d097/go.mod h1:xaLFMmpvUxqXtVkUJfg9QmT88cDaCJ3ZKgdZ78oO8Qo= -github.com/intel/goresctrl v0.3.0/go.mod h1:fdz3mD85cmP9sHD8JUlrNWAxvwM86CrbmVXltEKd7zk= github.com/iris-contrib/blackfriday v2.0.0+incompatible/go.mod h1:UzZ2bDEoaSGPbkg6SAB4att1aAwTmVIx/5gCVqeyUdI= github.com/iris-contrib/go.uuid v2.0.0+incompatible/go.mod h1:iz2lgM/1UnEf1kP0L/+fafWORmlnuysV2EMP8MW+qe0= github.com/iris-contrib/jade v1.1.3/go.mod h1:H/geBymxJhShH5kecoiOCSssPX7QWYH7UaeZTSWddIk= -github.com/iris-contrib/jade v1.1.4/go.mod h1:EDqR+ur9piDl6DUgs6qRrlfzmlx/D5UybogqrXvJTBE= github.com/iris-contrib/pongo2 v0.0.1/go.mod h1:Ssh+00+3GAZqSQb30AvBRNxBx7rf0GqwkjqxNd0u65g= github.com/iris-contrib/schema v0.0.1/go.mod h1:urYA3uvUNG1TIIjOSCzHr9/LmbQo8LrOcOqfqxa4hXw= -github.com/iris-contrib/schema v0.0.6/go.mod h1:iYszG0IOsuIsfzjymw1kMzTL8YQcCWlm65f3wX8J5iA= github.com/jackpal/go-nat-pmp v1.0.2 h1:KzKSgb7qkJvOUTqYl9/Hg/me3pWgBmERKrTGD7BdWus= github.com/jackpal/go-nat-pmp v1.0.2/go.mod h1:QPH045xvCAeXUZOxsnwmrtiCoxIr9eob+4orBN1SBKc= -github.com/jedisct1/go-minisign v0.0.0-20190909160543-45766022959e/go.mod h1:G1CVv03EnqU1wYL2dFwXxW2An0az9JTl/ZsqXQeBlkU= github.com/jessevdk/go-flags v0.0.0-20141203071132-1679536dcc89/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo= -github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= -github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4= github.com/jrick/logrotate v1.0.0/go.mod h1:LNinyqDIJnpAur+b8yyulnQw/wDuN1+BYKlTRt3OuAQ= github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= github.com/json-iterator/go v1.1.7/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= @@ -576,21 +358,12 @@ github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnr github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU= github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= -github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= github.com/k0kubun/colorstring v0.0.0-20150214042306-9440f1994b88/go.mod h1:3w7q1U84EfirKl04SVQ/s7nPm1ZPhiXd34z40TNz36k= -github.com/karalabe/usb v0.0.3-0.20230711191512-61db3e06439c/go.mod h1:Od972xHfMJowv7NGVDiWVxk2zxnWgjLlJzE+F4F7AGU= -github.com/kataras/blocks v0.0.7/go.mod h1:UJIU97CluDo0f+zEjbnbkeMRlvYORtmc1304EeyXf4I= github.com/kataras/golog v0.0.10/go.mod h1:yJ8YKCmyL+nWjERB90Qwn+bdyBZsaQwU3bTVFgkFIp8= -github.com/kataras/golog v0.1.7/go.mod h1:jOSQ+C5fUqsNSwurB/oAHq1IFSb0KI3l6GMa7xB6dZA= github.com/kataras/iris/v12 v12.1.8/go.mod h1:LMYy4VlP67TQ3Zgriz8RE2h2kMZV2SgMYbq3UhfoFmE= -github.com/kataras/iris/v12 v12.2.0-beta5/go.mod h1:q26aoWJ0Knx/00iPKg5iizDK7oQQSPjbD8np0XDh6dc= github.com/kataras/neffos v0.0.14/go.mod h1:8lqADm8PnbeFfL7CLXh1WHw53dG27MC3pgi2R1rmoTE= github.com/kataras/pio v0.0.2/go.mod h1:hAoW0t9UmXi4R5Oyq5Z4irTbaTsOemSrDGUtaTl7Dro= -github.com/kataras/pio v0.0.11/go.mod h1:38hH6SWH6m4DKSYmRhlrCJ5WItwWgCVrTNU62XZyUvI= github.com/kataras/sitemap v0.0.5/go.mod h1:KY2eugMKiPwsJgx7+U103YZehfvNGOXURubcGyk0Bz8= -github.com/kataras/sitemap v0.0.6/go.mod h1:dW4dOCNs896OR1HmG+dMLdT7JjDk7mYBzoIRwuj5jA4= -github.com/kataras/tunnel v0.0.4/go.mod h1:9FkU4LaeifdMWqZu7o20ojmW4B7hdhv2CMLwfnHGpYw= -github.com/kilic/bls12-381 v0.1.0/go.mod h1:vDTTHJONJ6G+P2R74EhnyotQDTliQDnFEwhdmfzw1ig= github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q= github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= @@ -615,13 +388,9 @@ github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= github.com/kylelemons/godebug v1.1.0 h1:RPNrshWIDI6G2gRW9EHilWtl7Z6Sb1BR0xunSBf0SNc= -github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+fNqagV/RAw= github.com/labstack/echo/v4 v4.5.0/go.mod h1:czIriw4a0C1dFun+ObrXp7ok03xON0N1awStJ6ArI7Y= -github.com/labstack/echo/v4 v4.9.0/go.mod h1:xkCDAdFCIf8jsFQ5NnbK7oqaF/yU1A1X20Ltm0OvSks= github.com/labstack/gommon v0.3.0/go.mod h1:MULnywXg0yavhxWKc+lOruYdAhDwPK9wf0OL7NoOu+k= -github.com/labstack/gommon v0.3.1/go.mod h1:uW6kP17uPlLJsD3ijUYn3/M5bAxtlZhMI6m3MFxTMTM= github.com/leanovate/gopter v0.2.9 h1:fQjYxZaynp97ozCzfOyOuAGOU4aU/z37zf/tOujFk7c= -github.com/leanovate/gopter v0.2.9/go.mod h1:U2L/78B+KVFIx2VmW6onHJQzXtFb+p5y3y2Sh+Jxxv8= github.com/leodido/go-urn v1.2.1/go.mod h1:zt4jvISO2HfUBqxjfIshjdMTYS56ZS/qv49ictyFfxY= github.com/leodido/go-urn v1.2.4 h1:XlAE/cm/ms7TE/VMVoduSpNBoyc2dOxHs5MZSwAN63Q= github.com/leodido/go-urn v1.2.4/go.mod h1:7ZrI8mTSeBSHl/UaRyKQW1qZeMgak41ANeCNaVckg+4= @@ -629,8 +398,6 @@ github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-b github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4= github.com/lyft/protoc-gen-validate v0.0.13/go.mod h1:XbGvPuh87YZc5TdIa2/I4pLk0QoUACkjt2znoq26NVQ= github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= -github.com/mailgun/raymond/v2 v2.0.46/go.mod h1:lsgvL50kgt1ylcFJYZiULi5fjPBkkhNfj4KA0W54Z18= -github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= github.com/mattn/go-colorable v0.1.8/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= @@ -658,11 +425,7 @@ github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zk github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= github.com/mediocregopher/radix/v3 v3.4.2/go.mod h1:8FL3F6UQRXHXIBSPUs5h0RybMF8i4n7wVopoX3x7Bv8= github.com/microcosm-cc/bluemonday v1.0.2/go.mod h1:iVP4YcDBq+n/5fb23BhYFvIMq/leAFZyRl6bYmGDlGc= -github.com/microcosm-cc/bluemonday v1.0.21/go.mod h1:ytNkv4RrDrLJ2pqlsSI46O6IVXmZOBBD4SaJyDwwTkM= github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= -github.com/miekg/pkcs11 v1.1.1/go.mod h1:XsNlhZGX73bx86s2hdc/FuaLm2CPZJemRLMA+WTFxgs= -github.com/minio/sha256-simd v1.0.0/go.mod h1:OuYzVNI5vcoYIAmbIvHPl3N3jUzVedXbKy5RFepssQM= -github.com/mistifyio/go-zfs/v3 v3.0.1/go.mod h1:CzVgeB0RvF2EGzQnytKVvVSDwmKJXxkOTUGbNrTja/k= github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc= github.com/mitchellh/go-homedir v1.0.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= @@ -679,12 +442,6 @@ github.com/mitchellh/pointerstructure v1.2.0/go.mod h1:BRAsLI5zgXmw97Lf6s25bs8oh github.com/mmcloughlin/addchain v0.4.0 h1:SobOdjm2xLj1KkXN5/n0xTIWyZA2+s99UCY1iPfkHRY= github.com/mmcloughlin/addchain v0.4.0/go.mod h1:A86O+tHqZLMNO4w6ZZ4FlVQEadcoqkyU72HC5wJ4RlU= github.com/mmcloughlin/profile v0.1.1/go.mod h1:IhHD7q1ooxgwTgjxQYkACGA77oFTDdFVejUS1/tS/qU= -github.com/moby/locker v1.0.1/go.mod h1:S7SDdo5zpBK84bzzVlKr2V0hz+7x9hWbYC/kq7oQppc= -github.com/moby/spdystream v0.2.0/go.mod h1:f7i0iNDQJ059oMTcWxx8MA/zKFIuD/lY+0GqbN2Wy8c= -github.com/moby/sys/mountinfo v0.6.2/go.mod h1:IJb6JQeOklcdMU9F5xQ8ZALD+CUr5VlGpwtX+VE0rpI= -github.com/moby/sys/sequential v0.5.0/go.mod h1:tH2cOOs5V9MlPiXcQzRC+eEyab644PWKGRYaaV5ZZlo= -github.com/moby/sys/signal v0.7.0/go.mod h1:GQ6ObYZfqacOwTtlXvcmh9A26dVRul/hbOZn88Kg8Tg= -github.com/moby/sys/symlink v0.2.0/go.mod h1:7uZVF2dqJjG/NsClqul95CqKOBRQyYSNnJ6BMgR/gFs= github.com/moby/term v0.5.0 h1:xt8Q1nalod/v7BqbG21f8mQPqH+xAaC9C3N3wfWbVP0= github.com/moby/term v0.5.0/go.mod h1:8FzsFHVUBGZdbDsJw/ot+X+d5HLUbvklYLJ9uGfcI3Y= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -698,7 +455,6 @@ github.com/morikuni/aec v1.0.0 h1:nP9CBfwrvYnBRgY6qfDQkygYDmYwOilePFkwzv4dU8A= github.com/morikuni/aec v1.0.0/go.mod h1:BbKIizmSmc5MMPqRYbxO4ZU0S0+P200+tUnFx7PXmsc= github.com/moul/http2curl v1.0.0/go.mod h1:8UbvGypXm98wA/IqH45anm5Y2Z6ep6O31QGOAZ3H0fQ= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= -github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/naoina/go-stringutil v0.1.0 h1:rCUeRUHjBjGTSHl0VC00jUPLz8/F9dDzYI70Hzifhks= github.com/naoina/go-stringutil v0.1.0/go.mod h1:XJ2SJL9jCtBh+P9q5btrd/Ylo8XwT/h1USek5+NqSA0= github.com/naoina/toml v0.1.2-0.20170918210437-9fafd6967416 h1:shk/vn9oCoOTmwcouEdwIeOtOGA/ELRUw/GwvxwfT+0= @@ -733,10 +489,6 @@ github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8 github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM= github.com/opencontainers/image-spec v1.1.0-rc2.0.20221005185240-3a7f492d3f1b h1:YWuSjZCQAPM8UUBLkYUk1e+rZcvWHJmFb6i6rM44Xs8= github.com/opencontainers/image-spec v1.1.0-rc2.0.20221005185240-3a7f492d3f1b/go.mod h1:3OVijpioIKYWTqjiG0zfF6wvoJ4fAXGbjdZuI2NgsRQ= -github.com/opencontainers/runc v1.1.5/go.mod h1:1J5XiS+vdZ3wCyZybsuxXZWGrgSr8fFJHLXuG2PsnNg= -github.com/opencontainers/runtime-spec v1.1.0-rc.1/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0= -github.com/opencontainers/runtime-tools v0.9.1-0.20221107090550-2e043c6bd626/go.mod h1:BRHJJd0E+cx42OybVYSgUvZmU0B8P9gZuRXlZUP7TKI= -github.com/opencontainers/selinux v1.11.0/go.mod h1:E5dMC3VPuVvVHDYmi78qvhJp8+M586T4DlDRYpFkyec= github.com/opentracing-contrib/go-observer v0.0.0-20170622124052-a52f23424492/go.mod h1:Ngi6UdF0k5OKD5t5wlmGhe/EDKPoUM3BXZSSfIuJbis= github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74= github.com/opentracing/opentracing-go v1.0.2/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o= @@ -749,12 +501,10 @@ github.com/pact-foundation/pact-go v1.0.4/go.mod h1:uExwJY4kCzNPcHRj+hCR/HBbOOIw github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= -github.com/pelletier/go-toml v1.9.5/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c= github.com/pelletier/go-toml/v2 v2.0.1/go.mod h1:r9LEWfGN8R5k0VXJ+0BkIe7MYkRdwZOjgMj2KwnJFUo= github.com/pelletier/go-toml/v2 v2.0.8 h1:0ctb6s9mE31h0/lhu+J6OPmVeDxJn+kYnJc2jZR9tGQ= github.com/pelletier/go-toml/v2 v2.0.8/go.mod h1:vuYfssBdrU2XDZ9bYydBu6t+6a6PYNcZljzZR9VXg+4= github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac= -github.com/peterh/liner v1.1.1-0.20190123174540-a2c9a5303de7/go.mod h1:CRroGNssyjTd/qIG2FyxByd2S8JEAZXBl4qUrZf8GS0= github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc= github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4= @@ -793,7 +543,6 @@ github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsT github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A= github.com/prometheus/procfs v0.9.0 h1:wzCHvIvM5SxWqYvwgVL7yJY8Lz3PKn49KQtpgMYJfhI= github.com/prometheus/procfs v0.9.0/go.mod h1:+pB4zwohETzFnmlpe6yd2lSc+0/46IYZRB/chUwxUZY= -github.com/protolambda/bls12-381-util v0.0.0-20220416220906-d8552aa452c7/go.mod h1:IToEjHuttnUzwZI5KBSM/LOOW3qLbbrHOEfp3SbECGY= github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= @@ -805,7 +554,6 @@ github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/f github.com/rs/cors v1.7.0 h1:+88SsELBHx5r+hZ8TCkggzSstaWNbDvThkVK8H6f9ik= github.com/rs/cors v1.7.0/go.mod h1:gFx+x8UowdsKA9AchylcLynDq+nNFfI8FkUZdN/jGCU= github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g= -github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY= github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= @@ -832,15 +580,12 @@ github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= github.com/spf13/cobra v0.0.5/go.mod h1:3K3wKZymM7VvHMDS9+Akkh4K60UwM26emMESw8tLCHU= -github.com/spf13/cobra v1.5.0/go.mod h1:dWXEIy2H428czQCjInthrTRUg7yKbok+2Qi/yBIJoUM= github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo= github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= -github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s= github.com/status-im/keycard-go v0.2.0 h1:QDLFswOQu1r5jsycloeQh3bVU8n/NatHHaZobtDnDzA= github.com/status-im/keycard-go v0.2.0/go.mod h1:wlp8ZLbsmrF6g6WjugPAx+IzoLrkdf9+mHxBEeo3Hbg= -github.com/stefanberger/go-pkcs11uri v0.0.0-20201008174630-78d3cae3a980/go.mod h1:AO3tvPzVZ/ayst6UlUKUv6rcPQInYe3IknH3jYhAKu8= github.com/streadway/amqp v0.0.0-20190404075320-75d898a42a94/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= github.com/streadway/handy v0.0.0-20190108123426-d5acb3125c2a/go.mod h1:qNTQ5P5JnDBl6z3cMAg/SywNDC5ABu5ApDIw6lUbRmI= @@ -864,12 +609,8 @@ github.com/stretchr/testify v1.8.3 h1:RP3t2pwF7cMEbC1dqtB6poj3niw/9gnV4Cjg5oW5gt github.com/stretchr/testify v1.8.3/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= github.com/supranational/blst v0.3.11 h1:LyU6FolezeWAhvQk0k6O/d49jqgO52MSDDfYgbeoEm4= github.com/supranational/blst v0.3.11/go.mod h1:jZJtfjgudtNl4en1tzwPIV3KjUnQUvG3/j+w+fVonLw= -github.com/syndtr/gocapability v0.0.0-20200815063812-42c35b437635/go.mod h1:hkRG7XYTFWNJGYcbNJQlaLq0fg1yr4J4t/NcTQtrfww= github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7 h1:epCh84lMvA70Z7CTTCmYQn2CKbY8j86K7/FAIr141uY= github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7/go.mod h1:q4W45IWZaF22tdD+VEXcAWRA037jwmWEB5VWYORlTpc= -github.com/tchap/go-patricia/v2 v2.3.1/go.mod h1:VZRHKAb53DLaG+nA9EaYYiaEx6YztwDlLElMsnSHD4k= -github.com/tdewolff/minify/v2 v2.12.4/go.mod h1:h+SRvSIX3kwgwTFOpSckvSxgax3uy8kZTSF1Ojrr3bk= -github.com/tdewolff/parse/v2 v2.6.4/go.mod h1:woz0cgbLwFdtbjJu8PIKxhW05KplTFQkOdX78o+Jgrs= github.com/tidwall/gjson v1.11.0 h1:C16pk7tQNiH6VlCrtIXL1w8GaOsi1X3W8KDkE1BuYd4= github.com/tidwall/gjson v1.11.0/go.mod h1:/wbyibRr2FHMks5tjHJ5F8dMZh3AcwJEMf5vlfC0lxk= github.com/tidwall/match v1.1.1 h1:+Ho715JplO36QYgwN9PGYNhgZvoUSc9X2c80KVTi+GA= @@ -895,7 +636,6 @@ github.com/ugorji/go/codec v1.2.11 h1:BMaWp1Bb6fHwEtbplGBGJ498wD+LKlNSl25MjdZY4d github.com/ugorji/go/codec v1.2.11/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA= github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= -github.com/urfave/cli v1.22.12/go.mod h1:sSBEIC79qR6OvcmsD4U3KABeOTxDqQtdDnaFuUN30b8= github.com/urfave/cli/v2 v2.24.1 h1:/QYYr7g0EhwXEML8jO+8OYt5trPnLHS0p3mrgExJ5NU= github.com/urfave/cli/v2 v2.24.1/go.mod h1:GHupkWPMM0M/sj1a2b4wUrWBPzazNrIjouW6fmdJLxc= github.com/urfave/negroni v1.0.0/go.mod h1:Meg73S6kFm/4PpbYdq35yYWoCZ9mS/YSx+lKnmiohz4= @@ -907,12 +647,6 @@ github.com/valyala/fasthttp v1.48.0/go.mod h1:k2zXd82h/7UZc3VOdJ2WaUqt1uZ/XpXAfE github.com/valyala/fasttemplate v1.0.1/go.mod h1:UQGH1tvbgY+Nz5t2n7tXsz52dQxojPUpymEIMZ47gx8= github.com/valyala/fasttemplate v1.2.1/go.mod h1:KHLXt3tVN2HBp8eijSv/kGJopbvo7S+qRAEEKiv+SiQ= github.com/valyala/tcplisten v0.0.0-20161114210144-ceec8f93295a/go.mod h1:v3UYOV9WzVtRmSR+PDvWpU/qWl4Wa5LApYYX4ZtKbio= -github.com/valyala/tcplisten v1.0.0/go.mod h1:T0xQ8SeCZGxckz9qRXTfG43PvQ/mcWh7FwZEA7Ioqkc= -github.com/vishvananda/netlink v1.2.1-beta.2/go.mod h1:twkDnbuQxJYemMlGd4JFIcuhgX83tXhKS2B/PRMpOho= -github.com/vishvananda/netns v0.0.0-20210104183010-2eb08e3e575f/go.mod h1:DD4vA1DwXk04H54A1oHXtwZmA0grkVMdPxx/VGLCah0= -github.com/vmihailenco/msgpack v4.0.4+incompatible/go.mod h1:fy3FlTQTDXWkZ7Bh6AcGMlsjHatGryHQYUTf1ShIgkk= -github.com/vmihailenco/msgpack/v5 v5.3.5/go.mod h1:7xyJ9e+0+9SaZT0Wt1RGleJXzli6Q/V5KbhBonMG9jc= -github.com/vmihailenco/tagparser/v2 v2.0.0/go.mod h1:Wri+At7QHww0WTrCBeu4J6bNtoV6mEfg5OIWRZA9qds= github.com/xeipuuv/gojsonpointer v0.0.0-20180127040702-4e3ac2762d5f/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU= github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415/go.mod h1:GwrjFmJcFw6At/Gs6z4yjiIwzuJ1/+UwLxMQDVQXShQ= github.com/xeipuuv/gojsonschema v1.2.0/go.mod h1:anYRn/JVcOK2ZgGU+IjEV4nwlhoK5sQluxsYJ78Id3Y= @@ -921,35 +655,19 @@ github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1: github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 h1:bAn7/zixMGCfxrRTfdpNzjtPYqr8smhKouy9mxVdGPU= github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673/go.mod h1:N3UwUGtsrSj3ccvlPHLoLsHnpR27oXr4ZE984MbSER8= github.com/yalp/jsonpath v0.0.0-20180802001716-5cc68e5049a0/go.mod h1:/LWChgwKmvncFJFHJ7Gvn9wZArjbV5/FppcK2fKk/tI= -github.com/yosssi/ace v0.0.5/go.mod h1:ALfIzm2vT7t5ZE7uoIZqF3TQ7SAOyupFZnkrF5id+K0= github.com/yudai/gojsondiff v1.0.0/go.mod h1:AY32+k2cwILAkW1fbgxQ5mUmMiZFgLIV+FBNExI05xg= github.com/yudai/golcs v0.0.0-20170316035057-ecda9a501e82/go.mod h1:lgjkn3NuSvDfVJdfcVVdX+jpBxNmX4rDAzaS45IcYoM= github.com/yudai/pp v2.0.1+incompatible/go.mod h1:PuxR/8QJ7cyCkFp/aUDS+JY727OFEZkTdatxwunjIkc= github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= -github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= -go.etcd.io/bbolt v1.3.7/go.mod h1:N9Mkw9X8x5fupy0IKsmuqVtoGDyxsaDlbk4Rd05IAQw= go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg= -go.mozilla.org/pkcs7 v0.0.0-20200128120323-432b2356ecb1/go.mod h1:SNgMg+EgDFwmvSmLRTNKC5fegJjB7v23qTQ0XLGUNHk= go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk= go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk= go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= -go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= -go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.40.0/go.mod h1:UMklln0+MRhZC4e3PwmN3pCtq4DyIadWw4yikh6bNrw= -go.opentelemetry.io/otel v1.14.0/go.mod h1:o4buv+dJzx8rohcUeRmWUZhqupFvzWis188WlggnNeU= -go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.14.0/go.mod h1:UFG7EBMRdXyFstOwH028U0sVf+AvukSGhF0g8+dmNG8= -go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.14.0/go.mod h1:HrbCVv40OOLTABmOn1ZWty6CHXkU8DK/Urc43tHug70= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.14.0/go.mod h1:5w41DY6S9gZrbjuq6Y+753e96WfPha5IcsOSZTtullM= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.14.0/go.mod h1:+N7zNjIJv4K+DeX67XXET0P+eIciESgaFDBqh+ZJFS4= -go.opentelemetry.io/otel/metric v0.37.0/go.mod h1:DmdaHfGt54iV6UKxsV9slj2bBRJcKC1B1uvDLIioc1s= -go.opentelemetry.io/otel/sdk v1.14.0/go.mod h1:bwIC5TjrNG6QDCHNWvW4HLHtUQ4I+VQDsnjhvyZCALM= -go.opentelemetry.io/otel/trace v1.14.0/go.mod h1:8avnQLK+CG77yNLUae4ea2JDQ6iT+gozhnZjy/rw9G8= -go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= -go.uber.org/automaxprocs v1.5.2/go.mod h1:eRbA25aqJrxAbsLO0xy5jVwPt7FQnRgjW+efnwa1WM0= go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= go.uber.org/multierr v1.3.0/go.mod h1:VgVr7evmIr6uPjLBxg28wmKNXyqE9akIJ5XnfpiKl+4= go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA= @@ -1023,7 +741,6 @@ golang.org/x/net v0.10.0 h1:X2//UzNDwYmtCLn7To6G58Wr6f5ahEAQgKNzv9Y951M= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= -golang.org/x/oauth2 v0.4.0/go.mod h1:RznEsdpjGAINPTOF0UH/t+xJ75L18YO3Ho6Pyn+uRec= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -1084,7 +801,6 @@ golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.11.0 h1:eG7RXZHdqOJ1i+0lgLgCpSXAp6M3LYlAo6osgSi0xOM= golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= -golang.org/x/term v0.11.0/go.mod h1:zC9APTIj3jG3FdV/Ons+XE1riIZXG4aZ4GTHiPZJPIU= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= @@ -1097,7 +813,6 @@ golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxb golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20201208040808-7e3f01d25324/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.3.0 h1:rg5rLMjNzMS1RkNLzCG38eapWhnYLFYXDXj2gOlr8j4= -golang.org/x/time v0.3.0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= @@ -1126,7 +841,6 @@ golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8T golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20220517211312-f3a8303e98df h1:5Pf6pFKu98ODmgnpvkJ3kFUOQGGLIzLIkbzUHp47618= -golang.org/x/xerrors v0.0.0-20220517211312-f3a8303e98df/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= google.golang.org/api v0.3.1/go.mod h1:6wY9I6uQWHQ8EM57III9mq/AjF+i8G65rmVagqKMtkk= google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= @@ -1184,9 +898,7 @@ gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMy gopkg.in/gcfg.v1 v1.2.3/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o= gopkg.in/go-playground/assert.v1 v1.2.1/go.mod h1:9RXL0bg/zibRAgZUYszZSwO/z8Y/a8bDuhia5mkpMnE= gopkg.in/go-playground/validator.v8 v8.18.2/go.mod h1:RX2a/7Ha8BgOhfk7j780h4/u/RRjR0eouCJSH80/M2Y= -gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= gopkg.in/ini.v1 v1.51.1/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= -gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= gopkg.in/mgo.v2 v2.0.0-20180705113604-9856a29383ce/go.mod h1:yeKp02qBN3iKW1OzL3MGk2IdtZzaj7SFntXj72NppTA= gopkg.in/natefinch/lumberjack.v2 v2.0.0 h1:1Lc07Kr7qY4U2YPouBjpCLxpiyxIVoxqXgkXLknAOE8= gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k= @@ -1216,19 +928,8 @@ honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWh honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg= -k8s.io/api v0.26.2/go.mod h1:1kjMQsFE+QHPfskEcVNgL3+Hp88B80uj0QtSOlj8itU= -k8s.io/apimachinery v0.26.2/go.mod h1:ats7nN1LExKHvJ9TmwootT00Yz05MuYqPXEXaVeOy5I= -k8s.io/apiserver v0.26.2/go.mod h1:GHcozwXgXsPuOJ28EnQ/jXEM9QeG6HT22YxSNmpYNh8= -k8s.io/client-go v0.26.2/go.mod h1:u5EjOuSyBa09yqqyY7m3abZeovO/7D/WehVVlZ2qcqU= -k8s.io/component-base v0.26.2/go.mod h1:DxbuIe9M3IZPRxPIzhch2m1eT7uFrSBJUBuVCQEBivs= -k8s.io/cri-api v0.27.1/go.mod h1:+Ts/AVYbIo04S86XbTD73UPp/DkTiYxtsFeOFEu32L0= -k8s.io/klog/v2 v2.90.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0= -k8s.io/utils v0.0.0-20230220204549-a5ecb0141aa5/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= rsc.io/tmplfunc v0.0.3 h1:53XFQh69AfOa8Tw0Jm7t+GV7KZhOi6jzsCzTtKbMvzU= rsc.io/tmplfunc v0.0.3/go.mod h1:AG3sTPzElb1Io3Yg4voV9AGZJuleGAwaVRxL9M49PhA= -sigs.k8s.io/json v0.0.0-20220713155537-f223a00ba0e2/go.mod h1:B8JuhiUyNFVKdsE8h686QcCxMaH6HrOAZj4vswFpcB0= -sigs.k8s.io/structured-merge-diff/v4 v4.2.3/go.mod h1:qjx8mGObPmV2aSZepjQjbmb2ihdVs8cGKBraizNC69E= sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o= -sigs.k8s.io/yaml v1.3.0/go.mod h1:GeOyir5tyXNByN85N/dRIT9es5UQNerPYEKK56eTBm8= sourcegraph.com/sourcegraph/appdash v0.0.0-20190731080439-ebfcffb1b5c0/go.mod h1:hI742Nqp5OhwiqlzhgfbWU4mW4yO10fP+LoT9WOswdU= diff --git a/go/common/flag/flag.go b/go/common/flag/flag.go new file mode 100644 index 0000000000..5e8c36b6a2 --- /dev/null +++ b/go/common/flag/flag.go @@ -0,0 +1,168 @@ +package flag + +import ( + "flag" + "fmt" + "os" + "strconv" + "strings" +) + +// WrappedFlag is a construct that allows to have go flags while obeying to a new set of restricteveness rules +type WrappedFlag struct { + flagType string + ptr any + defaultValue any + description string +} + +// GetString returns the flag current value casted to string +func (f WrappedFlag) GetString() string { + return *f.ptr.(*string) +} + +// GetInt64 returns the flag current value casted to int64 +func (f WrappedFlag) GetInt64() int64 { + return *f.ptr.(*int64) +} + +// GetBool returns the flag current value casted to bool +func (f WrappedFlag) GetBool() bool { + return *f.ptr.(*bool) +} + +// singletonFlagger is the singleton instance of the loaded flags +var singletonFlagger = map[string]*WrappedFlag{} + +// String directly uses the go flag package +func String(flagName, defaultValue, description string) *string { + return flag.String(flagName, defaultValue, description) +} + +// RestrictedString wraps the go flag package depending on the restriction mode +func RestrictedString(flagName, defaultValue, description string) *WrappedFlag { + prtVal := new(string) + singletonFlagger[flagName] = &WrappedFlag{ + flagType: "string", + ptr: prtVal, + defaultValue: defaultValue, + description: description, + } + return singletonFlagger[flagName] +} + +// Int64 directly uses the go flag package +func Int64(flagName string, defaultValue int64, description string) *int64 { + return flag.Int64(flagName, defaultValue, description) +} + +// RestrictedInt64 wraps the go flag package depending on the restriction mode +func RestrictedInt64(flagName string, defaultValue int64, description string) *WrappedFlag { + prtVal := new(int64) + singletonFlagger[flagName] = &WrappedFlag{ + flagType: "int64", + ptr: prtVal, + defaultValue: defaultValue, + description: description, + } + return singletonFlagger[flagName] +} + +// Bool directly uses the go flag package +func Bool(flagName string, defaultValue bool, description string) *bool { + return flag.Bool(flagName, defaultValue, description) +} + +// RestrictedBool wraps the go flag package depending on the restriction mode +func RestrictedBool(flagName string, defaultValue bool, description string) *WrappedFlag { + prtVal := new(bool) + singletonFlagger[flagName] = &WrappedFlag{ + flagType: "bool", + ptr: prtVal, + defaultValue: defaultValue, + description: description, + } + return singletonFlagger[flagName] +} + +// Int directly uses the go flag package +func Int(flagName string, defaultValue int, description string) *int { + return flag.Int(flagName, defaultValue, description) +} + +// Uint64 directly uses the go flag package +func Uint64(flagName string, defaultValue uint64, description string) *uint64 { + return flag.Uint64(flagName, defaultValue, description) +} + +// Parse ensures the restricted mode is applied only to restricted flags +// Restricted Mode - Flags can only be inputted via ENV Vars via the enclave.json +// Non-Restricted Mode - Flags can only be inputted via normal CLI command line +func Parse() error { + mandatoryEnvFlags := false + val := os.Getenv("EDG_RESTRICTED") + if val == "true" { + fmt.Println("Using mandatory signed configurations.") + mandatoryEnvFlags = true + } + + for flagName, wflag := range singletonFlagger { + // parse restricted flags if in restricted mode + if mandatoryEnvFlags { + err := parseMandatoryFlags(flagName, wflag) + if err != nil { + return fmt.Errorf("unable to parse mandatory flag: %s - %w", flagName, err) + } + } else { + err := parseNonMandatoryFlag(flagName, wflag) + if err != nil { + return fmt.Errorf("unable to parse flag: %s - %w", flagName, err) + } + } + } + + // parse all remaining flags + flag.Parse() + return nil +} + +func parseNonMandatoryFlag(flagName string, wflag *WrappedFlag) error { + switch wflag.flagType { + case "string": + wflag.ptr = flag.String(flagName, wflag.defaultValue.(string), wflag.description) + case "int64": + wflag.ptr = flag.Int64(flagName, wflag.defaultValue.(int64), wflag.description) + case "bool": + wflag.ptr = flag.Bool(flagName, wflag.defaultValue.(bool), wflag.description) + default: + return fmt.Errorf("unexpected type: %s", wflag.flagType) + } + return nil +} + +func parseMandatoryFlags(flagName string, wflag *WrappedFlag) error { + val := os.Getenv("EDG_" + strings.ToUpper(flagName)) + if val == "" { + return fmt.Errorf("mandatory restricted flag not available - %s", flagName) + } + + switch wflag.flagType { + case "string": + wflag.ptr = &val + case "int64": + i, err := strconv.ParseInt(val, 10, 64) + if err != nil { + return fmt.Errorf("unable to parse flag %s - %w", flagName, err) + } + wflag.ptr = &i + case "bool": + b, err := strconv.ParseBool(val) + if err != nil { + return fmt.Errorf("unable to parse flag %s - %w", flagName, err) + } + wflag.ptr = &b + default: + return fmt.Errorf("unexpected mandatory type: %s", wflag.flagType) + } + return nil +} diff --git a/go/common/flag/flag_test.go b/go/common/flag/flag_test.go new file mode 100644 index 0000000000..bae24294cb --- /dev/null +++ b/go/common/flag/flag_test.go @@ -0,0 +1,68 @@ +package flag + +import ( + "fmt" + "os" + "strings" + "testing" + + "github.com/stretchr/testify/require" +) + +func TestStringFlagCreation(t *testing.T) { + expected := "Not the Default" + flagName := "testString" + + // Create the flag + flagOutput := String(flagName, "default", "Test string flag") + + // Parse the flag + os.Args = []string{"cmd", fmt.Sprintf("-%s=%s", flagName, expected)} + + // Parse the flags + require.NoError(t, Parse()) + + // Verify the flag value + require.Equal(t, expected, *flagOutput) +} + +func TestParseInRestrictedMode(t *testing.T) { + // Set up restricted mode + t.Setenv("EDG_RESTRICTED", "true") + defer os.Unsetenv("EDG_RESTRICTED") + + // Create a restricted flag + flagName := "testFlag" + flagOutput := RestrictedString(flagName, "default", "Test restricted flag") + + // Mimic setting the environment variable for the restricted flag + expectedValue := "restrictedValue" + t.Setenv("EDG_"+strings.ToUpper(flagName), expectedValue) + + defer os.Unsetenv("EDG_" + strings.ToUpper(flagName)) + + // Parse the flags + require.NoError(t, Parse()) + + // Verify the flag value + require.Equal(t, expectedValue, flagOutput.GetString()) +} + +func TestParseInUnrestrictedMode(t *testing.T) { + // Ensure unrestricted mode + os.Unsetenv("EDG_RESTRICTED") + + // Create a regular flag + flagName := "testUnrestrictedFlag" + expected := int64(12345) + // Parse the flag + os.Args = []string{"cmd", fmt.Sprintf("-%s=%d", flagName, expected)} + + flagOutput := RestrictedInt64(flagName, int64(1), "Test flag") + + // Parse the flags + require.NoError(t, Parse()) + + // Verify the flag value + require.Equal(t, expected, flagOutput.GetInt64()) +} diff --git a/go/enclave/container/cli.go b/go/enclave/container/cli.go index baf7cf0c6a..c440b95de2 100644 --- a/go/enclave/container/cli.go +++ b/go/enclave/container/cli.go @@ -1,16 +1,14 @@ package container import ( - "flag" "fmt" "math/big" - "os" "github.com/ten-protocol/go-ten/go/common" + "github.com/ten-protocol/go-ten/go/common/flag" + "github.com/ten-protocol/go-ten/go/config" gethcommon "github.com/ethereum/go-ethereum/common" - "github.com/naoina/toml" - "github.com/ten-protocol/go-ten/go/config" ) // EnclaveConfigToml is the structure that an enclave's .toml config is parsed into. @@ -49,37 +47,37 @@ func ParseConfig() (*config.EnclaveConfig, error) { cfg := config.DefaultEnclaveConfig() flagUsageMap := getFlagUsageMap() - configPath := flag.String(configName, "", flagUsageMap[configName]) hostID := flag.String(hostIDName, cfg.HostID.Hex(), flagUsageMap[hostIDName]) hostAddress := flag.String(hostAddressName, cfg.HostAddress, flagUsageMap[hostAddressName]) address := flag.String(addressName, cfg.Address, flagUsageMap[addressName]) nodeTypeStr := flag.String(nodeTypeName, cfg.NodeType.String(), flagUsageMap[nodeTypeName]) - l1ChainID := flag.Int64(l1ChainIDName, cfg.L1ChainID, flagUsageMap[l1ChainIDName]) - obscuroChainID := flag.Int64(obscuroChainIDName, cfg.ObscuroChainID, flagUsageMap[obscuroChainIDName]) willAttest := flag.Bool(willAttestName, cfg.WillAttest, flagUsageMap[willAttestName]) validateL1Blocks := flag.Bool(validateL1BlocksName, cfg.ValidateL1Blocks, flagUsageMap[validateL1BlocksName]) managementContractAddress := flag.String(ManagementContractAddressName, cfg.ManagementContractAddress.Hex(), flagUsageMap[ManagementContractAddressName]) loglevel := flag.Int(logLevelName, cfg.LogLevel, flagUsageMap[logLevelName]) logPath := flag.String(logPathName, cfg.LogPath, flagUsageMap[logPathName]) - useInMemoryDB := flag.Bool(useInMemoryDBName, cfg.UseInMemoryDB, flagUsageMap[useInMemoryDBName]) edgelessDBHost := flag.String(edgelessDBHostName, cfg.EdgelessDBHost, flagUsageMap[edgelessDBHostName]) sqliteDBPath := flag.String(sqliteDBPathName, cfg.SqliteDBPath, flagUsageMap[sqliteDBPathName]) - profilerEnabled := flag.Bool(profilerEnabledName, cfg.ProfilerEnabled, flagUsageMap[profilerEnabledName]) minGasPrice := flag.Int64(minGasPriceName, cfg.MinGasPrice.Int64(), flagUsageMap[minGasPriceName]) messageBusAddress := flag.String(messageBusAddressName, cfg.MessageBusAddress.Hex(), flagUsageMap[messageBusAddressName]) sequencerID := flag.String(sequencerIDName, cfg.SequencerID.Hex(), flagUsageMap[sequencerIDName]) - obscuroGenesis := flag.String(obscuroGenesisName, cfg.ObscuroGenesis, flagUsageMap[obscuroGenesisName]) - debugNamespaceEnabled := flag.Bool(debugNamespaceEnabledName, cfg.DebugNamespaceEnabled, flagUsageMap[debugNamespaceEnabledName]) maxBatchSize := flag.Uint64(maxBatchSizeName, cfg.MaxBatchSize, flagUsageMap[maxBatchSizeName]) maxRollupSize := flag.Uint64(maxRollupSizeName, cfg.MaxRollupSize, flagUsageMap[maxRollupSizeName]) baseFee := flag.Uint64("l2BaseFee", cfg.BaseFee.Uint64(), "") coinbaseAddress := flag.String("l2Coinbase", cfg.GasPaymentAddress.Hex(), "") gasLimit := flag.Uint64("l2GasLimit", cfg.GasLimit.Uint64(), "") - flag.Parse() + // set of restricted flags that can only be set in the signed enclave.json + obscuroGenesis := flag.RestrictedString(obscuroGenesisName, cfg.ObscuroGenesis, flagUsageMap[obscuroGenesisName]) + l1ChainID := flag.RestrictedInt64(l1ChainIDName, cfg.L1ChainID, flagUsageMap[l1ChainIDName]) + obscuroChainID := flag.RestrictedInt64(obscuroChainIDName, cfg.ObscuroChainID, flagUsageMap[obscuroChainIDName]) + useInMemoryDB := flag.RestrictedBool(useInMemoryDBName, cfg.UseInMemoryDB, flagUsageMap[useInMemoryDBName]) + profilerEnabled := flag.RestrictedBool(profilerEnabledName, cfg.ProfilerEnabled, flagUsageMap[profilerEnabledName]) + debugNamespaceEnabled := flag.RestrictedBool(debugNamespaceEnabledName, cfg.DebugNamespaceEnabled, flagUsageMap[debugNamespaceEnabledName]) - if *configPath != "" { - return fileBasedConfig(*configPath) + err := flag.Parse() + if err != nil { + return nil, err } nodeType, err := common.ToNodeType(*nodeTypeStr) @@ -91,22 +89,22 @@ func ParseConfig() (*config.EnclaveConfig, error) { cfg.HostAddress = *hostAddress cfg.Address = *address cfg.NodeType = nodeType - cfg.L1ChainID = *l1ChainID - cfg.ObscuroChainID = *obscuroChainID + cfg.L1ChainID = l1ChainID.GetInt64() + cfg.ObscuroChainID = obscuroChainID.GetInt64() cfg.WillAttest = *willAttest cfg.ValidateL1Blocks = *validateL1Blocks cfg.ManagementContractAddress = gethcommon.HexToAddress(*managementContractAddress) cfg.LogLevel = *loglevel cfg.LogPath = *logPath - cfg.UseInMemoryDB = *useInMemoryDB + cfg.UseInMemoryDB = useInMemoryDB.GetBool() cfg.EdgelessDBHost = *edgelessDBHost cfg.SqliteDBPath = *sqliteDBPath - cfg.ProfilerEnabled = *profilerEnabled + cfg.ProfilerEnabled = profilerEnabled.GetBool() cfg.MinGasPrice = big.NewInt(*minGasPrice) cfg.MessageBusAddress = gethcommon.HexToAddress(*messageBusAddress) cfg.SequencerID = gethcommon.HexToAddress(*sequencerID) - cfg.ObscuroGenesis = *obscuroGenesis - cfg.DebugNamespaceEnabled = *debugNamespaceEnabled + cfg.ObscuroGenesis = obscuroGenesis.GetString() + cfg.DebugNamespaceEnabled = debugNamespaceEnabled.GetBool() cfg.MaxBatchSize = *maxBatchSize cfg.MaxRollupSize = *maxRollupSize cfg.BaseFee = big.NewInt(0).SetUint64(*baseFee) @@ -115,41 +113,3 @@ func ParseConfig() (*config.EnclaveConfig, error) { return cfg, nil } - -// Parses the config from the .toml file at configPath. -func fileBasedConfig(configPath string) (*config.EnclaveConfig, error) { - bytes, err := os.ReadFile(configPath) - if err != nil { - panic(fmt.Sprintf("could not read config file at %s. Cause: %s", configPath, err)) - } - - var tomlConfig EnclaveConfigToml - err = toml.Unmarshal(bytes, &tomlConfig) - if err != nil { - panic(fmt.Sprintf("could not read config file at %s. Cause: %s", configPath, err)) - } - - nodeType, err := common.ToNodeType(tomlConfig.NodeType) - if err != nil { - return nil, fmt.Errorf("unrecognised node type '%s'", tomlConfig.NodeType) - } - - return &config.EnclaveConfig{ - HostID: gethcommon.HexToAddress(tomlConfig.HostID), - HostAddress: tomlConfig.HostAddress, - Address: tomlConfig.Address, - NodeType: nodeType, - L1ChainID: tomlConfig.L1ChainID, - ObscuroChainID: tomlConfig.ObscuroChainID, - WillAttest: tomlConfig.WillAttest, - ValidateL1Blocks: tomlConfig.ValidateL1Blocks, - ManagementContractAddress: gethcommon.HexToAddress(tomlConfig.ManagementContractAddress), - LogLevel: tomlConfig.LogLevel, - LogPath: tomlConfig.LogPath, - UseInMemoryDB: tomlConfig.UseInMemoryDB, - GenesisJSON: []byte(tomlConfig.GenesisJSON), - EdgelessDBHost: tomlConfig.EdgelessDBHost, - SqliteDBPath: tomlConfig.SqliteDBPath, - ProfilerEnabled: tomlConfig.ProfilerEnabled, - }, nil -} diff --git a/go/enclave/container/cli_test.go b/go/enclave/container/cli_test.go deleted file mode 100644 index 33d03f3b45..0000000000 --- a/go/enclave/container/cli_test.go +++ /dev/null @@ -1,95 +0,0 @@ -package container - -import ( - "os" - "path" - "reflect" - "sort" - "strconv" - "strings" - "testing" - - "github.com/ten-protocol/go-ten/go/config" -) - -const ( - testToml = "/test.toml" - expectedChainID = int64(1377) -) - -func TestConfigIsParsedFromTomlFileIfConfigFlagIsPresent(t *testing.T) { - wd, err := os.Getwd() - if err != nil { - panic(err) - } - - cfg, err := fileBasedConfig(path.Join(wd, testToml)) - if err != nil { - t.Fatalf("could not parse config. Cause: %s", err) - } - if cfg.L1ChainID != expectedChainID { - t.Fatalf("config file was not parsed from TOML. Expected L1ChainID of %d, got %d", expectedChainID, cfg.L1ChainID) - } -} - -func TestConfigIsParsedFromCmdLineFlagsIfConfigFlagIsNotPresent(t *testing.T) { - os.Args = append(os.Args, "--"+l1ChainIDName, strconv.FormatInt(expectedChainID, 10)) - - cfg, err := ParseConfig() - if err != nil { - t.Fatalf("could not parse config. Cause: %s", err) - } - if cfg.L1ChainID != expectedChainID { - t.Fatalf("config file was not parsed from flags. Expected L1ChainID of %d, got %d", expectedChainID, cfg.L1ChainID) - } -} - -func TestConfigFieldsMatchTomlConfigFields(t *testing.T) { - // We get all the config fields. - cfgReflection := reflect.TypeOf(config.EnclaveConfig{}) - cfgFields := make([]string, cfgReflection.NumField()) - for i := 0; i < cfgReflection.NumField(); i++ { - cfgFields[i] = cfgReflection.Field(i).Name - } - - // We get all the .toml config fields. - cfgTomlReflection := reflect.TypeOf(EnclaveConfigToml{}) - cfgTomlFields := make([]string, cfgTomlReflection.NumField()) - for i := 0; i < cfgTomlReflection.NumField(); i++ { - cfgTomlFields[i] = cfgTomlReflection.Field(i).Name - } - - sort.Strings(cfgFields) - sort.Strings(cfgTomlFields) - - if !reflect.DeepEqual(cfgFields, cfgTomlFields) { - t.Fatalf("config file supports the following fields: %s, but .toml config file supports the following fields: %s", cfgFields, cfgTomlFields) - } -} - -func TestConfigFlagsMatchConfigFields(t *testing.T) { - t.Skip("TODO - Reenable test when it's less disruptive to rename the CLI flags for consistency.") - - // We get all the config fields. - cfgReflection := reflect.TypeOf(config.HostConfig{}) - cfgFields := make([]string, cfgReflection.NumField()) - for i := 0; i < cfgReflection.NumField(); i++ { - cfgFields[i] = strings.ToLower(cfgReflection.Field(i).Name) - } - - // We get all the CLI flags via the usages map. - flagUsageMap := getFlagUsageMap() - i := 0 - cliFlags := make([]string, len(flagUsageMap)) - for key := range flagUsageMap { - cliFlags[i] = strings.ToLower(key) - i++ - } - - sort.Strings(cfgFields) - sort.Strings(cliFlags) - - if !reflect.DeepEqual(cfgFields, cliFlags) { - t.Fatalf("config file supports the following fields: %s, but there are CLI flags for the following fields: %s", cfgFields, cliFlags) - } -} diff --git a/go/enclave/container/test.toml b/go/enclave/container/test.toml deleted file mode 100644 index 196bf80f0d..0000000000 --- a/go/enclave/container/test.toml +++ /dev/null @@ -1,15 +0,0 @@ -hostID = "0x0000000000000000000000000000000000000001" -hostAddress = "127.0.0.1:10000" -address = "127.0.0.1:11000" -nodeType = "sequencer" -l1ChainID = 1377 -obscuroChainID = 443 -willAttest = false -validateL1Blocks = false -managementContractAddress = "0x0000000000000000000000000000000000000000" -logLevel = 3 -logPath = "enclave_logs.txt" -useInMemoryDb = true -sequencerID = "0x0000000000000000000000000000000000000000" -obscuroGenesis = "" -debugNamespaceEnabled = false \ No newline at end of file diff --git a/go/enclave/main/enclave-test.json b/go/enclave/main/enclave-test.json new file mode 100644 index 0000000000..3e2c3bbcf7 --- /dev/null +++ b/go/enclave/main/enclave-test.json @@ -0,0 +1,23 @@ +{ + "exe": "main", + "key": "testnet.pem", + "debug": true, + "heapSize": 4096, + "executableHeap": true, + "productID": 1, + "securityVersion": 1, + "mounts": [ + { + "source": "/enclavedata", + "target": "/data", + "type": "hostfs", + "readOnly": false + } + ], + "env": [ + { + "name": "RESTRICTED", + "value": "false" + } + ] +} \ No newline at end of file diff --git a/go/enclave/main/enclave.json b/go/enclave/main/enclave.json index 8150c9e596..3db18c70d4 100644 --- a/go/enclave/main/enclave.json +++ b/go/enclave/main/enclave.json @@ -13,5 +13,35 @@ "type": "hostfs", "readOnly": false } + ], + "env": [ + { + "name": "RESTRICTED", + "value": "true" + }, + { + "name": "L1CHAINID", + "value": "1" + }, + { + "name": "OBSCUROCHAINID", + "value": "443" + }, + { + "name": "OBSCUROGENESIS", + "value": "{}" + }, + { + "name": "USEINMEMORYDB", + "value": "false" + }, + { + "name": "PROFILERENABLED", + "value": "false" + }, + { + "name": "DEBUGNAMESPACENEABLED", + "value": "false" + } ] } \ No newline at end of file diff --git a/testnet/docker-compose.local.yml b/testnet/docker-compose.local.yml index af7fcbef6d..00a56026e5 100644 --- a/testnet/docker-compose.local.yml +++ b/testnet/docker-compose.local.yml @@ -17,6 +17,8 @@ services: build: context: $ROOT_PATH dockerfile: ./dockerfiles/enclave.Dockerfile + args: + RESTRICTEDMODE: false enclave-debug: image: "testnetobscuronet.azurecr.io/obscuronet/enclave_debug:latest" build: diff --git a/testnet/testnet-local-build_images.sh b/testnet/testnet-local-build_images.sh index 7e8c86172e..0f732c8d23 100755 --- a/testnet/testnet-local-build_images.sh +++ b/testnet/testnet-local-build_images.sh @@ -46,7 +46,7 @@ command() { command docker build -t testnetobscuronet.azurecr.io/obscuronet/eth2network:latest -f "${testnet_path}/eth2network.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/host:latest -f "${root_path}/dockerfiles/host.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/hardhatdeployer:latest -f "${tools_path}/hardhatdeployer/Dockerfile" "${root_path}" & -command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave:latest -f "${root_path}/dockerfiles/enclave.Dockerfile" "${root_path}" & +command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave:latest --build-arg RESTRICTEDMODE=false -f "${root_path}/dockerfiles/enclave.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave_debug:latest -f "${root_path}/dockerfiles/enclave.debug.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/obscuroscan:latest -f "${tools_path}/obscuroscan/Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/faucet:latest -f "${tools_path}/faucet/Dockerfile" "${root_path}" & From d92704e9a7def0a98ef287eeab42872015f32743 Mon Sep 17 00:00:00 2001 From: otherview Date: Tue, 28 Nov 2023 11:32:29 +0000 Subject: [PATCH 02/12] fixes --- dockerfiles/enclave.Dockerfile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/dockerfiles/enclave.Dockerfile b/dockerfiles/enclave.Dockerfile index 26b452c760..2ac4c8d01d 100644 --- a/dockerfiles/enclave.Dockerfile +++ b/dockerfiles/enclave.Dockerfile @@ -9,7 +9,7 @@ # /home/obscuro/go-obscuro/go/enclave/main contains the executable for the enclave # -ARG RESTRICTEDMODE +ARG RESTRICTEDMODE=true FROM ghcr.io/edgelesssys/ego-dev:v1.3.0 AS build-base @@ -51,7 +51,7 @@ FROM ghcr.io/edgelesssys/ego-deploy:v1.3.0 # Copy just the binary for the enclave into this build stage COPY --from=build-enclave \ - /home/obscuro/go-obscuro/go/enclave/main home/obscuro/go-obscuro/go/enclave/main + /home/obscuro/go-obscuro/go/enclave/main /home/obscuro/go-obscuro/go/enclave/main WORKDIR /home/obscuro/go-obscuro/go/enclave/main From 65484b2c3994a1b6b20df09cc963492a66ec0397 Mon Sep 17 00:00:00 2001 From: otherview Date: Tue, 28 Nov 2023 11:54:15 +0000 Subject: [PATCH 03/12] comments --- dockerfiles/enclave.Dockerfile | 1 + go/common/flag/flag.go | 8 ++++---- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/dockerfiles/enclave.Dockerfile b/dockerfiles/enclave.Dockerfile index 2ac4c8d01d..65c72bdcb1 100644 --- a/dockerfiles/enclave.Dockerfile +++ b/dockerfiles/enclave.Dockerfile @@ -9,6 +9,7 @@ # /home/obscuro/go-obscuro/go/enclave/main contains the executable for the enclave # +# Defaults to restricted flag mode ARG RESTRICTEDMODE=true FROM ghcr.io/edgelesssys/ego-dev:v1.3.0 AS build-base diff --git a/go/common/flag/flag.go b/go/common/flag/flag.go index 5e8c36b6a2..6511130b3a 100644 --- a/go/common/flag/flag.go +++ b/go/common/flag/flag.go @@ -8,7 +8,7 @@ import ( "strings" ) -// WrappedFlag is a construct that allows to have go flags while obeying to a new set of restricteveness rules +// WrappedFlag is a construct that allows to have go flags while obeying to a new set of restrictiveness rules type WrappedFlag struct { flagType string ptr any @@ -16,17 +16,17 @@ type WrappedFlag struct { description string } -// GetString returns the flag current value casted to string +// GetString returns the flag current value cast to string func (f WrappedFlag) GetString() string { return *f.ptr.(*string) } -// GetInt64 returns the flag current value casted to int64 +// GetInt64 returns the flag current value cast to int64 func (f WrappedFlag) GetInt64() int64 { return *f.ptr.(*int64) } -// GetBool returns the flag current value casted to bool +// GetBool returns the flag current value cast to bool func (f WrappedFlag) GetBool() bool { return *f.ptr.(*bool) } From 394ee33322375dd87157ac3e7f65777c49fd371b Mon Sep 17 00:00:00 2001 From: otherview Date: Tue, 28 Nov 2023 13:42:21 +0000 Subject: [PATCH 04/12] changing docker restricted mode to test mode --- dockerfiles/enclave.Dockerfile | 6 +++--- testnet/docker-compose.local.yml | 2 +- testnet/testnet-local-build_images.sh | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/dockerfiles/enclave.Dockerfile b/dockerfiles/enclave.Dockerfile index 65c72bdcb1..1a9b81aa86 100644 --- a/dockerfiles/enclave.Dockerfile +++ b/dockerfiles/enclave.Dockerfile @@ -10,7 +10,7 @@ # # Defaults to restricted flag mode -ARG RESTRICTEDMODE=true +ARG TESTMODE=false FROM ghcr.io/edgelesssys/ego-dev:v1.3.0 AS build-base @@ -35,12 +35,12 @@ RUN --mount=type=cache,target=/root/.cache/go-build \ ego-go build # New build stage for compiling the enclave with restricted flags mode -FROM build-enclave as build-enclave-restrictedmode-true +FROM build-enclave as build-enclave-testmode-false # Sign the enclave executable RUN ego sign enclave.json # New build stage for compiling the enclave without restricted flags mode -FROM build-enclave as build-enclave-restrictedmode-false +FROM build-enclave as build-enclave-testmode-true # Sign the enclave executable RUN ego sign enclave-test.json diff --git a/testnet/docker-compose.local.yml b/testnet/docker-compose.local.yml index 00a56026e5..b7f0e86aad 100644 --- a/testnet/docker-compose.local.yml +++ b/testnet/docker-compose.local.yml @@ -18,7 +18,7 @@ services: context: $ROOT_PATH dockerfile: ./dockerfiles/enclave.Dockerfile args: - RESTRICTEDMODE: false + TESTMODE: true enclave-debug: image: "testnetobscuronet.azurecr.io/obscuronet/enclave_debug:latest" build: diff --git a/testnet/testnet-local-build_images.sh b/testnet/testnet-local-build_images.sh index 0f732c8d23..8eadb57f1d 100755 --- a/testnet/testnet-local-build_images.sh +++ b/testnet/testnet-local-build_images.sh @@ -46,7 +46,7 @@ command() { command docker build -t testnetobscuronet.azurecr.io/obscuronet/eth2network:latest -f "${testnet_path}/eth2network.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/host:latest -f "${root_path}/dockerfiles/host.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/hardhatdeployer:latest -f "${tools_path}/hardhatdeployer/Dockerfile" "${root_path}" & -command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave:latest --build-arg RESTRICTEDMODE=false -f "${root_path}/dockerfiles/enclave.Dockerfile" "${root_path}" & +command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave:latest --build-arg TESTMODE=true -f "${root_path}/dockerfiles/enclave.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/enclave_debug:latest -f "${root_path}/dockerfiles/enclave.debug.Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/obscuroscan:latest -f "${tools_path}/obscuroscan/Dockerfile" "${root_path}" & command docker build -t testnetobscuronet.azurecr.io/obscuronet/faucet:latest -f "${tools_path}/faucet/Dockerfile" "${root_path}" & From 7544d424b3a4bd38df2cebfe2ba3294037f75ab4 Mon Sep 17 00:00:00 2001 From: otherview Date: Thu, 30 Nov 2023 16:39:09 +0000 Subject: [PATCH 05/12] PR comments --- dockerfiles/enclave.Dockerfile | 2 +- go/common/flag/flag.go | 215 ++++++++++++------------------ go/common/flag/flag_test.go | 68 ---------- go/config/enclave_cli_flags.go | 98 ++++++++++++++ go/config/enclave_config.go | 115 +++++++++++++++- go/config/enclave_config_test.go | 55 ++++++++ go/enclave/container/cli.go | 115 ---------------- go/enclave/container/cli_flags.go | 58 -------- go/enclave/main/enclave-test.json | 4 +- go/enclave/main/enclave.json | 4 +- go/enclave/main/main.go | 15 ++- 11 files changed, 368 insertions(+), 381 deletions(-) delete mode 100644 go/common/flag/flag_test.go create mode 100644 go/config/enclave_cli_flags.go create mode 100644 go/config/enclave_config_test.go delete mode 100644 go/enclave/container/cli.go delete mode 100644 go/enclave/container/cli_flags.go diff --git a/dockerfiles/enclave.Dockerfile b/dockerfiles/enclave.Dockerfile index 1a9b81aa86..17e4ac3609 100644 --- a/dockerfiles/enclave.Dockerfile +++ b/dockerfiles/enclave.Dockerfile @@ -45,7 +45,7 @@ FROM build-enclave as build-enclave-testmode-true RUN ego sign enclave-test.json # Tag the restricted mode as the current build -FROM build-enclave-restrictedmode-${RESTRICTEDMODE} as build-enclave +FROM build-enclave-testmode-${TESTMODE} as build-enclave # Trigger a new build stage and use the smaller ego version: FROM ghcr.io/edgelesssys/ego-deploy:v1.3.0 diff --git a/go/common/flag/flag.go b/go/common/flag/flag.go index 6511130b3a..db362151c2 100644 --- a/go/common/flag/flag.go +++ b/go/common/flag/flag.go @@ -3,166 +3,121 @@ package flag import ( "flag" "fmt" - "os" - "strconv" - "strings" ) -// WrappedFlag is a construct that allows to have go flags while obeying to a new set of restrictiveness rules -type WrappedFlag struct { - flagType string - ptr any - defaultValue any - description string +type TenFlag struct { + Name string + Value any + FlagType string + Description string + DefaultValue any } -// GetString returns the flag current value cast to string -func (f WrappedFlag) GetString() string { - return *f.ptr.(*string) -} - -// GetInt64 returns the flag current value cast to int64 -func (f WrappedFlag) GetInt64() int64 { - return *f.ptr.(*int64) -} - -// GetBool returns the flag current value cast to bool -func (f WrappedFlag) GetBool() bool { - return *f.ptr.(*bool) -} - -// singletonFlagger is the singleton instance of the loaded flags -var singletonFlagger = map[string]*WrappedFlag{} - -// String directly uses the go flag package -func String(flagName, defaultValue, description string) *string { - return flag.String(flagName, defaultValue, description) -} - -// RestrictedString wraps the go flag package depending on the restriction mode -func RestrictedString(flagName, defaultValue, description string) *WrappedFlag { - prtVal := new(string) - singletonFlagger[flagName] = &WrappedFlag{ - flagType: "string", - ptr: prtVal, - defaultValue: defaultValue, - description: description, +func NewStringFlag(name, defaultValue, description string) *TenFlag { + return &TenFlag{ + Name: name, + Value: "", + FlagType: "string", + Description: description, + DefaultValue: defaultValue, } - return singletonFlagger[flagName] -} - -// Int64 directly uses the go flag package -func Int64(flagName string, defaultValue int64, description string) *int64 { - return flag.Int64(flagName, defaultValue, description) } -// RestrictedInt64 wraps the go flag package depending on the restriction mode -func RestrictedInt64(flagName string, defaultValue int64, description string) *WrappedFlag { - prtVal := new(int64) - singletonFlagger[flagName] = &WrappedFlag{ - flagType: "int64", - ptr: prtVal, - defaultValue: defaultValue, - description: description, +func NewIntFlag(name string, defaultValue int, description string) *TenFlag { + return &TenFlag{ + Name: name, + Value: 0, + FlagType: "int", + Description: description, + DefaultValue: defaultValue, } - return singletonFlagger[flagName] } -// Bool directly uses the go flag package -func Bool(flagName string, defaultValue bool, description string) *bool { - return flag.Bool(flagName, defaultValue, description) +func NewBoolFlag(name string, defaultValue bool, description string) *TenFlag { + return &TenFlag{ + Name: name, + Value: false, + FlagType: "bool", + Description: description, + DefaultValue: defaultValue, + } } -// RestrictedBool wraps the go flag package depending on the restriction mode -func RestrictedBool(flagName string, defaultValue bool, description string) *WrappedFlag { - prtVal := new(bool) - singletonFlagger[flagName] = &WrappedFlag{ - flagType: "bool", - ptr: prtVal, - defaultValue: defaultValue, - description: description, +func NewInt64Flag(name string, defaultValue int64, description string) *TenFlag { + return &TenFlag{ + Name: name, + Value: false, + FlagType: "int64", + Description: description, + DefaultValue: defaultValue, } - return singletonFlagger[flagName] } -// Int directly uses the go flag package -func Int(flagName string, defaultValue int, description string) *int { - return flag.Int(flagName, defaultValue, description) +func NewUint64Flag(name string, defaultValue uint64, description string) *TenFlag { + return &TenFlag{ + Name: name, + Value: false, + FlagType: "uint64", + Description: description, + DefaultValue: defaultValue, + } } -// Uint64 directly uses the go flag package -func Uint64(flagName string, defaultValue uint64, description string) *uint64 { - return flag.Uint64(flagName, defaultValue, description) +func (f TenFlag) String() string { + if ptrVal, ok := f.Value.(*string); ok { + return *ptrVal + } + return f.Value.(string) } -// Parse ensures the restricted mode is applied only to restricted flags -// Restricted Mode - Flags can only be inputted via ENV Vars via the enclave.json -// Non-Restricted Mode - Flags can only be inputted via normal CLI command line -func Parse() error { - mandatoryEnvFlags := false - val := os.Getenv("EDG_RESTRICTED") - if val == "true" { - fmt.Println("Using mandatory signed configurations.") - mandatoryEnvFlags = true +func (f TenFlag) Int() int { + if ptrVal, ok := f.Value.(*int); ok { + return *ptrVal } + return f.Value.(int) +} - for flagName, wflag := range singletonFlagger { - // parse restricted flags if in restricted mode - if mandatoryEnvFlags { - err := parseMandatoryFlags(flagName, wflag) - if err != nil { - return fmt.Errorf("unable to parse mandatory flag: %s - %w", flagName, err) - } - } else { - err := parseNonMandatoryFlag(flagName, wflag) - if err != nil { - return fmt.Errorf("unable to parse flag: %s - %w", flagName, err) - } - } +func (f TenFlag) Int64() int64 { + if ptrVal, ok := f.Value.(*int64); ok { + return *ptrVal } - - // parse all remaining flags - flag.Parse() - return nil + return f.Value.(int64) } -func parseNonMandatoryFlag(flagName string, wflag *WrappedFlag) error { - switch wflag.flagType { - case "string": - wflag.ptr = flag.String(flagName, wflag.defaultValue.(string), wflag.description) - case "int64": - wflag.ptr = flag.Int64(flagName, wflag.defaultValue.(int64), wflag.description) - case "bool": - wflag.ptr = flag.Bool(flagName, wflag.defaultValue.(bool), wflag.description) - default: - return fmt.Errorf("unexpected type: %s", wflag.flagType) +func (f TenFlag) Uint64() uint64 { + if ptrVal, ok := f.Value.(*uint64); ok { + return *ptrVal } - return nil + return f.Value.(uint64) } -func parseMandatoryFlags(flagName string, wflag *WrappedFlag) error { - val := os.Getenv("EDG_" + strings.ToUpper(flagName)) - if val == "" { - return fmt.Errorf("mandatory restricted flag not available - %s", flagName) +func (f TenFlag) Bool() bool { + if ptrVal, ok := f.Value.(*bool); ok { + return *ptrVal } + return f.Value.(bool) +} - switch wflag.flagType { - case "string": - wflag.ptr = &val - case "int64": - i, err := strconv.ParseInt(val, 10, 64) - if err != nil { - return fmt.Errorf("unable to parse flag %s - %w", flagName, err) - } - wflag.ptr = &i - case "bool": - b, err := strconv.ParseBool(val) - if err != nil { - return fmt.Errorf("unable to parse flag %s - %w", flagName, err) +func CreateCLIFlags(flags map[string]*TenFlag) error { + for _, tflag := range flags { + switch tflag.FlagType { + case "string": + tflag.Value = flag.String(tflag.Name, tflag.DefaultValue.(string), tflag.Description) + case "bool": + tflag.Value = flag.Bool(tflag.Name, tflag.DefaultValue.(bool), tflag.Description) + case "int": + tflag.Value = flag.Int(tflag.Name, tflag.DefaultValue.(int), tflag.Description) + case "int64": + tflag.Value = flag.Int64(tflag.Name, tflag.DefaultValue.(int64), tflag.Description) + case "uint64": + tflag.Value = flag.Uint64(tflag.Name, tflag.DefaultValue.(uint64), tflag.Description) + default: + return fmt.Errorf("unexpected flag type %s", tflag.FlagType) } - wflag.ptr = &b - default: - return fmt.Errorf("unexpected mandatory type: %s", wflag.flagType) } return nil } + +func Parse() { + flag.Parse() +} diff --git a/go/common/flag/flag_test.go b/go/common/flag/flag_test.go deleted file mode 100644 index bae24294cb..0000000000 --- a/go/common/flag/flag_test.go +++ /dev/null @@ -1,68 +0,0 @@ -package flag - -import ( - "fmt" - "os" - "strings" - "testing" - - "github.com/stretchr/testify/require" -) - -func TestStringFlagCreation(t *testing.T) { - expected := "Not the Default" - flagName := "testString" - - // Create the flag - flagOutput := String(flagName, "default", "Test string flag") - - // Parse the flag - os.Args = []string{"cmd", fmt.Sprintf("-%s=%s", flagName, expected)} - - // Parse the flags - require.NoError(t, Parse()) - - // Verify the flag value - require.Equal(t, expected, *flagOutput) -} - -func TestParseInRestrictedMode(t *testing.T) { - // Set up restricted mode - t.Setenv("EDG_RESTRICTED", "true") - defer os.Unsetenv("EDG_RESTRICTED") - - // Create a restricted flag - flagName := "testFlag" - flagOutput := RestrictedString(flagName, "default", "Test restricted flag") - - // Mimic setting the environment variable for the restricted flag - expectedValue := "restrictedValue" - t.Setenv("EDG_"+strings.ToUpper(flagName), expectedValue) - - defer os.Unsetenv("EDG_" + strings.ToUpper(flagName)) - - // Parse the flags - require.NoError(t, Parse()) - - // Verify the flag value - require.Equal(t, expectedValue, flagOutput.GetString()) -} - -func TestParseInUnrestrictedMode(t *testing.T) { - // Ensure unrestricted mode - os.Unsetenv("EDG_RESTRICTED") - - // Create a regular flag - flagName := "testUnrestrictedFlag" - expected := int64(12345) - // Parse the flag - os.Args = []string{"cmd", fmt.Sprintf("-%s=%d", flagName, expected)} - - flagOutput := RestrictedInt64(flagName, int64(1), "Test flag") - - // Parse the flags - require.NoError(t, Parse()) - - // Verify the flag value - require.Equal(t, expected, flagOutput.GetInt64()) -} diff --git a/go/config/enclave_cli_flags.go b/go/config/enclave_cli_flags.go new file mode 100644 index 0000000000..175d2e8e57 --- /dev/null +++ b/go/config/enclave_cli_flags.go @@ -0,0 +1,98 @@ +package config + +import "github.com/ten-protocol/go-ten/go/common/flag" + +// EnclaveFlags are the flags that the enclave can receive +func EnclaveFlags() map[string]*flag.TenFlag { + return map[string]*flag.TenFlag{ + HostIDFlag: flag.NewStringFlag(HostIDFlag, "", FlagDescriptionMap[HostIDFlag]), + HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", FlagDescriptionMap[HostAddressFlag]), + AddressFlag: flag.NewStringFlag(AddressFlag, "", FlagDescriptionMap[HostAddressFlag]), + NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", FlagDescriptionMap[NodeTypeFlag]), + WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, FlagDescriptionMap[WillAttestFlag]), + ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, FlagDescriptionMap[ValidateL1BlocksFlag]), + ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", FlagDescriptionMap[ManagementContractAddressFlag]), + LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, FlagDescriptionMap[LogLevelFlag]), + LogPathFlag: flag.NewStringFlag(LogPathFlag, "", FlagDescriptionMap[LogPathFlag]), + EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", FlagDescriptionMap[EdgelessDBHostFlag]), + SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", FlagDescriptionMap[SQLiteDBPathFlag]), + MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, FlagDescriptionMap[MinGasPriceFlag]), + MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", FlagDescriptionMap[MessageBusAddressFlag]), + SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", FlagDescriptionMap[SequencerIDFlag]), + MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, FlagDescriptionMap[MaxBatchSizeFlag]), + MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, FlagDescriptionMap[MaxRollupSizeFlag]), + L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 0, ""), + L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "", ""), + L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 0, ""), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), + } +} + +// enclaveRestrictedFlags are the flags that the enclave can receive ONLY over the Ego signed enclave.json +var enclaveRestrictedFlags = map[string]*flag.TenFlag{ + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), +} + +// Flag names. +const ( + HostIDFlag = "hostID" + HostAddressFlag = "hostAddress" + AddressFlag = "address" + NodeTypeFlag = "nodeType" + L1ChainIDFlag = "l1ChainID" + ObscuroChainIDFlag = "obscuroChainID" + WillAttestFlag = "willAttest" + ValidateL1BlocksFlag = "validateL1Blocks" + ManagementContractAddressFlag = "managementContractAddress" + LogLevelFlag = "logLevel" + LogPathFlag = "logPath" + UseInMemoryDBFlag = "useInMemoryDB" + EdgelessDBHostFlag = "edgelessDBHost" + SQLiteDBPathFlag = "sqliteDBPath" + ProfilerEnabledFlag = "profilerEnabled" + MinGasPriceFlag = "minGasPrice" + MessageBusAddressFlag = "messageBusAddress" + SequencerIDFlag = "sequencerID" + ObscuroGenesisFlag = "obscuroGenesis" + DebugNamespaceEnabledFlag = "debugNamespaceEnabled" + MaxBatchSizeFlag = "maxBatchSize" + MaxRollupSizeFlag = "maxRollupSize" + L2BaseFeeFlag = "l2BaseFee" + L2CoinbaseFlag = "l2Coinbase" + L2GasLimitFlag = "l2GasLimit" +) + +var FlagDescriptionMap = map[string]string{ + HostIDFlag: "The 20 bytes of the address of the Obscuro host this enclave serves", + HostAddressFlag: "The peer-to-peer IP address of the Obscuro host this enclave serves", + AddressFlag: "The address on which to serve the Obscuro enclave service", + NodeTypeFlag: "The node's type (e.g. sequencer, validator)", + L1ChainIDFlag: "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)", + ObscuroChainIDFlag: "An integer representing the unique chain id of the Obscuro chain (default 443)", + WillAttestFlag: "Whether the enclave will produce a verified attestation report", + ValidateL1BlocksFlag: "Whether to validate incoming blocks using the hardcoded L1 genesis.json config", + ManagementContractAddressFlag: "The management contract address on the L1", + LogLevelFlag: "The verbosity level of logs. (Defaults to Info)", + LogPathFlag: "The path to use for the enclave service's log file", + UseInMemoryDBFlag: "Whether the enclave will use an in-memory DB rather than persist data", + EdgelessDBHostFlag: "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation", + SQLiteDBPathFlag: "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)", + ProfilerEnabledFlag: "Runs a profiler instance (Defaults to false)", + MinGasPriceFlag: "The minimum gas price for mining a transaction", + MessageBusAddressFlag: "The address of the L1 message bus contract owned by the management contract.", + SequencerIDFlag: "The 20 bytes of the address of the sequencer for this network", + ObscuroGenesisFlag: "The json string with the obscuro genesis", + DebugNamespaceEnabledFlag: "Whether the debug namespace is enabled", + MaxBatchSizeFlag: "The maximum size a batch is allowed to reach uncompressed", + MaxRollupSizeFlag: "The maximum size a rollup is allowed to reach", +} diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index 7471c3b391..6453375013 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -1,14 +1,18 @@ package config import ( + "fmt" "math/big" + "os" + "strconv" + "strings" - "github.com/ten-protocol/go-ten/go/common" - - gethcommon "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/params" + "github.com/ten-protocol/go-ten/go/common" + "github.com/ten-protocol/go-ten/go/common/flag" "github.com/ten-protocol/go-ten/go/common/log" + gethcommon "github.com/ethereum/go-ethereum/common" gethlog "github.com/ethereum/go-ethereum/log" ) @@ -100,3 +104,108 @@ func DefaultEnclaveConfig() *EnclaveConfig { GasLimit: new(big.Int).SetUint64(params.MaxGasLimit / 6), } } + +func FromFlags(flagMap map[string]*flag.TenFlag) (*EnclaveConfig, error) { + flagsTestMode := false + + // check if it's in test mode or not + val := os.Getenv("EDG_TESTMODE") + if val == "true" { + flagsTestMode = true + } else { + fmt.Println("Using mandatory signed configurations.") + } + + if !flagsTestMode { + envFlags, err := retrieveEnvFlags() + if err != nil { + return nil, fmt.Errorf("unable to retrieve env flags - %w", err) + } + + // create the final flag usage + parsedFlags := map[string]*flag.TenFlag{} + for flagName, cliflag := range flagMap { + parsedFlags[flagName] = cliflag + } + // env flags override CLI flags + for flagName, envflag := range envFlags { + parsedFlags[flagName] = envflag + } + + return newConfig(parsedFlags) + } + return newConfig(flagMap) +} + +func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { + parsedFlags := map[string]*flag.TenFlag{} + + for _, eflag := range enclaveRestrictedFlags { + val := os.Getenv("EDG_" + strings.ToUpper(eflag.Name)) + switch eflag.FlagType { + case "string": + parsedFlag := flag.NewStringFlag(eflag.Name, "", "") + parsedFlag.Value = val + + parsedFlags[eflag.Name] = parsedFlag + case "int64": + i, err := strconv.ParseInt(val, 10, 64) + if err != nil { + return nil, fmt.Errorf("unable to parse flag %s - %w", eflag.Name, err) + } + + parsedFlag := flag.NewIntFlag(eflag.Name, 0, "") + parsedFlag.Value = i + parsedFlags[eflag.Name] = parsedFlag + case "bool": + b, err := strconv.ParseBool(val) + if err != nil { + return nil, fmt.Errorf("unable to parse flag %s - %w", eflag.Name, err) + } + + parsedFlag := flag.NewBoolFlag(eflag.Name, false, "") + parsedFlag.Value = b + parsedFlags[eflag.Name] = parsedFlag + default: + return nil, fmt.Errorf("unexpected type: %s", eflag.FlagType) + } + } + return parsedFlags, nil +} + +func newConfig(flags map[string]*flag.TenFlag) (*EnclaveConfig, error) { + cfg := DefaultEnclaveConfig() + + nodeType, err := common.ToNodeType(flags[NodeTypeFlag].String()) + if err != nil { + return nil, fmt.Errorf("unrecognised node type '%s'", flags[NodeTypeFlag].String()) + } + + cfg.HostID = gethcommon.HexToAddress(flags[HostIDFlag].String()) + cfg.HostAddress = flags[HostAddressFlag].String() + cfg.Address = flags[AddressFlag].String() + cfg.NodeType = nodeType + cfg.L1ChainID = flags[L1ChainIDFlag].Int64() + cfg.ObscuroChainID = flags[ObscuroChainIDFlag].Int64() + cfg.WillAttest = flags[WillAttestFlag].Bool() + cfg.ValidateL1Blocks = flags[ValidateL1BlocksFlag].Bool() + cfg.ManagementContractAddress = gethcommon.HexToAddress(flags[ManagementContractAddressFlag].String()) + cfg.LogLevel = flags[LogLevelFlag].Int() + cfg.LogPath = flags[LogPathFlag].String() + cfg.UseInMemoryDB = flags[UseInMemoryDBFlag].Bool() + cfg.EdgelessDBHost = flags[EdgelessDBHostFlag].String() + cfg.SqliteDBPath = flags[SQLiteDBPathFlag].String() + cfg.ProfilerEnabled = flags[ProfilerEnabledFlag].Bool() + cfg.MinGasPrice = big.NewInt(flags[MinGasPriceFlag].Int64()) + cfg.MessageBusAddress = gethcommon.HexToAddress(flags[MessageBusAddressFlag].String()) + cfg.SequencerID = gethcommon.HexToAddress(flags[SequencerIDFlag].String()) + cfg.ObscuroGenesis = flags[ObscuroGenesisFlag].String() + cfg.DebugNamespaceEnabled = flags[DebugNamespaceEnabledFlag].Bool() + cfg.MaxBatchSize = flags[MaxBatchSizeFlag].Uint64() + cfg.MaxRollupSize = flags[MaxRollupSizeFlag].Uint64() + cfg.BaseFee = big.NewInt(0).SetUint64(flags[L2BaseFeeFlag].Uint64()) + cfg.GasPaymentAddress = gethcommon.HexToAddress(flags[L2CoinbaseFlag].String()) + cfg.GasLimit = big.NewInt(0).SetUint64(flags[L2GasLimitFlag].Uint64()) + + return cfg, nil +} diff --git a/go/config/enclave_config_test.go b/go/config/enclave_config_test.go new file mode 100644 index 0000000000..01d5c8da9f --- /dev/null +++ b/go/config/enclave_config_test.go @@ -0,0 +1,55 @@ +package config + +import ( + "flag" + "testing" + + "github.com/stretchr/testify/require" + tenflag "github.com/ten-protocol/go-ten/go/common/flag" +) + +func TestFromFlags(t *testing.T) { + // Backup the original CommandLine. + originalFlagSet := flag.CommandLine + // Create a new FlagSet for testing purposes. + flag.CommandLine = flag.NewFlagSet("", flag.ContinueOnError) + + // Defer a function to reset CommandLine after the test. + defer func() { + flag.CommandLine = originalFlagSet + }() + + flags := EnclaveFlags() + err := tenflag.CreateCLIFlags(flags) + require.NoError(t, err) + + // Set the flags as needed for the test. + err = flag.CommandLine.Set(HostIDFlag, "string-value") + require.NoError(t, err) + + err = flag.CommandLine.Set(NodeTypeFlag, "sequencer") + require.NoError(t, err) + + err = flag.CommandLine.Set(WillAttestFlag, "true") + require.NoError(t, err) + + err = flag.CommandLine.Set(LogLevelFlag, "123") + require.NoError(t, err) + + err = flag.CommandLine.Set(MinGasPriceFlag, "3333") + require.NoError(t, err) + + err = flag.CommandLine.Set(L2GasLimitFlag, "222222") + require.NoError(t, err) + + flag.Parse() + + require.Equal(t, "string-value", flags[HostIDFlag].String()) + require.Equal(t, true, flags[WillAttestFlag].Bool()) + require.Equal(t, 123, flags[LogLevelFlag].Int()) + require.Equal(t, int64(3333), flags[MinGasPriceFlag].Int64()) + require.Equal(t, uint64(222222), flags[L2GasLimitFlag].Uint64()) + + _, err = newConfig(flags) + require.NoError(t, err) +} diff --git a/go/enclave/container/cli.go b/go/enclave/container/cli.go deleted file mode 100644 index c440b95de2..0000000000 --- a/go/enclave/container/cli.go +++ /dev/null @@ -1,115 +0,0 @@ -package container - -import ( - "fmt" - "math/big" - - "github.com/ten-protocol/go-ten/go/common" - "github.com/ten-protocol/go-ten/go/common/flag" - "github.com/ten-protocol/go-ten/go/config" - - gethcommon "github.com/ethereum/go-ethereum/common" -) - -// EnclaveConfigToml is the structure that an enclave's .toml config is parsed into. -type EnclaveConfigToml struct { - HostID string - HostAddress string - Address string - NodeType string - L1ChainID int64 - ObscuroChainID int64 - WillAttest bool - ValidateL1Blocks bool - ManagementContractAddress string - LogLevel int - LogPath string - UseInMemoryDB bool - GenesisJSON string - EdgelessDBHost string - SqliteDBPath string - ProfilerEnabled bool - MinGasPrice int64 - MessageBusAddress string - SequencerID string - ObscuroGenesis string - DebugNamespaceEnabled bool - MaxBatchSize uint64 - MaxRollupSize uint64 - GasPaymentAddress string - BaseFee uint64 - GasLimit uint64 -} - -// ParseConfig returns a config.EnclaveConfig based on either the file identified by the `config` flag, or the flags -// with specific defaults (if the `config` flag isn't specified). -func ParseConfig() (*config.EnclaveConfig, error) { - cfg := config.DefaultEnclaveConfig() - flagUsageMap := getFlagUsageMap() - - hostID := flag.String(hostIDName, cfg.HostID.Hex(), flagUsageMap[hostIDName]) - hostAddress := flag.String(hostAddressName, cfg.HostAddress, flagUsageMap[hostAddressName]) - address := flag.String(addressName, cfg.Address, flagUsageMap[addressName]) - nodeTypeStr := flag.String(nodeTypeName, cfg.NodeType.String(), flagUsageMap[nodeTypeName]) - willAttest := flag.Bool(willAttestName, cfg.WillAttest, flagUsageMap[willAttestName]) - validateL1Blocks := flag.Bool(validateL1BlocksName, cfg.ValidateL1Blocks, flagUsageMap[validateL1BlocksName]) - managementContractAddress := flag.String(ManagementContractAddressName, cfg.ManagementContractAddress.Hex(), flagUsageMap[ManagementContractAddressName]) - loglevel := flag.Int(logLevelName, cfg.LogLevel, flagUsageMap[logLevelName]) - logPath := flag.String(logPathName, cfg.LogPath, flagUsageMap[logPathName]) - edgelessDBHost := flag.String(edgelessDBHostName, cfg.EdgelessDBHost, flagUsageMap[edgelessDBHostName]) - sqliteDBPath := flag.String(sqliteDBPathName, cfg.SqliteDBPath, flagUsageMap[sqliteDBPathName]) - minGasPrice := flag.Int64(minGasPriceName, cfg.MinGasPrice.Int64(), flagUsageMap[minGasPriceName]) - messageBusAddress := flag.String(messageBusAddressName, cfg.MessageBusAddress.Hex(), flagUsageMap[messageBusAddressName]) - sequencerID := flag.String(sequencerIDName, cfg.SequencerID.Hex(), flagUsageMap[sequencerIDName]) - maxBatchSize := flag.Uint64(maxBatchSizeName, cfg.MaxBatchSize, flagUsageMap[maxBatchSizeName]) - maxRollupSize := flag.Uint64(maxRollupSizeName, cfg.MaxRollupSize, flagUsageMap[maxRollupSizeName]) - baseFee := flag.Uint64("l2BaseFee", cfg.BaseFee.Uint64(), "") - coinbaseAddress := flag.String("l2Coinbase", cfg.GasPaymentAddress.Hex(), "") - gasLimit := flag.Uint64("l2GasLimit", cfg.GasLimit.Uint64(), "") - - // set of restricted flags that can only be set in the signed enclave.json - obscuroGenesis := flag.RestrictedString(obscuroGenesisName, cfg.ObscuroGenesis, flagUsageMap[obscuroGenesisName]) - l1ChainID := flag.RestrictedInt64(l1ChainIDName, cfg.L1ChainID, flagUsageMap[l1ChainIDName]) - obscuroChainID := flag.RestrictedInt64(obscuroChainIDName, cfg.ObscuroChainID, flagUsageMap[obscuroChainIDName]) - useInMemoryDB := flag.RestrictedBool(useInMemoryDBName, cfg.UseInMemoryDB, flagUsageMap[useInMemoryDBName]) - profilerEnabled := flag.RestrictedBool(profilerEnabledName, cfg.ProfilerEnabled, flagUsageMap[profilerEnabledName]) - debugNamespaceEnabled := flag.RestrictedBool(debugNamespaceEnabledName, cfg.DebugNamespaceEnabled, flagUsageMap[debugNamespaceEnabledName]) - - err := flag.Parse() - if err != nil { - return nil, err - } - - nodeType, err := common.ToNodeType(*nodeTypeStr) - if err != nil { - return nil, fmt.Errorf("unrecognised node type '%s'", *nodeTypeStr) - } - - cfg.HostID = gethcommon.HexToAddress(*hostID) - cfg.HostAddress = *hostAddress - cfg.Address = *address - cfg.NodeType = nodeType - cfg.L1ChainID = l1ChainID.GetInt64() - cfg.ObscuroChainID = obscuroChainID.GetInt64() - cfg.WillAttest = *willAttest - cfg.ValidateL1Blocks = *validateL1Blocks - cfg.ManagementContractAddress = gethcommon.HexToAddress(*managementContractAddress) - cfg.LogLevel = *loglevel - cfg.LogPath = *logPath - cfg.UseInMemoryDB = useInMemoryDB.GetBool() - cfg.EdgelessDBHost = *edgelessDBHost - cfg.SqliteDBPath = *sqliteDBPath - cfg.ProfilerEnabled = profilerEnabled.GetBool() - cfg.MinGasPrice = big.NewInt(*minGasPrice) - cfg.MessageBusAddress = gethcommon.HexToAddress(*messageBusAddress) - cfg.SequencerID = gethcommon.HexToAddress(*sequencerID) - cfg.ObscuroGenesis = obscuroGenesis.GetString() - cfg.DebugNamespaceEnabled = debugNamespaceEnabled.GetBool() - cfg.MaxBatchSize = *maxBatchSize - cfg.MaxRollupSize = *maxRollupSize - cfg.BaseFee = big.NewInt(0).SetUint64(*baseFee) - cfg.GasPaymentAddress = gethcommon.HexToAddress(*coinbaseAddress) - cfg.GasLimit = big.NewInt(0).SetUint64(*gasLimit) - - return cfg, nil -} diff --git a/go/enclave/container/cli_flags.go b/go/enclave/container/cli_flags.go deleted file mode 100644 index 7bf4eb6bbf..0000000000 --- a/go/enclave/container/cli_flags.go +++ /dev/null @@ -1,58 +0,0 @@ -package container - -// Flag names. -const ( - configName = "config" - hostIDName = "hostID" - hostAddressName = "hostAddress" - addressName = "address" - nodeTypeName = "nodeType" - l1ChainIDName = "l1ChainID" - obscuroChainIDName = "obscuroChainID" - willAttestName = "willAttest" - validateL1BlocksName = "validateL1Blocks" - ManagementContractAddressName = "managementContractAddress" - logLevelName = "logLevel" - logPathName = "logPath" - useInMemoryDBName = "useInMemoryDB" - edgelessDBHostName = "edgelessDBHost" - sqliteDBPathName = "sqliteDBPath" - profilerEnabledName = "profilerEnabled" - minGasPriceName = "minGasPrice" - messageBusAddressName = "messageBusAddress" - sequencerIDName = "sequencerID" - obscuroGenesisName = "obscuroGenesis" - debugNamespaceEnabledName = "debugNamespaceEnabled" - maxBatchSizeName = "maxBatchSize" - maxRollupSizeName = "maxRollupSize" -) - -// Returns a map of the flag usages. -// While we could just use constants instead of a map, this approach allows us to test that all the expected flags are defined. -func getFlagUsageMap() map[string]string { - return map[string]string{ - configName: "The path to the node's config file. Overrides all other flags", - hostIDName: "The 20 bytes of the address of the Obscuro host this enclave serves", - hostAddressName: "The peer-to-peer IP address of the Obscuro host this enclave serves", - addressName: "The address on which to serve the Obscuro enclave service", - nodeTypeName: "The node's type (e.g. sequencer, validator)", - l1ChainIDName: "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)", - obscuroChainIDName: "An integer representing the unique chain id of the Obscuro chain (default 443)", - willAttestName: "Whether the enclave will produce a verified attestation report", - validateL1BlocksName: "Whether to validate incoming blocks using the hardcoded L1 genesis.json config", - ManagementContractAddressName: "The management contract address on the L1", - logLevelName: "The verbosity level of logs. (Defaults to Info)", - logPathName: "The path to use for the enclave service's log file", - useInMemoryDBName: "Whether the enclave will use an in-memory DB rather than persist data", - edgelessDBHostName: "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation", - sqliteDBPathName: "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)", - profilerEnabledName: "Runs a profiler instance (Defaults to false)", - minGasPriceName: "The minimum gas price for mining a transaction", - messageBusAddressName: "The address of the L1 message bus contract owned by the management contract.", - sequencerIDName: "The 20 bytes of the address of the sequencer for this network", - obscuroGenesisName: "The json string with the obscuro genesis", - debugNamespaceEnabledName: "Whether the debug namespace is enabled", - maxBatchSizeName: "The maximum size a batch is allowed to reach uncompressed", - maxRollupSizeName: "The maximum size a rollup is allowed to reach", - } -} diff --git a/go/enclave/main/enclave-test.json b/go/enclave/main/enclave-test.json index 3e2c3bbcf7..260daa7724 100644 --- a/go/enclave/main/enclave-test.json +++ b/go/enclave/main/enclave-test.json @@ -16,8 +16,8 @@ ], "env": [ { - "name": "RESTRICTED", - "value": "false" + "name": "EDG_TESTMODE", + "value": "true" } ] } \ No newline at end of file diff --git a/go/enclave/main/enclave.json b/go/enclave/main/enclave.json index 3db18c70d4..7919f528d9 100644 --- a/go/enclave/main/enclave.json +++ b/go/enclave/main/enclave.json @@ -16,8 +16,8 @@ ], "env": [ { - "name": "RESTRICTED", - "value": "true" + "name": "TESTMODE", + "value": "false" }, { "name": "L1CHAINID", diff --git a/go/enclave/main/main.go b/go/enclave/main/main.go index d03967a258..7d062a1b06 100644 --- a/go/enclave/main/main.go +++ b/go/enclave/main/main.go @@ -4,16 +4,27 @@ import ( "fmt" "github.com/ten-protocol/go-ten/go/common/container" + tenflag "github.com/ten-protocol/go-ten/go/common/flag" + "github.com/ten-protocol/go-ten/go/config" enclavecontainer "github.com/ten-protocol/go-ten/go/enclave/container" ) // Runs an Obscuro enclave as a standalone process. func main() { - config, err := enclavecontainer.ParseConfig() + // fetch and parse flags + flags := config.EnclaveFlags() + err := tenflag.CreateCLIFlags(flags) if err != nil { panic(fmt.Errorf("could not parse config. Cause: %w", err)) } - enclaveContainer := enclavecontainer.NewEnclaveContainerFromConfig(config) + tenflag.Parse() + + enclaveConfig, err := config.FromFlags(flags) + if err != nil { + panic(fmt.Errorf("unable to create config from flags - %w", err)) + } + + enclaveContainer := enclavecontainer.NewEnclaveContainerFromConfig(enclaveConfig) container.Serve(enclaveContainer) } From d1d34115175ade034c63081323b6d781503243c6 Mon Sep 17 00:00:00 2001 From: otherview Date: Thu, 30 Nov 2023 17:16:25 +0000 Subject: [PATCH 06/12] tests --- go/config/enclave_config.go | 6 ++++ go/config/enclave_config_test.go | 55 +++++++++++++++++++++++++++++--- 2 files changed, 57 insertions(+), 4 deletions(-) diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index 6453375013..8eaefcb719 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -142,6 +142,12 @@ func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { for _, eflag := range enclaveRestrictedFlags { val := os.Getenv("EDG_" + strings.ToUpper(eflag.Name)) + + // all env flags must be set + if val == "" { + return nil, fmt.Errorf("env var not set: %s", eflag.Name) + } + switch eflag.FlagType { case "string": parsedFlag := flag.NewStringFlag(eflag.Name, "", "") diff --git a/go/config/enclave_config_test.go b/go/config/enclave_config_test.go index 01d5c8da9f..3d9e8609db 100644 --- a/go/config/enclave_config_test.go +++ b/go/config/enclave_config_test.go @@ -2,13 +2,15 @@ package config import ( "flag" + "math/big" + "strings" "testing" "github.com/stretchr/testify/require" tenflag "github.com/ten-protocol/go-ten/go/common/flag" ) -func TestFromFlags(t *testing.T) { +func TestCLIFlagTypes(t *testing.T) { // Backup the original CommandLine. originalFlagSet := flag.CommandLine // Create a new FlagSet for testing purposes. @@ -24,7 +26,7 @@ func TestFromFlags(t *testing.T) { require.NoError(t, err) // Set the flags as needed for the test. - err = flag.CommandLine.Set(HostIDFlag, "string-value") + err = flag.CommandLine.Set(LogPathFlag, "string-value") require.NoError(t, err) err = flag.CommandLine.Set(NodeTypeFlag, "sequencer") @@ -44,12 +46,57 @@ func TestFromFlags(t *testing.T) { flag.Parse() - require.Equal(t, "string-value", flags[HostIDFlag].String()) + require.Equal(t, "string-value", flags[LogPathFlag].String()) require.Equal(t, true, flags[WillAttestFlag].Bool()) require.Equal(t, 123, flags[LogLevelFlag].Int()) require.Equal(t, int64(3333), flags[MinGasPriceFlag].Int64()) require.Equal(t, uint64(222222), flags[L2GasLimitFlag].Uint64()) - _, err = newConfig(flags) + enclaveConfig, err := newConfig(flags) require.NoError(t, err) + + require.Equal(t, "string-value", enclaveConfig.LogPath) + require.Equal(t, true, enclaveConfig.WillAttest) + require.Equal(t, 123, enclaveConfig.LogLevel) + require.Equal(t, big.NewInt(3333), enclaveConfig.MinGasPrice) + require.Equal(t, big.NewInt(222222), enclaveConfig.GasLimit) +} + +func TestRestrictedMode(t *testing.T) { + // Backup the original CommandLine. + originalFlagSet := flag.CommandLine + // Create a new FlagSet for testing purposes. + flag.CommandLine = flag.NewFlagSet("", flag.ContinueOnError) + + // Defer a function to reset CommandLine after the test. + defer func() { + flag.CommandLine = originalFlagSet + }() + + t.Setenv("EDG_TESTMODE", "false") + t.Setenv("EDG_"+strings.ToUpper(L1ChainIDFlag), "4444") + t.Setenv("EDG_"+strings.ToUpper(ObscuroChainIDFlag), "1243") + t.Setenv("EDG_"+strings.ToUpper(ObscuroGenesisFlag), "{}") + t.Setenv("EDG_"+strings.ToUpper(UseInMemoryDBFlag), "true") + t.Setenv("EDG_"+strings.ToUpper(ProfilerEnabledFlag), "true") + t.Setenv("EDG_"+strings.ToUpper(DebugNamespaceEnabledFlag), "true") + + flags := EnclaveFlags() + err := tenflag.CreateCLIFlags(flags) + require.NoError(t, err) + + err = flag.CommandLine.Set(NodeTypeFlag, "sequencer") + require.NoError(t, err) + + flag.Parse() + + enclaveConfig, err := FromFlags(flags) + require.NoError(t, err) + + require.Equal(t, int64(4444), enclaveConfig.L1ChainID) + require.Equal(t, int64(1243), enclaveConfig.ObscuroChainID) + require.Equal(t, []byte(nil), enclaveConfig.GenesisJSON) + require.Equal(t, true, enclaveConfig.UseInMemoryDB) + require.Equal(t, true, enclaveConfig.ProfilerEnabled) + require.Equal(t, true, enclaveConfig.DebugNamespaceEnabled) } From 2da41e03e97e266bb4b7337a003298a9b397e083 Mon Sep 17 00:00:00 2001 From: otherview Date: Thu, 30 Nov 2023 17:44:41 +0000 Subject: [PATCH 07/12] Restricted flags cannot be used outside testmode --- go/common/flag/flag.go | 10 +++++++++ go/config/enclave_config.go | 13 +++++++++--- go/config/enclave_config_test.go | 35 ++++++++++++++++++++++++++++++++ 3 files changed, 55 insertions(+), 3 deletions(-) diff --git a/go/common/flag/flag.go b/go/common/flag/flag.go index db362151c2..a783e546c9 100644 --- a/go/common/flag/flag.go +++ b/go/common/flag/flag.go @@ -98,6 +98,16 @@ func (f TenFlag) Bool() bool { return f.Value.(bool) } +func (f TenFlag) IsSet() bool { + found := false + flag.Visit(func(fl *flag.Flag) { + if fl.Name == f.Name { + found = true + } + }) + return found +} + func CreateCLIFlags(flags map[string]*TenFlag) error { for _, tflag := range flags { switch tflag.FlagType { diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index 8eaefcb719..4feb2244f5 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -105,7 +105,7 @@ func DefaultEnclaveConfig() *EnclaveConfig { } } -func FromFlags(flagMap map[string]*flag.TenFlag) (*EnclaveConfig, error) { +func FromFlags(cliFlags map[string]*flag.TenFlag) (*EnclaveConfig, error) { flagsTestMode := false // check if it's in test mode or not @@ -122,9 +122,16 @@ func FromFlags(flagMap map[string]*flag.TenFlag) (*EnclaveConfig, error) { return nil, fmt.Errorf("unable to retrieve env flags - %w", err) } + // fail if any restricted flag is set via the cli + for _, envflag := range envFlags { + if cliflag, ok := cliFlags[envflag.Name]; ok && cliflag.IsSet() { + return nil, fmt.Errorf("restricted flag was set: %s", cliflag.Name) + } + } + // create the final flag usage parsedFlags := map[string]*flag.TenFlag{} - for flagName, cliflag := range flagMap { + for flagName, cliflag := range cliFlags { parsedFlags[flagName] = cliflag } // env flags override CLI flags @@ -134,7 +141,7 @@ func FromFlags(flagMap map[string]*flag.TenFlag) (*EnclaveConfig, error) { return newConfig(parsedFlags) } - return newConfig(flagMap) + return newConfig(cliFlags) } func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { diff --git a/go/config/enclave_config_test.go b/go/config/enclave_config_test.go index 3d9e8609db..4798efe536 100644 --- a/go/config/enclave_config_test.go +++ b/go/config/enclave_config_test.go @@ -100,3 +100,38 @@ func TestRestrictedMode(t *testing.T) { require.Equal(t, true, enclaveConfig.ProfilerEnabled) require.Equal(t, true, enclaveConfig.DebugNamespaceEnabled) } + +func TestRestrictedModeNoCLIDuplication(t *testing.T) { + // Backup the original CommandLine. + originalFlagSet := flag.CommandLine + // Create a new FlagSet for testing purposes. + flag.CommandLine = flag.NewFlagSet("", flag.ContinueOnError) + + // Defer a function to reset CommandLine after the test. + defer func() { + flag.CommandLine = originalFlagSet + }() + + t.Setenv("EDG_TESTMODE", "false") + t.Setenv("EDG_"+strings.ToUpper(L1ChainIDFlag), "4444") + t.Setenv("EDG_"+strings.ToUpper(ObscuroChainIDFlag), "1243") + t.Setenv("EDG_"+strings.ToUpper(ObscuroGenesisFlag), "{}") + t.Setenv("EDG_"+strings.ToUpper(UseInMemoryDBFlag), "true") + t.Setenv("EDG_"+strings.ToUpper(ProfilerEnabledFlag), "true") + t.Setenv("EDG_"+strings.ToUpper(DebugNamespaceEnabledFlag), "true") + + flags := EnclaveFlags() + err := tenflag.CreateCLIFlags(flags) + require.NoError(t, err) + + err = flag.CommandLine.Set(NodeTypeFlag, "sequencer") + require.NoError(t, err) + + err = flag.CommandLine.Set(L1ChainIDFlag, "5555") + require.NoError(t, err) + + flag.Parse() + + _, err = FromFlags(flags) + require.Errorf(t, err, "restricted flag was set: l1ChainID") +} From c01d897da61734e47dec89bad42d42df94455548 Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 4 Dec 2023 10:43:36 +0000 Subject: [PATCH 08/12] nit --- go/config/enclave_config.go | 2 +- go/config/enclave_config_test.go | 4 ++-- go/enclave/main/main.go | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index 4feb2244f5..aa1dd7fc28 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -105,7 +105,7 @@ func DefaultEnclaveConfig() *EnclaveConfig { } } -func FromFlags(cliFlags map[string]*flag.TenFlag) (*EnclaveConfig, error) { +func NewConfigFromFlags(cliFlags map[string]*flag.TenFlag) (*EnclaveConfig, error) { flagsTestMode := false // check if it's in test mode or not diff --git a/go/config/enclave_config_test.go b/go/config/enclave_config_test.go index 4798efe536..81854d7c3f 100644 --- a/go/config/enclave_config_test.go +++ b/go/config/enclave_config_test.go @@ -90,7 +90,7 @@ func TestRestrictedMode(t *testing.T) { flag.Parse() - enclaveConfig, err := FromFlags(flags) + enclaveConfig, err := NewConfigFromFlags(flags) require.NoError(t, err) require.Equal(t, int64(4444), enclaveConfig.L1ChainID) @@ -132,6 +132,6 @@ func TestRestrictedModeNoCLIDuplication(t *testing.T) { flag.Parse() - _, err = FromFlags(flags) + _, err = NewConfigFromFlags(flags) require.Errorf(t, err, "restricted flag was set: l1ChainID") } diff --git a/go/enclave/main/main.go b/go/enclave/main/main.go index 7d062a1b06..e276990960 100644 --- a/go/enclave/main/main.go +++ b/go/enclave/main/main.go @@ -20,7 +20,7 @@ func main() { tenflag.Parse() - enclaveConfig, err := config.FromFlags(flags) + enclaveConfig, err := config.NewConfigFromFlags(flags) if err != nil { panic(fmt.Errorf("unable to create config from flags - %w", err)) } From d85cad9955388cf598432dc2ebe9bf5cd367b537 Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 4 Dec 2023 14:42:27 +0000 Subject: [PATCH 09/12] pr comments --- go/config/enclave_cli_flags.go | 82 +++++++++++++++++----------------- go/config/enclave_config.go | 9 ++-- 2 files changed, 46 insertions(+), 45 deletions(-) diff --git a/go/config/enclave_cli_flags.go b/go/config/enclave_cli_flags.go index 175d2e8e57..bb006acdc8 100644 --- a/go/config/enclave_cli_flags.go +++ b/go/config/enclave_cli_flags.go @@ -2,47 +2,6 @@ package config import "github.com/ten-protocol/go-ten/go/common/flag" -// EnclaveFlags are the flags that the enclave can receive -func EnclaveFlags() map[string]*flag.TenFlag { - return map[string]*flag.TenFlag{ - HostIDFlag: flag.NewStringFlag(HostIDFlag, "", FlagDescriptionMap[HostIDFlag]), - HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", FlagDescriptionMap[HostAddressFlag]), - AddressFlag: flag.NewStringFlag(AddressFlag, "", FlagDescriptionMap[HostAddressFlag]), - NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", FlagDescriptionMap[NodeTypeFlag]), - WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, FlagDescriptionMap[WillAttestFlag]), - ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, FlagDescriptionMap[ValidateL1BlocksFlag]), - ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", FlagDescriptionMap[ManagementContractAddressFlag]), - LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, FlagDescriptionMap[LogLevelFlag]), - LogPathFlag: flag.NewStringFlag(LogPathFlag, "", FlagDescriptionMap[LogPathFlag]), - EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", FlagDescriptionMap[EdgelessDBHostFlag]), - SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", FlagDescriptionMap[SQLiteDBPathFlag]), - MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, FlagDescriptionMap[MinGasPriceFlag]), - MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", FlagDescriptionMap[MessageBusAddressFlag]), - SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", FlagDescriptionMap[SequencerIDFlag]), - MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, FlagDescriptionMap[MaxBatchSizeFlag]), - MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, FlagDescriptionMap[MaxRollupSizeFlag]), - L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 0, ""), - L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "", ""), - L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 0, ""), - ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), - L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), - ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), - UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), - ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), - DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), - } -} - -// enclaveRestrictedFlags are the flags that the enclave can receive ONLY over the Ego signed enclave.json -var enclaveRestrictedFlags = map[string]*flag.TenFlag{ - L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), - ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), - ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), - UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), - ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), - DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), -} - // Flag names. const ( HostIDFlag = "hostID" @@ -96,3 +55,44 @@ var FlagDescriptionMap = map[string]string{ MaxBatchSizeFlag: "The maximum size a batch is allowed to reach uncompressed", MaxRollupSizeFlag: "The maximum size a rollup is allowed to reach", } + +// EnclaveFlags are the flags that the enclave can receive +func EnclaveFlags() map[string]*flag.TenFlag { + return map[string]*flag.TenFlag{ + HostIDFlag: flag.NewStringFlag(HostIDFlag, "", FlagDescriptionMap[HostIDFlag]), + HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", FlagDescriptionMap[HostAddressFlag]), + AddressFlag: flag.NewStringFlag(AddressFlag, "", FlagDescriptionMap[HostAddressFlag]), + NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", FlagDescriptionMap[NodeTypeFlag]), + WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, FlagDescriptionMap[WillAttestFlag]), + ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, FlagDescriptionMap[ValidateL1BlocksFlag]), + ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", FlagDescriptionMap[ManagementContractAddressFlag]), + LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, FlagDescriptionMap[LogLevelFlag]), + LogPathFlag: flag.NewStringFlag(LogPathFlag, "", FlagDescriptionMap[LogPathFlag]), + EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", FlagDescriptionMap[EdgelessDBHostFlag]), + SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", FlagDescriptionMap[SQLiteDBPathFlag]), + MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, FlagDescriptionMap[MinGasPriceFlag]), + MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", FlagDescriptionMap[MessageBusAddressFlag]), + SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", FlagDescriptionMap[SequencerIDFlag]), + MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, FlagDescriptionMap[MaxBatchSizeFlag]), + MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, FlagDescriptionMap[MaxRollupSizeFlag]), + L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 0, ""), + L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "", ""), + L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 0, ""), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), + } +} + +// enclaveRestrictedFlags are the flags that the enclave can receive ONLY over the Ego signed enclave.json +var enclaveRestrictedFlags = map[string]*flag.TenFlag{ + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), +} diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index aa1dd7fc28..de4a3e7689 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -106,17 +106,18 @@ func DefaultEnclaveConfig() *EnclaveConfig { } func NewConfigFromFlags(cliFlags map[string]*flag.TenFlag) (*EnclaveConfig, error) { - flagsTestMode := false + productionMode := true - // check if it's in test mode or not + // check if it's in production mode or not val := os.Getenv("EDG_TESTMODE") if val == "true" { - flagsTestMode = true + productionMode = false + fmt.Println("Using test mode flags") } else { fmt.Println("Using mandatory signed configurations.") } - if !flagsTestMode { + if productionMode { envFlags, err := retrieveEnvFlags() if err != nil { return nil, fmt.Errorf("unable to retrieve env flags - %w", err) From 4285c60b0b41b982d66ea662ca9954a33769760e Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 4 Dec 2023 15:03:56 +0000 Subject: [PATCH 10/12] pr comments --- go/config/enclave_cli_flags.go | 83 ++++++++++++---------------------- go/config/enclave_config.go | 24 +++++----- 2 files changed, 41 insertions(+), 66 deletions(-) diff --git a/go/config/enclave_cli_flags.go b/go/config/enclave_cli_flags.go index bb006acdc8..023adc011a 100644 --- a/go/config/enclave_cli_flags.go +++ b/go/config/enclave_cli_flags.go @@ -31,68 +31,43 @@ const ( L2GasLimitFlag = "l2GasLimit" ) -var FlagDescriptionMap = map[string]string{ - HostIDFlag: "The 20 bytes of the address of the Obscuro host this enclave serves", - HostAddressFlag: "The peer-to-peer IP address of the Obscuro host this enclave serves", - AddressFlag: "The address on which to serve the Obscuro enclave service", - NodeTypeFlag: "The node's type (e.g. sequencer, validator)", - L1ChainIDFlag: "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)", - ObscuroChainIDFlag: "An integer representing the unique chain id of the Obscuro chain (default 443)", - WillAttestFlag: "Whether the enclave will produce a verified attestation report", - ValidateL1BlocksFlag: "Whether to validate incoming blocks using the hardcoded L1 genesis.json config", - ManagementContractAddressFlag: "The management contract address on the L1", - LogLevelFlag: "The verbosity level of logs. (Defaults to Info)", - LogPathFlag: "The path to use for the enclave service's log file", - UseInMemoryDBFlag: "Whether the enclave will use an in-memory DB rather than persist data", - EdgelessDBHostFlag: "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation", - SQLiteDBPathFlag: "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)", - ProfilerEnabledFlag: "Runs a profiler instance (Defaults to false)", - MinGasPriceFlag: "The minimum gas price for mining a transaction", - MessageBusAddressFlag: "The address of the L1 message bus contract owned by the management contract.", - SequencerIDFlag: "The 20 bytes of the address of the sequencer for this network", - ObscuroGenesisFlag: "The json string with the obscuro genesis", - DebugNamespaceEnabledFlag: "Whether the debug namespace is enabled", - MaxBatchSizeFlag: "The maximum size a batch is allowed to reach uncompressed", - MaxRollupSizeFlag: "The maximum size a rollup is allowed to reach", -} - // EnclaveFlags are the flags that the enclave can receive func EnclaveFlags() map[string]*flag.TenFlag { return map[string]*flag.TenFlag{ - HostIDFlag: flag.NewStringFlag(HostIDFlag, "", FlagDescriptionMap[HostIDFlag]), - HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", FlagDescriptionMap[HostAddressFlag]), - AddressFlag: flag.NewStringFlag(AddressFlag, "", FlagDescriptionMap[HostAddressFlag]), - NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", FlagDescriptionMap[NodeTypeFlag]), - WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, FlagDescriptionMap[WillAttestFlag]), - ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, FlagDescriptionMap[ValidateL1BlocksFlag]), - ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", FlagDescriptionMap[ManagementContractAddressFlag]), - LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, FlagDescriptionMap[LogLevelFlag]), - LogPathFlag: flag.NewStringFlag(LogPathFlag, "", FlagDescriptionMap[LogPathFlag]), - EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", FlagDescriptionMap[EdgelessDBHostFlag]), - SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", FlagDescriptionMap[SQLiteDBPathFlag]), - MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, FlagDescriptionMap[MinGasPriceFlag]), - MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", FlagDescriptionMap[MessageBusAddressFlag]), - SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", FlagDescriptionMap[SequencerIDFlag]), - MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, FlagDescriptionMap[MaxBatchSizeFlag]), - MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, FlagDescriptionMap[MaxRollupSizeFlag]), + HostIDFlag: flag.NewStringFlag(HostIDFlag, "", "The 20 bytes of the address of the Obscuro host this enclave serves"), + HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", "The peer-to-peer IP address of the Obscuro host this enclave serves"), + AddressFlag: flag.NewStringFlag(AddressFlag, "", "The address on which to serve the Obscuro enclave service"), + NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", "The node's type (e.g. sequencer, validator)"), + WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, "Whether the enclave will produce a verified attestation report"), + ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, "Whether to validate incoming blocks using the hardcoded L1 genesis.json config"), + ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", "The management contract address on the L1"), + LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, "The verbosity level of logs. (Defaults to Info)"), + LogPathFlag: flag.NewStringFlag(LogPathFlag, "", "The path to use for the enclave service's log file"), + EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation"), + SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)"), + MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, "The minimum gas price for mining a transaction"), + MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", "The address of the L1 message bus contract owned by the management contract."), + SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", "The 20 bytes of the address of the sequencer for this network"), + MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, "The maximum size a batch is allowed to reach uncompressed"), + MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, "The maximum size a rollup is allowed to reach"), L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 0, ""), L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "", ""), L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 0, ""), - ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), - L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), - ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), - UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), - ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), - DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", "The json string with the obscuro genesis"), + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)"), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, "An integer representing the unique chain id of the Obscuro chain (default 443)"), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, "Whether the enclave will use an in-memory DB rather than persist data"), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, "Runs a profiler instance (Defaults to false)"), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, "Whether the debug namespace is enabled"), } } // enclaveRestrictedFlags are the flags that the enclave can receive ONLY over the Ego signed enclave.json -var enclaveRestrictedFlags = map[string]*flag.TenFlag{ - L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, FlagDescriptionMap[L1ChainIDFlag]), - ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, FlagDescriptionMap[ObscuroChainIDFlag]), - ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", FlagDescriptionMap[ObscuroGenesisFlag]), - UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, FlagDescriptionMap[UseInMemoryDBFlag]), - ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, FlagDescriptionMap[ProfilerEnabledFlag]), - DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, FlagDescriptionMap[DebugNamespaceEnabledFlag]), +var enclaveRestrictedFlags = []string{ + L1ChainIDFlag, + ObscuroChainIDFlag, + ObscuroGenesisFlag, + UseInMemoryDBFlag, + ProfilerEnabledFlag, + DebugNamespaceEnabledFlag, } diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index de4a3e7689..768164c478 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -149,39 +149,39 @@ func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { parsedFlags := map[string]*flag.TenFlag{} for _, eflag := range enclaveRestrictedFlags { - val := os.Getenv("EDG_" + strings.ToUpper(eflag.Name)) + val := os.Getenv("EDG_" + strings.ToUpper(eflag)) // all env flags must be set if val == "" { - return nil, fmt.Errorf("env var not set: %s", eflag.Name) + return nil, fmt.Errorf("env var not set: %s", eflag) } - switch eflag.FlagType { + switch EnclaveFlags()[eflag].FlagType { case "string": - parsedFlag := flag.NewStringFlag(eflag.Name, "", "") + parsedFlag := flag.NewStringFlag(eflag, "", "") parsedFlag.Value = val - parsedFlags[eflag.Name] = parsedFlag + parsedFlags[eflag] = parsedFlag case "int64": i, err := strconv.ParseInt(val, 10, 64) if err != nil { - return nil, fmt.Errorf("unable to parse flag %s - %w", eflag.Name, err) + return nil, fmt.Errorf("unable to parse flag %s - %w", eflag, err) } - parsedFlag := flag.NewIntFlag(eflag.Name, 0, "") + parsedFlag := flag.NewIntFlag(eflag, 0, "") parsedFlag.Value = i - parsedFlags[eflag.Name] = parsedFlag + parsedFlags[eflag] = parsedFlag case "bool": b, err := strconv.ParseBool(val) if err != nil { - return nil, fmt.Errorf("unable to parse flag %s - %w", eflag.Name, err) + return nil, fmt.Errorf("unable to parse flag %s - %w", eflag, err) } - parsedFlag := flag.NewBoolFlag(eflag.Name, false, "") + parsedFlag := flag.NewBoolFlag(eflag, false, "") parsedFlag.Value = b - parsedFlags[eflag.Name] = parsedFlag + parsedFlags[eflag] = parsedFlag default: - return nil, fmt.Errorf("unexpected type: %s", eflag.FlagType) + return nil, fmt.Errorf("unexpected type: %s", EnclaveFlags()[eflag].FlagType) } } return parsedFlags, nil From 5087ef5bdf34d64660c78928848715b8bc453808 Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 4 Dec 2023 15:06:48 +0000 Subject: [PATCH 11/12] pr comments --- go/enclave/main/main.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/go/enclave/main/main.go b/go/enclave/main/main.go index e276990960..9b4bab37c6 100644 --- a/go/enclave/main/main.go +++ b/go/enclave/main/main.go @@ -15,7 +15,7 @@ func main() { flags := config.EnclaveFlags() err := tenflag.CreateCLIFlags(flags) if err != nil { - panic(fmt.Errorf("could not parse config. Cause: %w", err)) + panic(fmt.Errorf("could not create CLI flags. Cause: %w", err)) } tenflag.Parse() From 190302d1964e1c1c0f9991acf8085c95a80c0c0f Mon Sep 17 00:00:00 2001 From: otherview Date: Mon, 4 Dec 2023 16:00:46 +0000 Subject: [PATCH 12/12] pr comments --- go/config/enclave_cli_flags.go | 59 ++++++++++++----------- go/config/enclave_config.go | 43 ++--------------- go/config/enclave_config_test.go | 6 +-- go/enclave/main/main.go | 6 +-- go/node/config.go | 3 +- integration/common/constants.go | 41 +++++++++++++++- integration/simulation/devnetwork/node.go | 4 +- 7 files changed, 85 insertions(+), 77 deletions(-) diff --git a/go/config/enclave_cli_flags.go b/go/config/enclave_cli_flags.go index 023adc011a..030ddd1c87 100644 --- a/go/config/enclave_cli_flags.go +++ b/go/config/enclave_cli_flags.go @@ -1,6 +1,9 @@ package config -import "github.com/ten-protocol/go-ten/go/common/flag" +import ( + "github.com/ten-protocol/go-ten/go/common" + "github.com/ten-protocol/go-ten/go/common/flag" +) // Flag names. const ( @@ -32,34 +35,32 @@ const ( ) // EnclaveFlags are the flags that the enclave can receive -func EnclaveFlags() map[string]*flag.TenFlag { - return map[string]*flag.TenFlag{ - HostIDFlag: flag.NewStringFlag(HostIDFlag, "", "The 20 bytes of the address of the Obscuro host this enclave serves"), - HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "", "The peer-to-peer IP address of the Obscuro host this enclave serves"), - AddressFlag: flag.NewStringFlag(AddressFlag, "", "The address on which to serve the Obscuro enclave service"), - NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, "", "The node's type (e.g. sequencer, validator)"), - WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, "Whether the enclave will produce a verified attestation report"), - ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, "Whether to validate incoming blocks using the hardcoded L1 genesis.json config"), - ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", "The management contract address on the L1"), - LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 0, "The verbosity level of logs. (Defaults to Info)"), - LogPathFlag: flag.NewStringFlag(LogPathFlag, "", "The path to use for the enclave service's log file"), - EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation"), - SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)"), - MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 0, "The minimum gas price for mining a transaction"), - MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", "The address of the L1 message bus contract owned by the management contract."), - SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", "The 20 bytes of the address of the sequencer for this network"), - MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 0, "The maximum size a batch is allowed to reach uncompressed"), - MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 0, "The maximum size a rollup is allowed to reach"), - L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 0, ""), - L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "", ""), - L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 0, ""), - ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", "The json string with the obscuro genesis"), - L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 0, "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)"), - ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 0, "An integer representing the unique chain id of the Obscuro chain (default 443)"), - UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, false, "Whether the enclave will use an in-memory DB rather than persist data"), - ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, "Runs a profiler instance (Defaults to false)"), - DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, "Whether the debug namespace is enabled"), - } +var EnclaveFlags = map[string]*flag.TenFlag{ + HostIDFlag: flag.NewStringFlag(HostIDFlag, "", "The 20 bytes of the address of the Obscuro host this enclave serves"), + HostAddressFlag: flag.NewStringFlag(HostAddressFlag, "127.0.0.1:10000", "The peer-to-peer IP address of the Obscuro host this enclave serves"), + AddressFlag: flag.NewStringFlag(AddressFlag, "127.0.0.1:11000", "The address on which to serve the Obscuro enclave service"), + NodeTypeFlag: flag.NewStringFlag(NodeTypeFlag, common.Sequencer.String(), "The node's type (e.g. sequencer, validator)"), + WillAttestFlag: flag.NewBoolFlag(WillAttestFlag, false, "Whether the enclave will produce a verified attestation report"), + ValidateL1BlocksFlag: flag.NewBoolFlag(ValidateL1BlocksFlag, false, "Whether to validate incoming blocks using the hardcoded L1 genesis.json config"), + ManagementContractAddressFlag: flag.NewStringFlag(ManagementContractAddressFlag, "", "The management contract address on the L1"), + LogLevelFlag: flag.NewIntFlag(LogLevelFlag, 3, "The verbosity level of logs. (Defaults to Info)"), + LogPathFlag: flag.NewStringFlag(LogPathFlag, "stdout", "The path to use for the enclave service's log file"), + EdgelessDBHostFlag: flag.NewStringFlag(EdgelessDBHostFlag, "", "Host address for the edgeless DB instance (can be empty if useInMemoryDB is true or if not using attestation"), + SQLiteDBPathFlag: flag.NewStringFlag(SQLiteDBPathFlag, "", "Filepath for the sqlite DB persistence file (can be empty if a throwaway file in /tmp/ is acceptable or if using InMemory DB or if using attestation/EdgelessDB)"), + MinGasPriceFlag: flag.NewInt64Flag(MinGasPriceFlag, 1, "The minimum gas price for mining a transaction"), + MessageBusAddressFlag: flag.NewStringFlag(MessageBusAddressFlag, "", "The address of the L1 message bus contract owned by the management contract."), + SequencerIDFlag: flag.NewStringFlag(SequencerIDFlag, "", "The 20 bytes of the address of the sequencer for this network"), + MaxBatchSizeFlag: flag.NewUint64Flag(MaxBatchSizeFlag, 1024*25, "The maximum size a batch is allowed to reach uncompressed"), + MaxRollupSizeFlag: flag.NewUint64Flag(MaxRollupSizeFlag, 1024*64, "The maximum size a rollup is allowed to reach"), + L2BaseFeeFlag: flag.NewUint64Flag(L2BaseFeeFlag, 1, ""), + L2CoinbaseFlag: flag.NewStringFlag(L2CoinbaseFlag, "0xd6C9230053f45F873Cb66D8A02439380a37A4fbF", ""), + L2GasLimitFlag: flag.NewUint64Flag(L2GasLimitFlag, 9e18, ""), + ObscuroGenesisFlag: flag.NewStringFlag(ObscuroGenesisFlag, "", "The json string with the obscuro genesis"), + L1ChainIDFlag: flag.NewInt64Flag(L1ChainIDFlag, 1337, "An integer representing the unique chain id of the Ethereum chain used as an L1 (default 1337)"), + ObscuroChainIDFlag: flag.NewInt64Flag(ObscuroChainIDFlag, 443, "An integer representing the unique chain id of the Obscuro chain (default 443)"), + UseInMemoryDBFlag: flag.NewBoolFlag(UseInMemoryDBFlag, true, "Whether the enclave will use an in-memory DB rather than persist data"), + ProfilerEnabledFlag: flag.NewBoolFlag(ProfilerEnabledFlag, false, "Runs a profiler instance (Defaults to false)"), + DebugNamespaceEnabledFlag: flag.NewBoolFlag(DebugNamespaceEnabledFlag, false, "Whether the debug namespace is enabled"), } // enclaveRestrictedFlags are the flags that the enclave can receive ONLY over the Ego signed enclave.json diff --git a/go/config/enclave_config.go b/go/config/enclave_config.go index 768164c478..30c7fe6aca 100644 --- a/go/config/enclave_config.go +++ b/go/config/enclave_config.go @@ -7,13 +7,9 @@ import ( "strconv" "strings" - "github.com/ethereum/go-ethereum/params" + gethcommon "github.com/ethereum/go-ethereum/common" "github.com/ten-protocol/go-ten/go/common" "github.com/ten-protocol/go-ten/go/common/flag" - "github.com/ten-protocol/go-ten/go/common/log" - - gethcommon "github.com/ethereum/go-ethereum/common" - gethlog "github.com/ethereum/go-ethereum/log" ) // EnclaveConfig contains the full configuration for an Obscuro enclave service. @@ -74,37 +70,6 @@ type EnclaveConfig struct { GasLimit *big.Int } -// DefaultEnclaveConfig returns an EnclaveConfig with default values. -func DefaultEnclaveConfig() *EnclaveConfig { - return &EnclaveConfig{ - HostID: gethcommon.BytesToAddress([]byte("")), - HostAddress: "127.0.0.1:10000", - Address: "127.0.0.1:11000", - NodeType: common.Sequencer, - L1ChainID: 1337, - ObscuroChainID: 443, - WillAttest: false, // todo (config) - attestation should be on by default before production release - ValidateL1Blocks: false, - GenesisJSON: nil, - ManagementContractAddress: gethcommon.BytesToAddress([]byte("")), - LogLevel: int(gethlog.LvlInfo), - LogPath: log.SysOut, - UseInMemoryDB: true, // todo (config) - persistence should be on by default before production release - EdgelessDBHost: "", - SqliteDBPath: "", - ProfilerEnabled: false, - MinGasPrice: big.NewInt(1), - SequencerID: gethcommon.BytesToAddress([]byte("")), - ObscuroGenesis: "", - DebugNamespaceEnabled: false, - MaxBatchSize: 1024 * 25, - MaxRollupSize: 1024 * 64, - GasPaymentAddress: gethcommon.HexToAddress("0xd6C9230053f45F873Cb66D8A02439380a37A4fbF"), - BaseFee: new(big.Int).SetUint64(1), - GasLimit: new(big.Int).SetUint64(params.MaxGasLimit / 6), - } -} - func NewConfigFromFlags(cliFlags map[string]*flag.TenFlag) (*EnclaveConfig, error) { productionMode := true @@ -156,7 +121,7 @@ func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { return nil, fmt.Errorf("env var not set: %s", eflag) } - switch EnclaveFlags()[eflag].FlagType { + switch EnclaveFlags[eflag].FlagType { case "string": parsedFlag := flag.NewStringFlag(eflag, "", "") parsedFlag.Value = val @@ -181,14 +146,14 @@ func retrieveEnvFlags() (map[string]*flag.TenFlag, error) { parsedFlag.Value = b parsedFlags[eflag] = parsedFlag default: - return nil, fmt.Errorf("unexpected type: %s", EnclaveFlags()[eflag].FlagType) + return nil, fmt.Errorf("unexpected type: %s", EnclaveFlags[eflag].FlagType) } } return parsedFlags, nil } func newConfig(flags map[string]*flag.TenFlag) (*EnclaveConfig, error) { - cfg := DefaultEnclaveConfig() + cfg := &EnclaveConfig{} nodeType, err := common.ToNodeType(flags[NodeTypeFlag].String()) if err != nil { diff --git a/go/config/enclave_config_test.go b/go/config/enclave_config_test.go index 81854d7c3f..79cd1361d8 100644 --- a/go/config/enclave_config_test.go +++ b/go/config/enclave_config_test.go @@ -21,7 +21,7 @@ func TestCLIFlagTypes(t *testing.T) { flag.CommandLine = originalFlagSet }() - flags := EnclaveFlags() + flags := EnclaveFlags err := tenflag.CreateCLIFlags(flags) require.NoError(t, err) @@ -81,7 +81,7 @@ func TestRestrictedMode(t *testing.T) { t.Setenv("EDG_"+strings.ToUpper(ProfilerEnabledFlag), "true") t.Setenv("EDG_"+strings.ToUpper(DebugNamespaceEnabledFlag), "true") - flags := EnclaveFlags() + flags := EnclaveFlags err := tenflag.CreateCLIFlags(flags) require.NoError(t, err) @@ -120,7 +120,7 @@ func TestRestrictedModeNoCLIDuplication(t *testing.T) { t.Setenv("EDG_"+strings.ToUpper(ProfilerEnabledFlag), "true") t.Setenv("EDG_"+strings.ToUpper(DebugNamespaceEnabledFlag), "true") - flags := EnclaveFlags() + flags := EnclaveFlags err := tenflag.CreateCLIFlags(flags) require.NoError(t, err) diff --git a/go/enclave/main/main.go b/go/enclave/main/main.go index 9b4bab37c6..48ffc8c4be 100644 --- a/go/enclave/main/main.go +++ b/go/enclave/main/main.go @@ -12,13 +12,13 @@ import ( // Runs an Obscuro enclave as a standalone process. func main() { // fetch and parse flags - flags := config.EnclaveFlags() - err := tenflag.CreateCLIFlags(flags) + flags := config.EnclaveFlags // fetch the flags that enclave requires + err := tenflag.CreateCLIFlags(config.EnclaveFlags) // using tenflag convert those flags into the golang flags package ( go flags is a singlen ) if err != nil { panic(fmt.Errorf("could not create CLI flags. Cause: %w", err)) } - tenflag.Parse() + tenflag.Parse() // parse the golang flags package defined flags from CLI enclaveConfig, err := config.NewConfigFromFlags(flags) if err != nil { diff --git a/go/node/config.go b/go/node/config.go index 7aa3b93dce..13a27978cb 100644 --- a/go/node/config.go +++ b/go/node/config.go @@ -9,6 +9,7 @@ import ( "github.com/ten-protocol/go-ten/integration/common/testlog" gethcommon "github.com/ethereum/go-ethereum/common" + integrationCommon "github.com/ten-protocol/go-ten/integration/common" ) const ( @@ -73,7 +74,7 @@ func NewNodeConfig(opts ...Option) *Config { } func (c *Config) ToEnclaveConfig() *config.EnclaveConfig { - cfg := config.DefaultEnclaveConfig() + cfg := integrationCommon.DefaultEnclaveConfig() if c.nodeType == "validator" { cfg.NodeType = common.Validator diff --git a/integration/common/constants.go b/integration/common/constants.go index 7934dd0e93..63e4ab993c 100644 --- a/integration/common/constants.go +++ b/integration/common/constants.go @@ -1,9 +1,17 @@ package common import ( - gethcommon "github.com/ethereum/go-ethereum/common" + "math/big" + "github.com/ethereum/go-ethereum/crypto" + "github.com/ethereum/go-ethereum/params" + "github.com/ten-protocol/go-ten/go/common" + "github.com/ten-protocol/go-ten/go/common/log" + "github.com/ten-protocol/go-ten/go/config" "github.com/ten-protocol/go-ten/go/wallet" + + gethcommon "github.com/ethereum/go-ethereum/common" + gethlog "github.com/ethereum/go-ethereum/log" ) // The Contract addresses are the result of the deploying a smart contract from hardcoded owners. @@ -48,3 +56,34 @@ type ERC20Mapping struct { Owner wallet.Wallet // for now the wrapped L2 version is owned by a wallet, but this will change L2Address *gethcommon.Address } + +// DefaultEnclaveConfig returns an EnclaveConfig with default values. +func DefaultEnclaveConfig() *config.EnclaveConfig { + return &config.EnclaveConfig{ + HostID: gethcommon.BytesToAddress([]byte("")), + HostAddress: "127.0.0.1:10000", + Address: "127.0.0.1:11000", + NodeType: common.Sequencer, + L1ChainID: 1337, + ObscuroChainID: 443, + WillAttest: false, // todo (config) - attestation should be on by default before production release + ValidateL1Blocks: false, + GenesisJSON: nil, + ManagementContractAddress: gethcommon.BytesToAddress([]byte("")), + LogLevel: int(gethlog.LvlInfo), + LogPath: log.SysOut, + UseInMemoryDB: true, // todo (config) - persistence should be on by default before production release + EdgelessDBHost: "", + SqliteDBPath: "", + ProfilerEnabled: false, + MinGasPrice: big.NewInt(1), + SequencerID: gethcommon.BytesToAddress([]byte("")), + ObscuroGenesis: "", + DebugNamespaceEnabled: false, + MaxBatchSize: 1024 * 25, + MaxRollupSize: 1024 * 64, + GasPaymentAddress: gethcommon.HexToAddress("0xd6C9230053f45F873Cb66D8A02439380a37A4fbF"), + BaseFee: new(big.Int).SetUint64(1), + GasLimit: new(big.Int).SetUint64(params.MaxGasLimit / 6), + } +} diff --git a/integration/simulation/devnetwork/node.go b/integration/simulation/devnetwork/node.go index 60e70c2dca..f2922b6f31 100644 --- a/integration/simulation/devnetwork/node.go +++ b/integration/simulation/devnetwork/node.go @@ -31,6 +31,8 @@ import ( "github.com/ten-protocol/go-ten/integration/common/testlog" "github.com/ten-protocol/go-ten/integration/simulation/network" "github.com/ten-protocol/go-ten/integration/simulation/params" + + integrationCommon "github.com/ten-protocol/go-ten/integration/common" ) // InMemNodeOperator represents an Obscuro node playing a role in a DevSimulation @@ -158,7 +160,7 @@ func (n *InMemNodeOperator) createEnclaveContainer() *enclavecontainer.EnclaveCo hostPort := n.config.PortStart + integration.DefaultHostP2pOffset + n.operatorIdx hostAddr := fmt.Sprintf("%s:%d", network.Localhost, hostPort) - defaultCfg := config.DefaultEnclaveConfig() + defaultCfg := integrationCommon.DefaultEnclaveConfig() enclaveConfig := &config.EnclaveConfig{ HostID: n.l1Wallet.Address(),