diff --git a/bots-common/go.mod b/bots-common/go.mod index c8382e4..4784317 100644 --- a/bots-common/go.mod +++ b/bots-common/go.mod @@ -8,11 +8,10 @@ require ( github.com/go-openapi/strfmt v0.23.0 github.com/go-openapi/swag v0.23.0 github.com/go-openapi/validate v0.24.0 - github.com/oapi-codegen/runtime v1.1.1 + github.com/rabbitmq/amqp091-go v1.10.0 ) require ( - github.com/apapsch/go-jsonmerge/v2 v2.0.0 // indirect github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2 // indirect github.com/go-logr/logr v1.4.1 // indirect github.com/go-logr/stdr v1.2.2 // indirect diff --git a/bots-common/go.sum b/bots-common/go.sum index ab90841..43e5142 100644 --- a/bots-common/go.sum +++ b/bots-common/go.sum @@ -1,9 +1,5 @@ -github.com/RaveNoX/go-jsoncommentstrip v1.0.0/go.mod h1:78ihd09MekBnJnxpICcwzCMzGrKSKYe4AqU6PDYYpjk= -github.com/apapsch/go-jsonmerge/v2 v2.0.0 h1:axGnT1gRIfimI7gJifB699GoE/oq+F2MU7Dml6nw9rQ= -github.com/apapsch/go-jsonmerge/v2 v2.0.0/go.mod h1:lvDnEdqiQrp0O42VQGgmlKpxL1AP2+08jFMw88y4klk= github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2 h1:DklsrG3dyBCFEj5IhUbnKptjxatkF07cF2ak3yi77so= github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw= -github.com/bmatcuk/doublestar v1.1.1/go.mod h1:UD6OnuiIn0yFxxA2le/rnRU1G4RaI4UvFv1sNto9p6w= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -38,7 +34,6 @@ 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/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/juju/gnuflag v0.0.0-20171113085948-2ce1bb71843d/go.mod h1:2PavIy+JPciBPrBUjwbNvtwB6RQlve+hkpll6QSNmOE= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= @@ -47,17 +42,16 @@ github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0 github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= 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/oapi-codegen/runtime v1.1.1 h1:EXLHh0DXIJnWhdRPN2w4MXAzFyE4CskzhNLUmtpMYro= -github.com/oapi-codegen/runtime v1.1.1/go.mod h1:SK9X900oXmPWilYR5/WKPzt3Kqxn/uS/+lbpREv+eCg= github.com/oklog/ulid v1.3.1 h1:EGfNDEx6MqHz8B3uNV6QAib1UR2Lm97sHi3ocA6ESJ4= github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs= github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/rabbitmq/amqp091-go v1.10.0 h1:STpn5XsHlHGcecLmMFCtg7mqq0RnD+zFr4uzukfVhBw= +github.com/rabbitmq/amqp091-go v1.10.0/go.mod h1:Hy4jKW5kQART1u+JkDTF9YYOQUHXqMuhrgxOEeS7G4o= github.com/rogpeppe/go-internal v1.12.0 h1:exVL4IDcn6na9z1rAb56Vxr+CgyK3nn3O+epU5NdKM8= github.com/rogpeppe/go-internal v1.12.0/go.mod h1:E+RYuTGaKKdloAfM02xzb0FW3Paa99yedzYV+kq4uf4= -github.com/spkg/bom v0.0.0-20160624110644-59b7046e48ad/go.mod h1:qLr4V1qq6nMqFKkMo8ZTx3f+BZEkzsRUY10Xsm2mwU0= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= @@ -72,6 +66,8 @@ go.opentelemetry.io/otel/sdk v1.24.0 h1:YMPPDNymmQN3ZgczicBY3B6sf9n62Dlj9pWD3ucg go.opentelemetry.io/otel/sdk v1.24.0/go.mod h1:KVrIYw6tEubO9E96HQpcmpTKDVn9gdv35HoYiQWGDFg= go.opentelemetry.io/otel/trace v1.24.0 h1:CsKnnL4dUAr/0llH9FKuc698G04IrpWV0MQA/Y1YELI= go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= +go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= +go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M= golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.20.0 h1:Od9JTbYCk261bKm4M/mw7AklTlFYIa0bIp9BgSm1S8Y= diff --git a/bots-common/listen.go b/bots-common/listen.go index 9a1f42d..363f133 100644 --- a/bots-common/listen.go +++ b/bots-common/listen.go @@ -1,9 +1,16 @@ package common import ( + "crypto/tls" + "fmt" "log" + "maps" "net/http" "net/url" + "strings" + "time" + + rabbitmq "github.com/rabbitmq/amqp091-go" ) const RequestType_CreateBrachTag = "create" @@ -31,8 +38,168 @@ const RequestType_Wiki = "wiki" type RequestProcessor func(*RequestHandler) error type ListenDefinitions struct { - GitAuthor, Url string - Handlers map[string]RequestProcessor + RabbitURL string // amqps://user:password@host/queue + + GitAuthor string + Handlers map[string]RequestProcessor +} + +type RabbitMessage rabbitmq.Delivery + +func processRabbitMQ(msgCh chan<- RabbitMessage, server url.URL, topics []string) error { + queueName := server.Path + server.Path = "" + + if queueName[0] == '/' { + queueName = queueName[1:] + } + + connection, err := rabbitmq.DialTLS(server.String(), &tls.Config{ + ServerName: server.Hostname(), + }) + if err != nil { + return fmt.Errorf("Cannot connect to %s . Err: %w", server.Hostname(), err) + } + defer connection.Close() + + ch, err := connection.Channel() + if err != nil { + return fmt.Errorf("Cannot create a channel. Err: %w", err) + } + defer ch.Close() + + if err = ch.ExchangeDeclarePassive("pubsub", "topic", true, false, false, false, nil); err != nil { + return fmt.Errorf("Cannot find pubsub exchange? Err: %w", err) + } + + var q rabbitmq.Queue + if len(queueName) == 0 { + q, err = ch.QueueDeclare("", false, true, true, false, nil) + } else { + q, err = ch.QueueDeclarePassive(queueName, true, false, true, false, nil) + if err != nil { + log.Printf("queue not found .. trying to create it: %v\n", err) + if ch.IsClosed() { + ch, err = connection.Channel() + if err != nil { + return fmt.Errorf("Channel cannot be re-opened. Err: %w", err) + } + } + q, err = ch.QueueDeclare(queueName, true, false, true, false, nil) + + if err != nil { + log.Printf("can't create persistent queue ... falling back to temporaty queue: %v\n", err) + if ch.IsClosed() { + ch, err = connection.Channel() + return fmt.Errorf("Channel cannot be re-opened. Err: %w", err) + } + q, err = ch.QueueDeclare("", false, true, true, false, nil) + } + } + } + if err != nil { + return fmt.Errorf("Cannot declare queue. Err: %w", err) + } + // log.Printf("queue: %s:%d", q.Name, q.Consumers) + + for _, topic := range topics { + err = ch.QueueBind(q.Name, topic, "pubsub", false, nil) + if err != nil { + return fmt.Errorf("Cannot find queue to exchange with topic %s. Err: %w", topic, err) + } + } + + msgs, err := ch.Consume(q.Name, "", true, true, false, false, nil) + if err != nil { + return fmt.Errorf("Cannot start consumer. Err: %w", err) + } + // log.Printf("queue: %s:%d", q.Name, q.Consumers) + + for { + msg, ok := <-msgs + if !ok { + return fmt.Errorf("channel/connection closed?\n") + } + + msgCh <- RabbitMessage(msg) + } +} + +func connectAndProcessRabbitMQ(log *log.Logger, ch chan<- RabbitMessage, server url.URL, topics []string) { + defer func() { + if r := recover(); r != nil { + log.Println("'crash' RabbitMQ worker. Recovering... reconnecting...") + time.Sleep(5 * time.Second) + go connectAndProcessRabbitMQ(log, ch, server, topics) + } + }() + + for { + err := processRabbitMQ(ch, server, topics) + if err != nil { + log.Printf("Error in RabbitMQ connection. %#v", err) + log.Println("Reconnecting in 2 seconds...") + time.Sleep(2 * time.Second) + } + } +} + +func ConnectToRabbitMQ(log *log.Logger, server url.URL, topics []string) chan RabbitMessage { + ch := make(chan RabbitMessage, 100) + go connectAndProcessRabbitMQ(log, ch, server, topics) + + return ch +} + +func ProcessRabbitMQEvents(listenDefs ListenDefinitions) { + server, err := url.Parse(listenDefs.RabbitURL) + if err != nil { + log.Panicf("cannot parse server URL. Err: %#v", err) + } + + topics := make([]string, 0, len(listenDefs.Handlers)) + for k := range listenDefs.Handlers { + topics = append(topics, fmt.Sprintf("*.gitea.%s#", k)) + } + + ch := ConnectToRabbitMQ(log.Default(), *server, topics) + + for { + msg, ok := <-ch + if !ok { + return + } + + route := strings.Split(msg.RoutingKey, ".") + if len(route > 3) { + if handler, found := listenDefs.Handlers[route[2]]; found { + switch route[2] { + case RequestType_CreateBrachTag, RequestType_DeleteBranchTag: + case RequestType_Fork: + case RequestType_Issue: + case RequestType_IssueAssign: + case RequestType_IssueComment: + case RequestType_IssueLabel: + case RequestType_IssueMilestone: + case RequestType_Push: + case RequestType_Repository: + case RequestType_Release: + case RequestType_PR: + case RequestType_PRAssign: + case RequestType_PRLabel: + case RequestType_PRComment: + case RequestType_PRMilestone: + case RequestType_PRSync: + case RequestType_PRReviewAccepted: + case RequestType_PRReviewRejected: + case RequestType_PRReviewRequest: + case RequestType_Wiki: + + } + handler + } + } + } } func StartServer(listenDefs ListenDefinitions, config []*AutogitConfig) { @@ -47,15 +214,6 @@ func StartServerWithAddress(listenDefs ListenDefinitions, addr string) { h := CreateRequestHandler(listenDefs.GitAuthor, listenDefs.Url) defer h.Close() - if len(req.Header.Get("Content-Type")) == 0 || - req.Header["Content-Type"][0] != "application/json" || - req.Method != "POST" { - - h.WriteError() - res.WriteHeader(http.StatusInternalServerError) - return - } - hdr := req.Header[GiteaRequestHeader] if len(hdr) != 1 { h.ErrLogger.Printf("Unsupported number of %s headers: %d: %#v\n", GiteaRequestHeader, len(hdr), hdr) diff --git a/bots-common/request_handler.go b/bots-common/request_handler.go index d18e64f..386cb12 100644 --- a/bots-common/request_handler.go +++ b/bots-common/request_handler.go @@ -1,11 +1,12 @@ package common import ( + "encoding/json" + "fmt" "log" "os" ) - type Request struct { Type string Data interface{} @@ -13,20 +14,153 @@ type Request struct { PrjGit string } -type RequestHandler struct { - Error error - GitCommiter, GitPath string - Branch []string +func ParseRequestJSON(reqType string, data []byte) (interface{}, error) { + switch reqType { + case RequestType_CreateBrachTag, RequestType_DeleteBranchTag: + create := CreateWebhookEvent{} + if err := json.Unmarshal(data, &create); err != nil { + return nil, err + } + return create, nil - StdLogger, ErrLogger *log.Logger - Request + case RequestType_Fork: + fork := ForkWebhookEvent{} + if err := json.Unmarshal(data, &fork); err != nil { + return nil, err + } + return fork, nil + + case RequestType_Push: + push := PushRequest{} + if err := json.Unmarshal(data, &push); err != nil { + return nil, err + } + return push, nil + + case RequestType_Repository: + repoAction := RepositoryAction{} + if err := json.Unmarshal(data, &repoAction); err != nil { + return nil, err + } + return repoAction, nil + + case RequestType_Release: + release := ReleaseWebhookEvent{} + if err := json.Unmarshal(data, &release); err != nil { + return nil, err + } + return release, nil + + case RequestType_Issue: + issue := IssueWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_IssueAssign: + issue := IssueWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_IssueComment, RequestType_PRComment: + issue := IssueCommentWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_IssueLabel: + issue := IssueWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_IssueMilestone: + issue := IssueWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_PR: + pr := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &pr); err != nil { + return nil, err + } + return pr, nil + + case RequestType_PRLabel: + pr := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &pr); err != nil { + return nil, err + } + return pr, nil + + case RequestType_PRMilestone: + pr := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &pr); err != nil { + return nil, err + } + return pr, nil + + case RequestType_PRAssign: + issue := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_PRReviewRequest: + issue := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &issue); err != nil { + return nil, err + } + return issue, nil + + case RequestType_PRReviewAccepted, RequestType_PRReviewRejected: + pr := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &pr); err != nil { + return nil, err + } + return pr, nil + + case RequestType_PRSync: + pr := PullRequestWebhookEvent{} + if err := json.Unmarshal(data, &pr); err != nil { + return nil, err + } + return pr, nil + + case RequestType_Wiki: + wiki := WikiWebhookEvent{} + if err := json.Unmarshal(data, &wiki); err != nil { + return nil, err + } + return wiki, nil + } + + return nil, fmt.Errorf("Unknown webhook request type: %s", reqType) +} + + +type RequestHandler struct { + Error error + GitCommiter string + GitPath string + Branch []string + + StdLogger, ErrLogger *log.Logger + Request Request } func (r *RequestHandler) WriteError() { r.ErrLogger.Println("internal error sent") } - func CreateRequestHandler(git_author, name string) *RequestHandler { var h *RequestHandler = new(RequestHandler) @@ -45,4 +179,3 @@ func CreateRequestHandler(git_author, name string) *RequestHandler { } return h } - diff --git a/gitea-events-rabbitmq-publisher/main.go b/gitea-events-rabbitmq-publisher/main.go index c0a8e45..31c21ce 100644 --- a/gitea-events-rabbitmq-publisher/main.go +++ b/gitea-events-rabbitmq-publisher/main.go @@ -42,7 +42,7 @@ func dumpUnhandledData(reqType string, data []byte) { } } -func parseRequestJSON(reqType string, data []byte) (org *common.Organization, extraAction string, err error) { +func parseRequestJSONOrg(reqType string, data []byte) (org *common.Organization, extraAction string, err error) { extraAction = "" switch reqType { @@ -353,7 +353,7 @@ func main() { res.WriteHeader(http.StatusBadRequest) } - org, extraAction, err := parseRequestJSON(reqType, data) + org, extraAction, err := parseRequestJSONOrg(reqType, data) if err != nil { res.WriteHeader(http.StatusBadRequest) log.Printf("error parsing webhook %s JSON. err: %v", reqType, err) diff --git a/obs-staging-bot/rabbitmq.go b/obs-staging-bot/rabbitmq.go index ea7ac81..2f035f1 100644 --- a/obs-staging-bot/rabbitmq.go +++ b/obs-staging-bot/rabbitmq.go @@ -8,7 +8,6 @@ import ( "sync" "time" - _ "github.com/mattn/go-sqlite3" rabbitmq "github.com/rabbitmq/amqp091-go" "src.opensuse.org/autogits/common" "src.opensuse.org/autogits/common/gitea-generated/models" @@ -95,13 +94,6 @@ func processObsMessage(msg *rabbitmq.Delivery) { } func ProcessingObsMessages(host, username, password, queueName string) { - defer func() { - if r := recover(); r != nil { - log.Print("recovering... reconnecting...\n") - time.Sleep(5 * time.Second) - go ProcessingObsMessages(host, username, password, queueName) - } - }() if obsNotifications == nil { obsNotifications = make(map[string]*BuildNotification) diff --git a/pr-review/README.md b/pr-review/README.md index a8f7b3b..9f34a6c 100644 --- a/pr-review/README.md +++ b/pr-review/README.md @@ -9,8 +9,9 @@ Areas of Responsibility * Detects a PackageGit PR creation against a package and creates a coresponsing PR against the ProjectGit * When a PackageGit PR is updated, the corresponding PR against the ProjectGit is updated -* Stores reference to the PackageGit PR in the headers of the ProjectGit PR, for later reference +* Stores reference to the PackageGit PR in the headers of the ProjectGit PR comments, for later reference * this allows ProjectGit PR to be merged to seperated later (via another tool, for example) +* Initiates all staging workflows via review requests Target Usage diff --git a/prjgit-updater/go.mod b/prjgit-updater/go.mod index 848013e..c1b4925 100644 --- a/prjgit-updater/go.mod +++ b/prjgit-updater/go.mod @@ -7,7 +7,6 @@ replace src.opensuse.org/autogits/common => ../bots-common require src.opensuse.org/autogits/common v0.0.0-00010101000000-000000000000 require ( - github.com/apapsch/go-jsonmerge/v2 v2.0.0 // indirect github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2 // indirect github.com/go-logr/logr v1.4.1 // indirect github.com/go-logr/stdr v1.2.2 // indirect @@ -25,9 +24,9 @@ require ( github.com/josharian/intern v1.0.0 // indirect github.com/mailru/easyjson v0.7.7 // indirect github.com/mitchellh/mapstructure v1.5.0 // indirect - github.com/oapi-codegen/runtime v1.1.1 // indirect github.com/oklog/ulid v1.3.1 // indirect github.com/opentracing/opentracing-go v1.2.0 // indirect + github.com/rabbitmq/amqp091-go v1.10.0 // indirect go.mongodb.org/mongo-driver v1.14.0 // indirect go.opentelemetry.io/otel v1.24.0 // indirect go.opentelemetry.io/otel/metric v1.24.0 // indirect diff --git a/prjgit-updater/go.sum b/prjgit-updater/go.sum index ab90841..43e5142 100644 --- a/prjgit-updater/go.sum +++ b/prjgit-updater/go.sum @@ -1,9 +1,5 @@ -github.com/RaveNoX/go-jsoncommentstrip v1.0.0/go.mod h1:78ihd09MekBnJnxpICcwzCMzGrKSKYe4AqU6PDYYpjk= -github.com/apapsch/go-jsonmerge/v2 v2.0.0 h1:axGnT1gRIfimI7gJifB699GoE/oq+F2MU7Dml6nw9rQ= -github.com/apapsch/go-jsonmerge/v2 v2.0.0/go.mod h1:lvDnEdqiQrp0O42VQGgmlKpxL1AP2+08jFMw88y4klk= github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2 h1:DklsrG3dyBCFEj5IhUbnKptjxatkF07cF2ak3yi77so= github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw= -github.com/bmatcuk/doublestar v1.1.1/go.mod h1:UD6OnuiIn0yFxxA2le/rnRU1G4RaI4UvFv1sNto9p6w= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -38,7 +34,6 @@ 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/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/juju/gnuflag v0.0.0-20171113085948-2ce1bb71843d/go.mod h1:2PavIy+JPciBPrBUjwbNvtwB6RQlve+hkpll6QSNmOE= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= @@ -47,17 +42,16 @@ github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0 github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= 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/oapi-codegen/runtime v1.1.1 h1:EXLHh0DXIJnWhdRPN2w4MXAzFyE4CskzhNLUmtpMYro= -github.com/oapi-codegen/runtime v1.1.1/go.mod h1:SK9X900oXmPWilYR5/WKPzt3Kqxn/uS/+lbpREv+eCg= github.com/oklog/ulid v1.3.1 h1:EGfNDEx6MqHz8B3uNV6QAib1UR2Lm97sHi3ocA6ESJ4= github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs= github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/rabbitmq/amqp091-go v1.10.0 h1:STpn5XsHlHGcecLmMFCtg7mqq0RnD+zFr4uzukfVhBw= +github.com/rabbitmq/amqp091-go v1.10.0/go.mod h1:Hy4jKW5kQART1u+JkDTF9YYOQUHXqMuhrgxOEeS7G4o= github.com/rogpeppe/go-internal v1.12.0 h1:exVL4IDcn6na9z1rAb56Vxr+CgyK3nn3O+epU5NdKM8= github.com/rogpeppe/go-internal v1.12.0/go.mod h1:E+RYuTGaKKdloAfM02xzb0FW3Paa99yedzYV+kq4uf4= -github.com/spkg/bom v0.0.0-20160624110644-59b7046e48ad/go.mod h1:qLr4V1qq6nMqFKkMo8ZTx3f+BZEkzsRUY10Xsm2mwU0= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= @@ -72,6 +66,8 @@ go.opentelemetry.io/otel/sdk v1.24.0 h1:YMPPDNymmQN3ZgczicBY3B6sf9n62Dlj9pWD3ucg go.opentelemetry.io/otel/sdk v1.24.0/go.mod h1:KVrIYw6tEubO9E96HQpcmpTKDVn9gdv35HoYiQWGDFg= go.opentelemetry.io/otel/trace v1.24.0 h1:CsKnnL4dUAr/0llH9FKuc698G04IrpWV0MQA/Y1YELI= go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= +go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= +go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M= golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.20.0 h1:Od9JTbYCk261bKm4M/mw7AklTlFYIa0bIp9BgSm1S8Y=