mirror of
https://github.com/harness/drone.git
synced 2025-05-06 12:41:08 +08:00

This Commit adds: - stream package (provides different implementation of stream producers and consumers) + Redis -> will be used for any non-local deployments + InMemory -> a VERY BASIC implementation that is used for local execution - events package + GenericReporter -> responsible for reporting events, can be used to send any type of event and payload + GenericReader -> responsible for reading events from a stream, can be used to register handlers for any type of event and payload + ReaderFactory -> responsible for launching readers for any type of consumer group&name. - webhook package + The wire frame of the webhook package. - gitrpc/events package + defines event Reader/Reporter for events of category git
51 lines
1.6 KiB
Go
51 lines
1.6 KiB
Go
// Copyright 2022 Harness Inc. All rights reserved.
|
|
// Use of this source code is governed by the Polyform Free Trial License
|
|
// that can be found in the LICENSE.md file for this repository.
|
|
|
|
package events
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"encoding/gob"
|
|
"fmt"
|
|
"time"
|
|
)
|
|
|
|
// GenericReporter represents an event reporter that supports sending typesafe messages
|
|
// for an arbitrary set of custom events within an event category using the ReporterSendEvent method.
|
|
// NOTE: Optimally this should be an interface with SendEvent[T] method, but that's not possible in go.
|
|
type GenericReporter struct {
|
|
producer StreamProducer
|
|
category string
|
|
}
|
|
|
|
// ReportEvent reports an event using the provided GenericReporter.
|
|
// Returns the reported event's ID in case of success.
|
|
// NOTE: This call is blocking until the event was send (not until it was processed).
|
|
//
|
|
//nolint:revive // emphasize that this is meant to be an operation on *GenericReporter
|
|
func ReporterSendEvent[T interface{}](reporter *GenericReporter, ctx context.Context,
|
|
eventType EventType, payload T) (string, error) {
|
|
streamID := getStreamID(reporter.category, eventType)
|
|
event := Event[T]{
|
|
ID: "", // will be set by GenericReader
|
|
Timestamp: time.Now(),
|
|
Payload: payload,
|
|
}
|
|
|
|
buff := &bytes.Buffer{}
|
|
encoder := gob.NewEncoder(buff)
|
|
|
|
if err := encoder.Encode(&event); err != nil {
|
|
return "", fmt.Errorf("failed to encode payload: %w", err)
|
|
}
|
|
|
|
streamPayload := map[string]interface{}{
|
|
streamPayloadKey: buff.Bytes(),
|
|
}
|
|
|
|
// We are using the message ID as event ID.
|
|
return reporter.producer.Send(ctx, streamID, streamPayload)
|
|
}
|