diff --git a/.gitignore b/.gitignore index e5a47a9b..cb617397 100644 --- a/.gitignore +++ b/.gitignore @@ -17,6 +17,7 @@ restagent/upload/ restagent/software/ restagent/database/ restagent/license/ +restagent/restagent sshsvc/sshsvc sshsvc/mmllog/ @@ -33,6 +34,7 @@ vendor *.vsix *.log *.log-* +*.log.* *.bak *.bak* *.exe diff --git a/go.mod b/go.mod index a013be2c..b3873542 100644 --- a/go.mod +++ b/go.mod @@ -43,6 +43,8 @@ require ( xorm.io/xorm v1.3.9 ) +require github.com/google/go-cmp v0.6.0 // indirect + require ( filippo.io/edwards25519 v1.1.0 // indirect github.com/KyleBanks/depth v1.2.1 // indirect @@ -67,7 +69,7 @@ require ( github.com/go-openapi/swag v0.23.0 // indirect github.com/go-playground/locales v0.14.1 // indirect github.com/go-playground/universal-translator v0.18.1 // indirect - github.com/go-playground/validator/v10 v10.22.0 // indirect + github.com/go-playground/validator/v10 v10.22.0 github.com/goccy/go-json v0.10.3 // indirect github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 // indirect github.com/golang/snappy v0.0.4 // indirect diff --git a/go.sum b/go.sum index e013b378..59b0d79c 100644 --- a/go.sum +++ b/go.sum @@ -1,10 +1,24 @@ +cloud.google.com/go v0.112.1/go.mod h1:+Vbu+Y1UU+I1rjmzeMOb/8RfkKJK2Gyxi1X6jJCZLo4= +cloud.google.com/go/compute v1.24.0/go.mod h1:kw1/T+h/+tK2LJK0wiPPx1intgdAM3j/g3hFDlscY40= +cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA= +cloud.google.com/go/firestore v1.15.0/go.mod h1:GWOxFXcv8GZUtYpWHw/w6IuYNux/BtmeVTMmjrm4yhk= +cloud.google.com/go/iam v1.1.5/go.mod h1:rB6P/Ic3mykPbFio+vo7403drjlgvoWfYpJhMXEbzv8= +cloud.google.com/go/longrunning v0.5.5/go.mod h1:WV2LAxD8/rg5Z1cNW6FJ/ZpX4E4VnDnoTk0yawPBB7s= +cloud.google.com/go/storage v1.35.1/go.mod h1:M6M/3V/D3KpzMTJyPOR/HU6n2Si5QdaXYEsng2xgOs8= filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA= filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4= gitea.com/xorm/sqlfiddle v0.0.0-20180821085327-62ce714f951a h1:lSA0F4e9A2NcQSqGqTOXqu2aRi/XEQxDCBwM8yJtE6s= gitea.com/xorm/sqlfiddle v0.0.0-20180821085327-62ce714f951a/go.mod h1:EXuID2Zs0pAQhH8yz+DNjUbjppKQzKFAn28TMYPB6IU= +gitee.com/travelliu/dm v1.8.11192/go.mod h1:DHTzyhCrM843x9VdKVbZ+GKXGRbKM2sJ4LxihRxShkE= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/KyleBanks/depth v1.2.1 h1:5h8fQADFrWtarTdtDudMmGsC7GPbOAu6RVB3ffsVFHc= github.com/KyleBanks/depth v1.2.1/go.mod h1:jzSb9d0L43HxTQfT+oSA1EEp2q+ne2uh6XgeJcm8brE= +github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= +github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= +github.com/alecthomas/kingpin/v2 v2.4.0/go.mod h1:0gyi0zQnjuFk8xrkNKamJoyUo382HRL7ATRpFZCw6tE= +github.com/alecthomas/units v0.0.0-20211218093645-b94a6e3cc137/go.mod h1:OMCwj8VM1Kc9e19TLln2VL61YJF0x1XFtfdL4JdbSyE= +github.com/allegro/bigcache/v3 v3.1.0/go.mod h1:aPyh7jEvrog9zAwx5N7+JUQX5dZTSGpxF1LAR4dr35I= +github.com/armon/go-metrics v0.4.1/go.mod h1:E6amYzXo6aW1tqzoZGT755KkbgrJsSdpwZ+3JqfkOG4= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/bsm/ginkgo/v2 v2.12.0 h1:Ny8MWAHyOepLGlLKYmXG4IEkioBysk6GpaRTLC8zwWs= @@ -20,10 +34,13 @@ github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UF github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/chenjiandongx/ginprom v0.0.0-20210617023641-6c809602c38a h1:yTfhjWYoPomJkHVArtNHpo36FuOa6Kc2ZjTLvyyQ5Lg= github.com/chenjiandongx/ginprom v0.0.0-20210617023641-6c809602c38a/go.mod h1:lINNCb1ZH3c0uL/9ApaQ8muR4QILsi0STj8Ojt8ZmwU= +github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= github.com/cloudwego/base64x v0.1.4 h1:jwCgWpFanWmN8xoIUHa2rtzmkd5J2plF/dnLS6Xd/0Y= github.com/cloudwego/base64x v0.1.4/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w= github.com/cloudwego/iasm v0.2.0 h1:1KNIy1I1H9hNNFEEH3DVnI4UujN+1zjpuk6gwHLTssg= github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY= +github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= +github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -39,6 +56,8 @@ github.com/ebitengine/purego v0.8.1 h1:sdRKd6plj7KYW33EH5As6YKfe8m9zbN9JMrOjNVF/ github.com/ebitengine/purego v0.8.1/go.mod h1:iIjxzd6CiRiOG0UyXP+V1+jWqUXVjPKLAI0mRfJZTmQ= github.com/fastly/go-utils v0.0.0-20180712184237-d95a45783239 h1:Ghm4eQYC0nEPnSJdVkTrXpu9KtoVCSo1hg7mtI7G9KU= github.com/fastly/go-utils v0.0.0-20180712184237-d95a45783239/go.mod h1:Gdwt2ce0yfBxPvZrHkprdPPTTS3N5rwmLE8T22KBXlw= +github.com/fatih/color v1.14.1/go.mod h1:2oHN61fhTpgcxD3TSWCgKDiH1+x4OiDVVGH8WlgGZGg= +github.com/felixge/httpsnoop v1.0.4/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHkI4W8= github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= @@ -55,6 +74,10 @@ github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU= github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y= github.com/go-forks/fsnotify v1.4.7 h1:lyiU2Wqd4fNGCQDn9dZ4UxSiSFgeU1rM6yIfahk8haY= github.com/go-forks/fsnotify v1.4.7/go.mod h1:AU8mot+GznW5+B4jRJHxKg/2EeO+jMORGRkKSxs0biw= +github.com/go-kit/log v0.2.1/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0= +github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs= +github.com/go-logr/logr v1.4.1/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= +github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0= github.com/go-ole/go-ole v1.3.0 h1:Dt6ye7+vXGIKZ7Xtk4s6/xVdGDQynvom7xCFEdWr6uE= github.com/go-ole/go-ole v1.3.0/go.mod h1:5LS6F96DhAwUc7C+1HLexzMXY1xGRSryjyPPKW6zv78= @@ -82,10 +105,14 @@ github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqw github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE= github.com/goccy/go-json v0.10.3 h1:KZ5WoDbxAIgm2HNbYckL0se1fHD6rz5j4ywS6ebzDqA= github.com/goccy/go-json v0.10.3/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M= +github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang-jwt/jwt/v5 v5.2.1 h1:OuVbFODueb089Lh128TAcimifWaLhJwVflnrgM17wHk= github.com/golang-jwt/jwt/v5 v5.2.1/go.mod h1:pqrtFR0X4osieyHYxtmOUWsAWrfe1Q5UVIyoH402zdk= +github.com/golang-sql/civil v0.0.0-20220223132316-b832511892a9/go.mod h1:8vg3r2VgvsThLBIFL93Qb5yWzgyZWhEmBwUJWevAkK0= +github.com/golang-sql/sqlexp v0.1.0/go.mod h1:J4ad9Vo8ZCWQ2GMrC4UCQy1JpCbwU9m3EOqtpKwwwHI= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF08vX0COfcOBJRhZ8lUbR+ZWIs0Y5g= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= +github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/mock v1.6.0/go.mod h1:p6yTPP+5HYm5mzsMV8JkE6ZKdX+/wYM6Hr+LicevLPs= github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= @@ -94,6 +121,7 @@ github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrU github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:WU3c8KckQ9AFe+yFwt9sWVRKCVIyN9cPHBJSNnbL67w= github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= +github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM= github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= @@ -106,8 +134,12 @@ github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/gopacket v1.1.19/go.mod h1:iJ8V8n6KS+z2U1A8pUwu8bW5SyEMkXJB8Yo/Vo+TKTo= +github.com/google/s2a-go v0.1.7/go.mod h1:50CgR4k1jNlWBu4UfS4AcfhVe1r6pdZPygJ3R8F0Qdw= github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/googleapis/enterprise-certificate-proxy v0.3.2/go.mod h1:VLSiSSBs/ksPL8kq3OBOQ6WRI2QnaFynd1DCjZ62+V0= +github.com/googleapis/gax-go/v2 v2.12.3/go.mod h1:AKloxT6GtNbaLm8QTNSidHUVsHYcBHwWRvkNFJUQcS4= +github.com/googleapis/google-cloud-go-testing v0.0.0-20210719221736-1c9a4c676720/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= github.com/gopacket/gopacket v1.2.0 h1:eXbzFad7f73P1n2EJHQlsKuvIMJjVXK5tXoSca78I3A= github.com/gopacket/gopacket v1.2.0/go.mod h1:BrAKEy5EOGQ76LSqh7DMAr7z0NNPdczWm2GxCG7+I8M= github.com/gorilla/mux v1.8.1 h1:TuBL49tXwgrFYWhqrNgrUNEY92u81SPhu7sTdzQEiWY= @@ -117,9 +149,26 @@ github.com/gorilla/websocket v1.5.3/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/ad github.com/gosnmp/gosnmp v1.36.2-0.20231009064202-d306ed5aa998/go.mod h1:O938QjIS4vpSag1UTcnnBq9MfNmimuOGtvQsT1NbErc= github.com/gosnmp/gosnmp v1.38.0 h1:I5ZOMR8kb0DXAFg/88ACurnuwGwYkXWq3eLpJPHMEYc= github.com/gosnmp/gosnmp v1.38.0/go.mod h1:FE+PEZvKrFz9afP9ii1W3cprXuVZ17ypCcyyfYuu5LY= +github.com/hashicorp/consul/api v1.28.2/go.mod h1:KyzqzgMEya+IZPcD65YFoOVAgPpbfERu4I/tzG6/ueE= +github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= +github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48= +github.com/hashicorp/go-hclog v1.5.0/go.mod h1:W4Qnvbt70Wk/zYJryRzDRU/4r0kIg0PVHBcfoyhpF5M= +github.com/hashicorp/go-immutable-radix v1.3.1/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= +github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM= +github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8= +github.com/hashicorp/golang-lru v0.5.4/go.mod h1:iADmTwqILo4mZ8BN3D2Q6+9jd8WM5uGBxy+E8yxSoD4= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= +github.com/hashicorp/serf v0.10.1/go.mod h1:yL2t6BqATOLGc5HF7qbFkTfXoPIY0WZdWHfEvMqbG+4= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= +github.com/jackc/chunkreader/v2 v2.0.1/go.mod h1:odVSm741yZoC3dpHEUXIqA9tQRhFrgOHwnPIn9lDKlk= +github.com/jackc/pgconn v1.14.0/go.mod h1:9mBNlny0UvkgJdCDvdVHYSjI+8tD2rnKK69Wz8ti++E= +github.com/jackc/pgio v1.0.0/go.mod h1:oP+2QK2wFfUWgr+gxjoBH9KGBb31Eio69xUb0w5bYf8= +github.com/jackc/pgpassfile v1.0.0/go.mod h1:CEx0iS5ambNFdcRtxPj5JhEz+xB6uRky5eyVu/W2HEg= +github.com/jackc/pgproto3/v2 v2.3.2/go.mod h1:WfJCnwN3HIg9Ish/j3sgWXnAfK8A9Y0bwXYU5xKaEdA= +github.com/jackc/pgservicefile v0.0.0-20221227161230-091c0ba34f0a/go.mod h1:5TJZWKEWniPve33vlWYSoGYefn3gLQRzjfDlhSJ9ZKM= +github.com/jackc/pgtype v1.14.0/go.mod h1:LUMuVrfsFfdKGLw+AFFVv6KtHOFMwRgDDzBt76IqCA4= +github.com/jackc/pgx/v4 v4.18.0/go.mod h1:FydWkUyadDmdNH/mHnGob881GawxeEm7TcMCzkb+qQE= github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869 h1:IPJ3dvxmJ4uczJe5YQdrYB16oTJlGSC/OyZDqUk9xX4= github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869/go.mod h1:cJ6Cj7dQo+O6GJNiMx+Pa94qKj+TG8ONdKHgMNIyyag= github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E= @@ -130,8 +179,10 @@ github.com/jonboulle/clockwork v0.4.0 h1:p4Cf1aMWXnXAUh8lVfewRBx1zaTSYKrKMF2g3ST github.com/jonboulle/clockwork v0.4.0/go.mod h1:xgRqUGwRcjKCO1vbZUEtSLrqKoPSsUpK7fnezOII0kc= github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= 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/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= +github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8= github.com/klauspost/compress v1.17.9 h1:6KIumPrER1LHsvBVuDa0r5xaG0Es51mhhB9BQB2qeMA= @@ -158,6 +209,7 @@ github.com/lestrrat/go-file-rotatelogs v0.0.0-20180223000712-d3151e2a480f h1:sgU github.com/lestrrat/go-file-rotatelogs v0.0.0-20180223000712-d3151e2a480f/go.mod h1:UGmTpUd3rjbtfIpwAPrcfmGf/Z1HS95TATB+m57TPB8= github.com/lestrrat/go-strftime v0.0.0-20180220042222-ba3bf9c1d042 h1:Bvq8AziQ5jFF4BHGAEDSqwPW1NJS3XshxbRCxtjFAZc= github.com/lestrrat/go-strftime v0.0.0-20180220042222-ba3bf9c1d042/go.mod h1:TPpsiPUEh0zFL1Snz4crhMlBe60PYxRHr5oFF3rRYg0= +github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o= github.com/linxGnu/gosmpp v0.3.0 h1:LL+eY+zc9Ei/YY0po9A6L6SHf8nPyGvqsLddttr/y/4= github.com/linxGnu/gosmpp v0.3.0/go.mod h1:Ba6SULQql3IbF2A5Mtj3DqMKoFbx1pEz/8xyiOh8ZOs= github.com/lufia/plan9stats v0.0.0-20211012122336-39d0f177ccd0/go.mod h1:zJYVVT2jmtg6P3p1VtQj7WsuWi/y4VnjVBn7F8KPB3I= @@ -169,6 +221,7 @@ github.com/mailru/easyjson v0.9.0 h1:PrnmzHw7262yW8sTBwxi1PdJA3Iw/EKBa8psRf7d9a4 github.com/mailru/easyjson v0.9.0/go.mod h1:1+xMtQp2MRNVL/V1bOzuP3aP8VNwRW55fQUto+XFtTU= github.com/matoous/go-nanoid/v2 v2.1.0 h1:P64+dmq21hhWdtvZfEAofnvJULaRR1Yib0+PnU669bE= github.com/matoous/go-nanoid/v2 v2.1.0/go.mod h1:KlbGNQ+FhrUNIHUxZdL63t7tl4LaPkZNpUULS8H4uVM= +github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mattn/go-sqlite3 v1.14.16 h1:yOQRA0RpS5PFz/oikGwBEqvAWhWg5ufRz4ETLjwpU1Y= @@ -177,6 +230,8 @@ github.com/metaleap/go-util v0.0.0-20180330192724-a09253046f73 h1:4vKVhAdype/dej github.com/metaleap/go-util v0.0.0-20180330192724-a09253046f73/go.mod h1:l71/5fppWP5A6nqhcxz6wQAYok6pr/vM2+KHIy50/LY= github.com/metaleap/go-xsd v0.0.0-20180330193350-61f7638f502f h1:eeJGcYszuvOpmuJxeq57LaOO8mJurfjpOHJJMfQSD0s= github.com/metaleap/go-xsd v0.0.0-20180330193350-61f7638f502f/go.mod h1:WK3zEKtwVd/v+NM3lh1ZE6MdDfHsdOFFOD5Ezi4Hutg= +github.com/microsoft/go-mssqldb v1.6.0/go.mod h1:00mDtPbeQCRGC1HwOOR5K/gr30P1NcEG0vx6Kbv2aJU= +github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY= github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -192,6 +247,10 @@ github.com/mssola/useragent v1.0.0 h1:WRlDpXyxHDNfvZaPEut5Biveq86Ze4o4EMffyMxmH5 github.com/mssola/useragent v1.0.0/go.mod h1:hz9Cqz4RXusgg1EdI4Al0INR62kP7aPSRNHnpU+b85Y= github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 h1:C3w9PqII01/Oq1c1nUAm88MOHcQC9l5mIlSMApZMrHA= github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= +github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= +github.com/nats-io/nats.go v1.34.0/go.mod h1:Ubdu4Nh9exXdSz0RVWRFBbRfrbSxOYd26oF0wkWclB8= +github.com/nats-io/nkeys v0.4.7/go.mod h1:kqXRgRDPlGy7nGaEDMuYzmiJCIAAWDK0IMBtDmGD0nc= +github.com/nats-io/nuid v1.0.1/go.mod h1:19wcPz3Ph3q0Jbyiqsd0kePYG7A95tJPxeL+1OSON2c= github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A= github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU= @@ -200,6 +259,7 @@ github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+W github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE= github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU= +github.com/onsi/ginkgo/v2 v2.1.6/go.mod h1:MEH45j8TBi6u9BMogfbp0stKC5cdGjumZj5Y7AG4VIk= github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= @@ -246,6 +306,7 @@ github.com/robfig/cron/v3 v3.0.1/go.mod h1:eQICP3HwyT7UooqI/z+Ov+PtYAWygg1TEWWzG github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M= github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA= github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= +github.com/sagikazarmark/crypt v0.19.0/go.mod h1:c6vimRziqqERhtSe0MhIvzE1w54FrCHtrXb5NH/ja78= github.com/sagikazarmark/locafero v0.6.0 h1:ON7AQg37yzcRPU69mt7gwhFEBwxI6P9T4Qu3N51bwOk= github.com/sagikazarmark/locafero v0.6.0/go.mod h1:77OmuIc6VTraTXKXIs/uvUxKGUXjE1GbemJYHqdNjX0= github.com/sagikazarmark/slog-shim v0.1.0 h1:diDBnUNK9N/354PgrxMywXnAwEr1QZcOr6gto+ugjYE= @@ -258,6 +319,7 @@ github.com/shoenig/go-m1cpu v0.1.6 h1:nxdKQNcEB6vzgA2E2bvzKIYRuNj7XNJ4S/aRSwKzFt github.com/shoenig/go-m1cpu v0.1.6/go.mod h1:1JJMcUBvfNwpq05QDQVAnx3gUHr9IYF7GNg9SUEw2VQ= github.com/shoenig/test v0.6.4 h1:kVTaSd7WLz5WZ2IaoM0RSzRsUD+m8wRR+5qvntpn4LU= github.com/shoenig/test v0.6.4/go.mod h1:byHiCGXqrVaflBLAMq/srcZIHynQPQgeyvkvXnjqq0k= +github.com/shopspring/decimal v1.3.1/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= github.com/sirupsen/logrus v1.4.2 h1:SPIRibHv4MatM3XXNO2BJeFLZwZ2LvZgfQ5+UNI2im4= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= @@ -312,10 +374,12 @@ github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2 github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= github.com/urfave/cli/v2 v2.1.1/go.mod h1:SE9GqnLQmjVa0iPEY0f1w3ygNIYcIJ0OKPMoW2caLfQ= +github.com/urfave/cli/v2 v2.3.0/go.mod h1:LJmUH05zAU44vOAcrfzZQKsZbVcdbOG8rtL3/XcUArI= github.com/vishvananda/netlink v1.1.0 h1:1iyaYNBLmP6L0220aDnYQpo1QEV4t4hJ+xEEhhJH8j0= github.com/vishvananda/netlink v1.1.0/go.mod h1:cTgwzPIzzgDAYoQrMm0EdrjRUBkTqKYppBueQtXaqoE= github.com/vishvananda/netns v0.0.0-20211101163701-50045581ed74 h1:gga7acRE695APm9hlsSMoOoE65U4/TcqNj90mc69Rlg= github.com/vishvananda/netns v0.0.0-20211101163701-50045581ed74/go.mod h1:DD4vA1DwXk04H54A1oHXtwZmA0grkVMdPxx/VGLCah0= +github.com/xhit/go-str2duration/v2 v2.1.0/go.mod h1:ohY8p+0f07DiV6Em5LKB0s2YpLtXVyJfNt1+BlmyAsU= github.com/xuri/efp v0.0.0-20240408161823-9ad904a10d6d h1:llb0neMWDQe87IzJLS4Ci7psK/lVsjIS2otl+1WyRyY= github.com/xuri/efp v0.0.0-20240408161823-9ad904a10d6d/go.mod h1:ybY/Jr0T0GTCnYjKqmdwxyxn2BQf2RcQIIvex5QldPI= github.com/xuri/excelize/v2 v2.9.0 h1:1tgOaEq92IOEumR1/JfYS/eR0KHOCsRv/rYXXh6YJQE= @@ -330,8 +394,21 @@ github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5t github.com/yusufpapurcu/wmi v1.2.3/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0= github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0= github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0= +github.com/ziutek/mymysql v1.5.4/go.mod h1:LMSpPZ6DbqWFxNCHW77HeMg9I646SAhApZ/wKdgO/C0= +go.etcd.io/etcd/api/v3 v3.5.12/go.mod h1:Ot+o0SWSyT6uHhA56al1oCED0JImsRiU9Dc26+C2a+4= +go.etcd.io/etcd/client/pkg/v3 v3.5.12/go.mod h1:seTzl2d9APP8R5Y2hFL3NVlD6qC/dOT+3kvrqPyTas4= +go.etcd.io/etcd/client/v2 v2.305.12/go.mod h1:aQ/yhsxMu+Oht1FOupSr60oBvcS9cKXHrzBpDsPTf9E= +go.etcd.io/etcd/client/v3 v3.5.12/go.mod h1:tSbBCakoWmmddL+BKVAJHa9km+O/E+bumDe9mSbPiqw= +go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.49.0/go.mod h1:Mjt1i1INqiaoZOMGR1RIUJN+i3ChKoFRqzrRQhlkbs0= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0/go.mod h1:p8pYQP+m5XfbZm9fxtSKAbM6oIllS7s2AfxrChvc7iw= +go.opentelemetry.io/otel v1.24.0/go.mod h1:W7b9Ozg4nkF5tWI5zsXkaKKDjdVjpD4oAt9Qi/MArHo= +go.opentelemetry.io/otel/metric v1.24.0/go.mod h1:VYhLe1rFfxuTXLgj4CBiyz+9WYBA8pNGJgDcSFRKBco= +go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= +go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= +go.uber.org/zap v1.21.0/go.mod h1:wjWOCqI0f2ZZrJF/UufIOkiC8ii6tm1iqIsLo76RfJw= golang.org/x/arch v0.9.0 h1:ub9TgUInamJ8mrZIGlBG6/4TqWeMszd4N8lNorbrr6k= golang.org/x/arch v0.9.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= @@ -379,6 +456,7 @@ golang.org/x/net v0.25.0/go.mod h1:JkAGAh7GEvH74S6FOH42FLoXpXbE/aqXSrIQjXgsiwM= golang.org/x/net v0.27.0/go.mod h1:dDi0PyhWNoiUOrAS8uXv/vnScO4wnHQO4mj9fn/RytE= golang.org/x/net v0.33.0 h1:74SYHlV8BIgHIFC/LrYkOGIwL19eTYXQ5wc6TBuO36I= golang.org/x/net v0.33.0/go.mod h1:HXLR5J+9DxmrqMwG9qjGCxZ+zKXxBru04zlTvWlWuN4= +golang.org/x/oauth2 v0.21.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -423,6 +501,7 @@ golang.org/x/sys v0.22.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.29.0 h1:TPYlXGxvx1MGTn2GiZDhnjPA9wZzZeGKHHmKhHYvgaU= golang.org/x/sys v0.29.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/telemetry v0.0.0-20240228155512-f48c80bd79b2/go.mod h1:TeRTkGYfJXctD9OcfyVLyj2J3IxLnKwHJR8f4D8a3YE= +golang.org/x/telemetry v0.0.0-20240521205824-bda55230c457/go.mod h1:pRgIJT+bRLFKnoM1ldnzKoxTIn14Yxz928LQRYYgIN0= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= @@ -465,6 +544,13 @@ golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8T golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= 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-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= +google.golang.org/api v0.171.0/go.mod h1:Hnq5AHm4OTMt2BUVjael2CWZFD6vksJdWCWiUAmjC9o= +google.golang.org/appengine v1.6.8/go.mod h1:1jJ3jBArFh5pcgW8gCtRJnepW8FzD1V44FJffLiz/Ds= +google.golang.org/genproto v0.0.0-20240213162025-012b6fc9bca9/go.mod h1:mqHbVIp48Muh7Ywss/AD6I5kNVKZMmAa/QEW58Gxp2s= +google.golang.org/genproto/googleapis/api v0.0.0-20240311132316-a219d84964c2/go.mod h1:O1cOfN1Cy6QEYr7VxtjOyP5AdAuR0aJ/MYZaaof623Y= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240314234333-6e1732d8331c/go.mod h1:WtryC6hu0hhx87FDGxWCDptyssuo68sk10vYjF+T9fY= +google.golang.org/grpc v1.62.1/go.mod h1:IWTG0VlJLCh1SkC58F7np9ka9mx/WNkjl4PGJaiq+QE= google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= @@ -489,6 +575,7 @@ gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.0/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= @@ -519,6 +606,8 @@ modernc.org/strutil v1.1.3/go.mod h1:MEHNA7PdEnEwLvspRMtWTNnp2nnyvMfkimT1NKNAGbw modernc.org/token v1.0.1 h1:A3qvTqOwexpfZZeyI0FeGPDlSWX5pjZu9hF4lU+EKWg= modernc.org/token v1.0.1/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM= nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= +rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= +sigs.k8s.io/yaml v1.3.0/go.mod h1:GeOyir5tyXNByN85N/dRIT9es5UQNerPYEKK56eTBm8= xorm.io/builder v0.3.13 h1:a3jmiVVL19psGeXx8GIurTp7p0IIgqeDmwhcR6BAOAo= xorm.io/builder v0.3.13/go.mod h1:aUW0S9eb9VCaPohFCH3j7czOx1PMW3i1HrSzbLYGBSE= xorm.io/xorm v1.3.9 h1:TUovzS0ko+IQ1XnNLfs5dqK1cJl1H5uHpWbWqAQ04nU= diff --git a/src/modules/crontask/processor/nbiNRM/amf/schema.go b/src/modules/crontask/processor/nbiNRM/amf/schema.go new file mode 100644 index 00000000..203d5924 --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/amf/schema.go @@ -0,0 +1,57 @@ +package amf + +type ManagedElement struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorName string `json:"vendorName"` + ManagedBy string `json:"managedBy"` + ManagementIpAddress string `json:"managementIpAddress"` + SwVersion string `json:"swVersion"` + PatchInfo string `json:"patchInfo"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` +} + +type AmfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` + AmfGuamiList string `json:"amfGuamiList"` + SnssaiList string `json:"snssaiList"` + MaxUser int `json:"maxUser"` + RelativeCapacity int `json:"relativeCapacity"` + MaxGnbNum int `json:"maxGnbNum"` +} + +type EpRpDynN8Amf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type EpRpDynN11Amf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type EpRpDynN12Amf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type IPResource struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + InterfaceType string `json:"interfaceType"` + LocIpV4AddrList string `json:"locIpV4AddrList"` + LocIpV6AddrList string `json:"locIpV6AddrList"` +} diff --git a/src/modules/crontask/processor/nbiNRM/nbiNRM.go b/src/modules/crontask/processor/nbiNRM/nbiNRM.go new file mode 100644 index 00000000..e948fab8 --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/nbiNRM.go @@ -0,0 +1,125 @@ +package nbiNRM + +import ( + "encoding/json" + "fmt" + "strconv" + "strings" + + "be.ems/lib/log" + "be.ems/src/framework/cron" +) + +const ( + // NBI CM表名 + NbiCmTableName = "nbi_cm" + CmVersion = "v1" // CM版本 +) + +type EventType int + +const ( + ObjectCreationEvent EventType = iota // ObjectCreationEvent 创建事件 + ObjectDeletionEvent // ObjectDeletionEvent 删除事件 + ObjectAttributeValueChangeEvent // ObjectAttributeValueChangeEvent 修改事件 + ObjectUnkownEvent // 未知事件 +) + +func (et EventType) EventTypeEnumString() string { + switch et { + case ObjectCreationEvent: + return "ObjectCreationEvent" + case ObjectDeletionEvent: + return "ObjectDeletionEvent" + case ObjectAttributeValueChangeEvent: + return "ObjectAttributeValueChangeEvent" + default: + return "ObjectUnkownEvent" + } +} + +func (et EventType) EventTypeIntString() string { + return fmt.Sprintf("%d", et) +} + +// ParseCallTag 将字符串转换为 CallTag 枚举类型 +func EventTypeInt(s string) EventType { + if i, err := strconv.Atoi(s); err == nil { + return EventType(i) + } + // 如果转换失败,则按名称匹配(忽略大小写) + switch strings.ToLower(s) { + case "ObjectCreationEvent": + return ObjectCreationEvent + case "ObjectDeletionEvent": + return ObjectDeletionEvent + case "ObjectAttributeValueChangeEvent": + return ObjectAttributeValueChangeEvent + case "": + // 如果字符串为空,则返回未知事件 + return ObjectUnkownEvent + default: + return ObjectUnkownEvent + } +} + +// NbiCm 表结构 +type NbiCm struct { + Id string `json:"id" db:"id PRIMARY KEY"` + NeType string `json:"neType" db:"ne_type"` + NeId string `json:"neId" db:"ne_id"` + CmVersion string `json:"cmVersion" db:"cm_version"` + RmUid string `json:"rmUid" db:"rm_uid"` + EventType EventType `json:"eventType" db:"event_type"` + ObjectType string `json:"objectType" db:"object_type"` + ValueJson string `json:"valueJson" db:"value_json"` + Timestamp string `json:"timestamp" db:"timestamp"` +} + +var NewProcessor = &BarProcessor{ + progress: 0, + count: 0, +} + +// bar 队列任务处理 +type BarProcessor struct { + // 任务进度 + progress int + // 执行次数 + count int +} + +type BarParams struct { + Duration int `json:"duration"` + TableName string `json:"tableName"` + Columns string `json:"columns"` // exported column name of time string + TimeCol string `json:"timeCol"` // time stamp of column name + TimeUnit string `json:"timeUnit"` // timestamp unit: second/micro/milli + Extras string `json:"extras"` // extras condition for where + FilePath string `json:"filePath"` // file path +} + +func (s *BarProcessor) Execute(data any) (any, error) { + s.count++ + + options := data.(cron.JobData) + sysJob := options.SysJob + var params BarParams + + err := json.Unmarshal([]byte(sysJob.TargetParams), ¶ms) + if err != nil { + return nil, err + } + + err = s.SyncAmfNbiCM() + if err != nil { + log.Errorf("SyncAmfNbiCM error: %v", err) + return nil, err + } + + // 返回结果,用于记录执行结果 + return map[string]any{ + "msg": "sucess", + "affected": 1, + }, nil +} diff --git a/src/modules/crontask/processor/nbiNRM/pcf/schema.go b/src/modules/crontask/processor/nbiNRM/pcf/schema.go new file mode 100644 index 00000000..a85536aa --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/pcf/schema.go @@ -0,0 +1,39 @@ +package pcf + +type ManagedElement struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorName string `json:"vendorName"` + ManagedBy string `json:"managedBy"` + ManagementIpAddress string `json:"managementIpAddress"` + SwVersion string `json:"swVersion"` + PatchInfo string `json:"patchInfo"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` +} + +type PcfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` +} + +type UdrFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + MaxSubNbr int `json:"maxSubNbr"` +} + +type IPResource struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + InterfaceType string `json:"interfaceType"` + LocIpV4AddrList string `json:"locIpV4AddrList"` + LocIpV6AddrList string `json:"locIpV6AddrList"` +} diff --git a/src/modules/crontask/processor/nbiNRM/smf/schema.go b/src/modules/crontask/processor/nbiNRM/smf/schema.go new file mode 100644 index 00000000..789225b1 --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/smf/schema.go @@ -0,0 +1,55 @@ +package smf + +type ManagedElement struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorName string `json:"vendorName"` + ManagedBy string `json:"managedBy"` + ManagementIpAddress string `json:"managementIpAddress"` + SwVersion string `json:"swVersion"` + PatchInfo string `json:"patchInfo"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` +} + +type SmfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` + MaxPduSessions int `json:"maxPduSessions"` + MaxQfi int `json:"maxQfi"` + UpfList string `json:"upfList"` +} + +type AddrPool struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AddrType string `json:"addrType"` + IpVersion string `json:"ipVersion"` + AddrSegList string `json:"addrSegList"` +} + +type EpRpDynN7Smf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} +type EpRpDynN10Smf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type IPResource struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + InterfaceType string `json:"interfaceType"` + LocIpV4AddrList string `json:"locIpV4AddrList"` + LocIpV6AddrList string `json:"locIpV6AddrList"` +} diff --git a/src/modules/crontask/processor/nbiNRM/syncAmf.go b/src/modules/crontask/processor/nbiNRM/syncAmf.go new file mode 100644 index 00000000..110ad84c --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/syncAmf.go @@ -0,0 +1,136 @@ +package nbiNRM + +import ( + "encoding/json" + "fmt" + "time" + + "be.ems/lib/dborm" + "be.ems/lib/log" + + "be.ems/src/modules/crontask/processor/nbiNRM/amf" +) + +// SyncAmfNbiCM 从ne_info获取AMF网元并同步数据到nbi_cm表 +func (s *BarProcessor) SyncAmfNbiCM() error { + log.Info("Starting AMF NBI CM synchronization") + + // 从ne_info表获取AMF类型的网元 + var amfNEs []struct { + NeID string `db:"ne_id"` + NeType string `db:"ne_type"` + RmUid string `db:"rm_uid"` + } + + err := dborm.DefaultDB().Table("ne_info"). + Where("ne_type = ? AND status = 1", "AMF"). + Find(&amfNEs).Error + + if err != nil { + log.Errorf("Failed to query AMF network elements: %v", err) + return err + } + + log.Infof("Found %d AMF network elements", len(amfNEs)) + + // 当前时间戳 + now := time.Now() + timestamp := now.Unix() + + // 遍历每个AMF网元,生成对应的NBI CM记录 + for _, ne := range amfNEs { + // 为每个网元生成ManagedElement记录 + managedElement := amf.ManagedElement{ + Id: "ManagedElement=" + ne.NeID, + UserLabel: "AMF-" + ne.NeID, + VendorName: "Vendor", + ManagedBy: "OMC", + ManagementIpAddress: "", // 可以从其他表获取IP地址 + SwVersion: "", // 可以从其他表获取软件版本 + AdministrativeState: "UNLOCKED", + OperationalState: "ENABLED", + } + + // 序列化为JSON + meJSON, err := json.Marshal(managedElement) + if err != nil { + log.Errorf("Failed to marshal ManagedElement for ne_id %s: %v", ne.NeID, err) + continue + } + + // 生成唯一ID + meID := fmt.Sprintf("nbi-cm-%s-me-%d", ne.NeID, timestamp) + + // 插入ManagedElement记录 + nbiCM := NbiCm{ + Id: meID, + NeType: ne.NeType, + NeId: ne.NeID, + CmVersion: CmVersion, + RmUid: ne.RmUid, + EventType: EventTypeInt("ObjectCreationEvent"), + ObjectType: "ManagedElement", + ValueJson: string(meJSON), + Timestamp: fmt.Sprintf("%d", timestamp), + } + + // 插入到数据库 + err = dborm.DefaultDB().Table("nbi_cm").Create(&nbiCM).Error + if err != nil { + log.Errorf("Failed to insert ManagedElement record: %v", err) + continue + } + + // 为每个网元生成AmfFunction记录 + amfFunction := amf.AmfFunction{ + Id: "ManagedElement=" + ne.NeID + ",AmfFunction=1", + UserLabel: "AMF-" + ne.NeID + "-Func", + AdministrativeState: "UNLOCKED", + OperationalState: "ENABLED", + VnfInstanceId: "vnf-" + ne.NeID, + Fqdn: "amf-" + ne.NeID + ".example.com", + SbiServiceList: "Namf_Communication,Namf_EventExposure,Namf_MT,Namf_Location", + AmfGuamiList: "[{\"mcc\":\"460\",\"mnc\":\"01\",\"amfId\":\"" + ne.NeID + "\"}]", + SnssaiList: "[{\"sst\":1,\"sd\":\"010203\"}]", + MaxUser: 1000000, + RelativeCapacity: 30, + MaxGnbNum: 100, + } + + // 序列化为JSON + amfJSON, err := json.Marshal(amfFunction) + if err != nil { + log.Errorf("Failed to marshal AmfFunction for ne_id %s: %v", ne.NeID, err) + continue + } + + // 生成唯一ID + amfID := fmt.Sprintf("nbi-cm-%s-amf-%d", ne.NeID, timestamp) + + // 插入AmfFunction记录 + nbiCM = NbiCm{ + Id: amfID, + NeType: ne.NeType, + NeId: ne.NeID, + CmVersion: "1.0", + RmUid: "OMC-SYSTEM", + EventType: EventTypeInt("ObjectCreationEvent"), + ObjectType: "AmfFunction", + ValueJson: string(amfJSON), + Timestamp: fmt.Sprintf("%d", timestamp), + } + + // 插入到数据库 + err = dborm.DefaultDB().Table("nbi_cm").Create(&nbiCM).Error + if err != nil { + log.Errorf("Failed to insert AmfFunction record: %v", err) + continue + } + + // 可以继续添加其他AMF相关对象,如EpRpDynN8Amf、IPResource等 + // 这里仅展示了基本结构,可根据实际需求扩展 + } + + log.Info("AMF NBI CM synchronization completed") + return nil +} diff --git a/src/modules/crontask/processor/nbiNRM/udm/schema.go b/src/modules/crontask/processor/nbiNRM/udm/schema.go new file mode 100644 index 00000000..36a71fcf --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/udm/schema.go @@ -0,0 +1,53 @@ +package udm + +type ManagedElement struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorName string `json:"vendorName"` + ManagedBy string `json:"managedBy"` + ManagementIpAddress string `json:"managementIpAddress"` + SwVersion string `json:"swVersion"` + PatchInfo string `json:"patchInfo"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` +} + +type UdmFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` +} + +type UdrFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` + MaxNumSupi int `json:"maxNumSupi"` + MaxNumMsisdn int `json:"maxNumMsisdn"` +} + +type AusfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` + SbiServiceList string `json:"sbiServiceList"` +} + +type IPResource struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + InterfaceType string `json:"interfaceType"` + LocIpV4AddrList string `json:"locIpV4AddrList"` + LocIpV6AddrList string `json:"locIpV6AddrList"` +} diff --git a/src/modules/crontask/processor/nbiNRM/upf/schema.go b/src/modules/crontask/processor/nbiNRM/upf/schema.go new file mode 100644 index 00000000..4901246a --- /dev/null +++ b/src/modules/crontask/processor/nbiNRM/upf/schema.go @@ -0,0 +1,156 @@ +package upf + +type ManagedElement struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorName string `json:"vendorName"` + ManagedBy string `json:"managedBy"` + ManagementIpAddress string `json:"managementIpAddress"` + SwVersion string `json:"swVersion"` + PatchInfo string `json:"patchInfo"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` +} + +type InventoryUnitRack struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorUnitFamilyType string `json:"vendorUnitFamilyType"` + VendorUnitTypeNumber string `json:"vendorUnitTypeNumber"` + VendorName string `json:"vendorName"` + SerialNumber string `json:"serialNumber"` + VersionNumber string `json:"versionNumber"` + DateOfManufacture string `json:"dateOfManufacture"` + DateOfLastService string `json:"dateOfLastService"` + ManufacturerData string `json:"manufacturerData"` + RackPosition string `json:"rackPosition"` +} + +type InventoryUnitShelf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorUnitFamilyType string `json:"vendorUnitFamilyType"` + VendorUnitTypeNumber string `json:"vendorUnitTypeNumber"` + VendorName string `json:"vendorName"` + SerialNumber string `json:"serialNumber"` + VersionNumber string `json:"versionNumber"` + DateOfManufacture string `json:"dateOfManufacture"` + DateOfLastService string `json:"dateOfLastService"` + ManufacturerData string `json:"manufacturerData"` + ShelfPosition string `json:"shelfPosition"` +} + +type InventoryUnitPack struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorUnitFamilyType string `json:"vendorUnitFamilyType"` + VendorUnitTypeNumber string `json:"vendorUnitTypeNumber"` + VendorName string `json:"vendorName"` + SerialNumber string `json:"serialNumber"` + VersionNumber string `json:"versionNumber"` + DateOfManufacture string `json:"dateOfManufacture"` + DateOfLastService string `json:"dateOfLastService"` + ManufacturerData string `json:"manufacturerData"` + SlotsOccupied string `json:"slotsOccupied"` +} + +type InventoryUnitHost struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorUnitFamilyType string `json:"vendorUnitFamilyType"` + VendorUnitTypeNumber string `json:"vendorUnitTypeNumber"` + VendorName string `json:"vendorName"` + SerialNumber string `json:"serialNumber"` + VersionNumber string `json:"versionNumber"` + DateOfManufacture string `json:"dateOfManufacture"` + DateOfLastService string `json:"dateOfLastService"` + ManufacturerData string `json:"manufacturerData"` + HostPosition string `json:"hostPosition"` + NumberOfCpu string `json:"numberOfCpu"` + MemSize string `json:"memSize"` + HardDiskSize string `json:"hardDiskSize"` +} + +type InventoryUnitAccessory struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + VendorUnitFamilyType string `json:"vendorUnitFamilyType"` + VendorUnitTypeNumber string `json:"vendorUnitTypeNumber"` + VendorName string `json:"vendorName"` + SerialNumber string `json:"serialNumber"` + VersionNumber string `json:"versionNumber"` + DateOfManufacture string `json:"dateOfManufacture"` + DateOfLastService string `json:"dateOfLastService"` + ManufacturerData string `json:"manufacturerData"` + AccessoryPosition string `json:"accessoryPosition"` + AccessoryType string `json:"accessoryType"` + AddtionalInformation string `json:"addtionalInformation"` +} + +type UpfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + MaxQosFlows string `json:"maxQosFlows"` + MaxThroughput string `json:"maxThroughput"` +} + +type EpRpDynN9Upf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type EpRpDynN3Upf struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + LocIpAddrList string `json:"locIpAddrList"` + FarIpSubnetworkList string `json:"farIpSubnetworkList"` +} + +type AmfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` +} + +type SmfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` +} + +type UdrFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` +} + +type AusfFunction struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + AdministrativeState string `json:"administrativeState"` + OperationalState string `json:"operationalState"` + VnfInstanceId string `json:"vnfInstanceId"` + Fqdn string `json:"fqdn"` +} + +type IPResource struct { + Id string `json:"id"` + UserLabel string `json:"userLabel"` + InterfaceType string `json:"interfaceType"` + LocIpV4AddrList string `json:"locIpV4AddrList"` + LocIpV6AddrList string `json:"locIpV6AddrList"` +} diff --git a/src/modules/crontask/processor/processor.go b/src/modules/crontask/processor/processor.go index 9e41b045..426e43ec 100644 --- a/src/modules/crontask/processor/processor.go +++ b/src/modules/crontask/processor/processor.go @@ -9,6 +9,7 @@ import ( "be.ems/src/modules/crontask/processor/genNeStateAlarm" "be.ems/src/modules/crontask/processor/getStateFromNE" processorMonitorSysResource "be.ems/src/modules/crontask/processor/monitor_sys_resource" + "be.ems/src/modules/crontask/processor/nbiNRM" processorNeConfigBackup "be.ems/src/modules/crontask/processor/ne_config_backup" processorNeDataUDM "be.ems/src/modules/crontask/processor/ne_data_udm" "be.ems/src/modules/crontask/processor/removeFile" @@ -30,4 +31,5 @@ func InitCronQueue() { cron.CreateQueue("genNeStateAlarm", genNeStateAlarm.NewProcessor) cron.CreateQueue("exportTable", exportTable.NewProcessor) cron.CreateQueue("removeFile", removeFile.NewProcessor) + cron.CreateQueue("nbiNRM", nbiNRM.NewProcessor) }