process

package
v1.11.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 28, 2020 License: AGPL-3.0 Imports: 29 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// The message type key to be used when sending SQS messages. Use it to distinguish
	// the type of the message payload.
	PantherMessageType = "PantherMessageType"
)

Variables

View Source
var CreateTableMessageAttribute = sqs.MessageAttributeValue{
	DataType:    aws.String("String"),
	StringValue: aws.String("CreateTables"),
}

CreateTableMessageAttribute is the SQS message attribute for the CreateTablesMessage.

Functions

func Handle added in v1.11.0

func Handle(ctx context.Context, event *DataCatalogEvent) (err error)

func HandleCreateTablesMessage added in v1.11.0

func HandleCreateTablesMessage(ctx context.Context, msg *CreateTablesMessage) error

func HandleS3Notification added in v1.11.0

func HandleS3Notification(notification S3Notification) error

func HandleSyncEvent added in v1.10.0

func HandleSyncEvent(ctx context.Context, event *SyncEvent) error

HandleSyncEvent handles a full database sync by invoking all required table sync events in the background

func HandleSyncTableEvent added in v1.10.0

func HandleSyncTableEvent(ctx context.Context, event *SyncTableEvent) error

HandleSyncTableEvent starts or continues a gluetasks.SyncTablePartitions task. nolint: nakedret

func InvokeBackgroundSync added in v1.10.0

func InvokeBackgroundSync(ctx context.Context, lambdaAPI lambdaiface.LambdaAPI, event *SyncEvent) (err error)

InvokeBackgroundSync triggers a database sync in the background. The sync is kicked-off using a Lambda call and will be a long running task. This function does not wait for it to finish. If no TraceID is provided this function will try to use the AWS request id.

func Setup

func Setup()

Types

type CreateTablesMessage added in v1.11.0

type CreateTablesMessage struct {
	LogTypes []string
}

CreateTablesMessage is the event that triggers the creation of Glue tables/views for logtypes.

func (CreateTablesMessage) Send added in v1.11.0

func (m CreateTablesMessage) Send(sqsClient sqsiface.SQSAPI, queueURL string) error

type DataCatalogEvent added in v1.10.0

type DataCatalogEvent struct {
	events.SQSEvent
	SyncDatabaseEvent   *SyncEvent
	SyncTablePartitions *SyncTableEvent
}

DataCatalogEvent is the event that this lambda accepts.

type S3Notification added in v1.11.0

S3Notification is sent when new data is available in S3

func NewS3ObjectPutNotification added in v1.11.0

func NewS3ObjectPutNotification(bucket, key string, nbytes int) *S3Notification

type SyncEvent added in v1.5.0

type SyncEvent struct {
	// An identifier to use in order to keep track of all 'child' Lambda invocations for this sync.
	TraceID string
	// Which databases to sync
	DatabaseNames []string
	// Which log types to sync
	LogTypes []string
	// If set to true the sync will only scan for updates and will not modify Glue partitions
	DryRun bool
}

SyncEvent is a request to start a full database sync in the background.

type SyncTableEvent added in v1.10.0

type SyncTableEvent struct {
	// Use a common trace id (the SyncDatabase request id) for all events triggered by a sync event.
	// This is used in all logging done by the SyncTablePartitions task to be able to trace all lambda invocations
	// back to their original SyncDatabase request.
	TraceID string
	// NumCalls keeps track of the number of recursive calls for the specific sync table event.
	// It acts as a guard against infinite recursion.
	NumCalls int
	// NumTimeouts keeps track of how many times the last token was retried because of timeout.
	NumTimeouts int
	// Embed the full sync table partitions task state
	// This allows us to continue the task by recursively calling the lambda.
	// The task carries all status information over
	gluetasks.SyncTablePartitions
}

SyncTableEvent initializes or continues a gluetasks.SyncTablePartitions task

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL