mirror of https://github.com/harness/drone.git
* feat: [CODE-2472]: update wire * feat: [CODE-2472]: update wire * feat: [CODE-2472]: update wire * feat: [CODE-2742]: update comments * Merge branch 'main' into akp/CODE-2472 * feat: [CODE-2472]: naming and comment * Apply suggestion from code review * feat: [CODE-2472]: remove file * feat: [CODE-2472]: Created issue * feat: [CODE-2472]: Review * feat: [CODE-2472]: rebase * feat: [CODE-2679]: Comment status update changes (#2943) * rebase * feat: [CODE-2679]: review * feat: [CODE-2679]: wire changes * feat: [CODE-2679]: Comment status update changes * feat: [CODE-2679]: Comment status update changes * feat: [CODE-2472]: fix minor issues * feat: [CODE-2472]: Update the timestamps * feat: [CODE-2472]: Pullreq comment updated changes * feat: [CODE-2472]: changes * feat: [CODE-2472]: update name to edited * feat: [CODE-2472]: update name to edited * feat: [CODE-2472]: status change comment changes * feat: [CODE-2472]: Text changes only * feat: [CODE-2472]: initial codeBT-10437
parent
0a683e73a9
commit
694e790091
|
@ -22,6 +22,7 @@ import (
|
||||||
"github.com/harness/gitness/app/api/controller"
|
"github.com/harness/gitness/app/api/controller"
|
||||||
"github.com/harness/gitness/app/api/usererror"
|
"github.com/harness/gitness/app/api/usererror"
|
||||||
"github.com/harness/gitness/app/auth"
|
"github.com/harness/gitness/app/auth"
|
||||||
|
events "github.com/harness/gitness/app/events/pullreq"
|
||||||
"github.com/harness/gitness/types"
|
"github.com/harness/gitness/types"
|
||||||
"github.com/harness/gitness/types/enum"
|
"github.com/harness/gitness/types/enum"
|
||||||
|
|
||||||
|
@ -129,5 +130,16 @@ func (c *Controller) CommentStatus(
|
||||||
log.Ctx(ctx).Warn().Err(err).Msg("failed to publish PR changed event")
|
log.Ctx(ctx).Warn().Err(err).Msg("failed to publish PR changed event")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c.eventReporter.CommentStatusUpdated(ctx, &events.CommentStatusUpdatedPayload{
|
||||||
|
Base: events.Base{
|
||||||
|
PullReqID: pr.ID,
|
||||||
|
SourceRepoID: pr.SourceRepoID,
|
||||||
|
TargetRepoID: pr.TargetRepoID,
|
||||||
|
PrincipalID: session.Principal.ID,
|
||||||
|
Number: pr.Number,
|
||||||
|
},
|
||||||
|
ActivityID: act.ID,
|
||||||
|
})
|
||||||
|
|
||||||
return act, nil
|
return act, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
// Copyright 2023 Harness, Inc.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package events
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"github.com/harness/gitness/events"
|
||||||
|
|
||||||
|
"github.com/rs/zerolog/log"
|
||||||
|
)
|
||||||
|
|
||||||
|
const CommentStatusUpdatedEvent events.EventType = "comment-status-updated"
|
||||||
|
|
||||||
|
type CommentStatusUpdatedPayload struct {
|
||||||
|
Base
|
||||||
|
ActivityID int64 `json:"activity_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *Reporter) CommentStatusUpdated(
|
||||||
|
ctx context.Context,
|
||||||
|
payload *CommentStatusUpdatedPayload,
|
||||||
|
) {
|
||||||
|
if payload == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
eventID, err := events.ReporterSendEvent(r.innerReporter, ctx, CommentStatusUpdatedEvent, payload)
|
||||||
|
if err != nil {
|
||||||
|
log.Ctx(ctx).Err(err).Msgf(
|
||||||
|
"failed to send pull request comment status updated event for event id '%s'", eventID)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Ctx(ctx).Debug().Msgf("reported pull request comment status update event with id '%s'", eventID)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *Reader) RegisterCommentStatusUpdated(
|
||||||
|
fn events.HandlerFunc[*CommentStatusUpdatedPayload],
|
||||||
|
opts ...events.HandlerOption,
|
||||||
|
) error {
|
||||||
|
return events.ReaderRegisterEvent(r.innerReader, CommentStatusUpdatedEvent, fn, opts...)
|
||||||
|
}
|
|
@ -363,20 +363,12 @@ func (s *Service) handleEventPullReqComment(
|
||||||
Created: activity.Created,
|
Created: activity.Created,
|
||||||
Updated: activity.Updated,
|
Updated: activity.Updated,
|
||||||
},
|
},
|
||||||
|
CodeCommentInfo: extractCodeCommentInfoIfAvailable(activity),
|
||||||
},
|
},
|
||||||
}, nil
|
}, nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// PullReqCommentUpdatedPayload describes the body of the pullreq comment create trigger.
|
|
||||||
type PullReqCommentUpdatedPayload struct {
|
|
||||||
BaseSegment
|
|
||||||
PullReqSegment
|
|
||||||
PullReqTargetReferenceSegment
|
|
||||||
ReferenceSegment
|
|
||||||
PullReqCommentSegment
|
|
||||||
}
|
|
||||||
|
|
||||||
// handleEventPullReqCommentUpdated handles updated events for pull request comments.
|
// handleEventPullReqCommentUpdated handles updated events for pull request comments.
|
||||||
func (s *Service) handleEventPullReqCommentUpdated(
|
func (s *Service) handleEventPullReqCommentUpdated(
|
||||||
ctx context.Context,
|
ctx context.Context,
|
||||||
|
@ -399,7 +391,7 @@ func (s *Service) handleEventPullReqCommentUpdated(
|
||||||
err,
|
err,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
return &PullReqCommentUpdatedPayload{
|
return &PullReqCommentPayload{
|
||||||
BaseSegment: BaseSegment{
|
BaseSegment: BaseSegment{
|
||||||
Trigger: enum.WebhookTriggerPullReqCommentUpdated,
|
Trigger: enum.WebhookTriggerPullReqCommentUpdated,
|
||||||
Repo: targetRepoInfo,
|
Repo: targetRepoInfo,
|
||||||
|
@ -427,6 +419,7 @@ func (s *Service) handleEventPullReqCommentUpdated(
|
||||||
ParentID: activity.ParentID,
|
ParentID: activity.ParentID,
|
||||||
Created: activity.Created,
|
Created: activity.Created,
|
||||||
Updated: activity.Updated,
|
Updated: activity.Updated,
|
||||||
|
Kind: activity.Kind,
|
||||||
},
|
},
|
||||||
CodeCommentInfo: extractCodeCommentInfoIfAvailable(activity),
|
CodeCommentInfo: extractCodeCommentInfoIfAvailable(activity),
|
||||||
},
|
},
|
||||||
|
@ -555,6 +548,83 @@ func (s *Service) handleEventPullReqUpdated(
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// PullReqActivityStatusUpdatedPayload describes the body of the pullreq comment updated trigger.
|
||||||
|
type PullReqActivityStatusUpdatedPayload struct {
|
||||||
|
BaseSegment
|
||||||
|
PullReqSegment
|
||||||
|
PullReqTargetReferenceSegment
|
||||||
|
ReferenceSegment
|
||||||
|
PullReqCommentSegment
|
||||||
|
PullReqCommentStatusUpdatedSegment
|
||||||
|
}
|
||||||
|
|
||||||
|
// handleEventPullReqCommentUpdated handles status updated events for pull request comments.
|
||||||
|
func (s *Service) handleEventPullReqCommentStatusUpdated(
|
||||||
|
ctx context.Context,
|
||||||
|
event *events.Event[*pullreqevents.CommentStatusUpdatedPayload],
|
||||||
|
) error {
|
||||||
|
return s.triggerForEventWithPullReq(
|
||||||
|
ctx,
|
||||||
|
enum.WebhookTriggerPullReqCommentStatusUpdated,
|
||||||
|
event.ID,
|
||||||
|
event.Payload.PrincipalID,
|
||||||
|
event.Payload.PullReqID,
|
||||||
|
func(principal *types.Principal, pr *types.PullReq, targetRepo, sourceRepo *types.Repository) (any, error) {
|
||||||
|
targetRepoInfo := repositoryInfoFrom(ctx, targetRepo, s.urlProvider)
|
||||||
|
sourceRepoInfo := repositoryInfoFrom(ctx, sourceRepo, s.urlProvider)
|
||||||
|
activity, err := s.activityStore.Find(ctx, event.Payload.ActivityID)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf(
|
||||||
|
"failed to get activity by id for acitivity id %d: %w",
|
||||||
|
event.Payload.ActivityID,
|
||||||
|
err,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
status := enum.PullReqCommentStatusActive
|
||||||
|
if activity.Resolved != nil {
|
||||||
|
status = enum.PullReqCommentStatusResolved
|
||||||
|
}
|
||||||
|
|
||||||
|
return &PullReqActivityStatusUpdatedPayload{
|
||||||
|
BaseSegment: BaseSegment{
|
||||||
|
Trigger: enum.WebhookTriggerPullReqCommentStatusUpdated,
|
||||||
|
Repo: targetRepoInfo,
|
||||||
|
Principal: principalInfoFrom(principal.ToPrincipalInfo()),
|
||||||
|
},
|
||||||
|
PullReqSegment: PullReqSegment{
|
||||||
|
PullReq: pullReqInfoFrom(ctx, pr, targetRepo, s.urlProvider),
|
||||||
|
},
|
||||||
|
PullReqTargetReferenceSegment: PullReqTargetReferenceSegment{
|
||||||
|
TargetRef: ReferenceInfo{
|
||||||
|
Name: gitReferenceNamePrefixBranch + pr.TargetBranch,
|
||||||
|
Repo: targetRepoInfo,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ReferenceSegment: ReferenceSegment{
|
||||||
|
Ref: ReferenceInfo{
|
||||||
|
Name: gitReferenceNamePrefixBranch + pr.SourceBranch,
|
||||||
|
Repo: sourceRepoInfo,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PullReqCommentSegment: PullReqCommentSegment{
|
||||||
|
CommentInfo: CommentInfo{
|
||||||
|
ID: activity.ID,
|
||||||
|
Text: activity.Text,
|
||||||
|
Kind: activity.Kind,
|
||||||
|
ParentID: activity.ParentID,
|
||||||
|
Created: activity.Created,
|
||||||
|
Updated: activity.Updated,
|
||||||
|
},
|
||||||
|
CodeCommentInfo: extractCodeCommentInfoIfAvailable(activity),
|
||||||
|
},
|
||||||
|
PullReqCommentStatusUpdatedSegment: PullReqCommentStatusUpdatedSegment{
|
||||||
|
Status: status,
|
||||||
|
},
|
||||||
|
}, nil
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// PullReqReviewSubmittedPayload describes the body of the pullreq review submitted trigger.
|
// PullReqReviewSubmittedPayload describes the body of the pullreq review submitted trigger.
|
||||||
type PullReqReviewSubmittedPayload struct {
|
type PullReqReviewSubmittedPayload struct {
|
||||||
BaseSegment
|
BaseSegment
|
||||||
|
|
|
@ -200,6 +200,7 @@ func NewService(
|
||||||
_ = r.RegisterUpdated(service.handleEventPullReqUpdated)
|
_ = r.RegisterUpdated(service.handleEventPullReqUpdated)
|
||||||
_ = r.RegisterLabelAssigned(service.handleEventPullReqLabelAssigned)
|
_ = r.RegisterLabelAssigned(service.handleEventPullReqLabelAssigned)
|
||||||
_ = r.RegisterReviewSubmitted(service.handleEventPullReqReviewSubmitted)
|
_ = r.RegisterReviewSubmitted(service.handleEventPullReqReviewSubmitted)
|
||||||
|
_ = r.RegisterCommentStatusUpdated(service.handleEventPullReqCommentStatusUpdated)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
|
|
|
@ -81,10 +81,8 @@ type PullReqCommentSegment struct {
|
||||||
*CodeCommentInfo
|
*CodeCommentInfo
|
||||||
}
|
}
|
||||||
|
|
||||||
// PullReqCommentUpdatedSegment contains details for pullreq text comment edited payloads for webhooks.
|
type PullReqCommentStatusUpdatedSegment struct {
|
||||||
type PullReqCommentUpdatedSegment struct {
|
Status enum.PullReqCommentStatus `json:"status"`
|
||||||
CommentInfo
|
|
||||||
*CodeCommentInfo
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// PullReqLabelSegment contains details for all pull req label related payloads for webhooks.
|
// PullReqLabelSegment contains details for all pull req label related payloads for webhooks.
|
||||||
|
|
|
@ -188,7 +188,6 @@ const (
|
||||||
WebhookTriggerPullReqUpdated WebhookTrigger = "pullreq_updated"
|
WebhookTriggerPullReqUpdated WebhookTrigger = "pullreq_updated"
|
||||||
// WebhookTriggerPullReqLabelAssigned gets triggered when a label is assigned to a pull request.
|
// WebhookTriggerPullReqLabelAssigned gets triggered when a label is assigned to a pull request.
|
||||||
WebhookTriggerPullReqLabelAssigned WebhookTrigger = "pullreq_label_assigned"
|
WebhookTriggerPullReqLabelAssigned WebhookTrigger = "pullreq_label_assigned"
|
||||||
|
|
||||||
// WebhookTriggerPullReqReviewSubmitted gets triggered when a pull request review is submitted.
|
// WebhookTriggerPullReqReviewSubmitted gets triggered when a pull request review is submitted.
|
||||||
WebhookTriggerPullReqReviewSubmitted = "pullreq_review_submitted"
|
WebhookTriggerPullReqReviewSubmitted = "pullreq_review_submitted"
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in New Issue