-
Notifications
You must be signed in to change notification settings - Fork 479
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added support for KinesisTimeWindowEvent.
- Loading branch information
1 parent
0e443c1
commit 37d9352
Showing
9 changed files
with
191 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
58 changes: 58 additions & 0 deletions
58
Libraries/src/Amazon.Lambda.KinesisEvents/KinesisTimeWindowEvent.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
namespace Amazon.Lambda.KinesisEvents | ||
{ | ||
using System; | ||
using System.Collections.Generic; | ||
|
||
/// <summary> | ||
/// AWS Kinesis stream event | ||
/// https://docs.aws.amazon.com/lambda/latest/dg/with-kinesis.html#services-kinesis-windows | ||
/// </summary> | ||
public class KinesisTimeWindowEvent : KinesisEvent | ||
{ | ||
/// <summary> | ||
/// Time window for the records in the event. | ||
/// </summary> | ||
public TimeWindow Window { get; set; } | ||
|
||
/// <summary> | ||
/// State being built up to this invoke in the time window. | ||
/// </summary> | ||
public Dictionary<string, string> State { get; set; } | ||
|
||
/// <summary> | ||
/// Shard Id of the records. | ||
/// </summary> | ||
public string ShardId { get; set; } | ||
|
||
/// <summary> | ||
/// Kinesis stream or consumer ARN. | ||
/// </summary> | ||
public string EventSourceARN { get; set; } | ||
|
||
/// <summary> | ||
/// Set to true for the last invoke of the time window. Subsequent invoke will start a new time window along with a fresh state. | ||
/// </summary> | ||
public bool? IsFinalInvokeForWindow { get; set; } | ||
|
||
/// <summary> | ||
/// Set to true if window is terminated prematurely. Subsequent invoke will continue the same window with a fresh state. | ||
/// </summary> | ||
public bool? IsWindowTerminatedEarly { get; set; } | ||
|
||
/// <summary> | ||
/// Kinesis event record. | ||
/// </summary> | ||
public class TimeWindow | ||
{ | ||
/// <summary> | ||
/// Window start instant. | ||
/// </summary> | ||
public DateTime Start { get; set; } | ||
|
||
/// <summary> | ||
/// Window end instant. | ||
/// </summary> | ||
public DateTime End { get; set; } | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
35 changes: 35 additions & 0 deletions
35
...es/src/Amazon.Lambda.Serialization.SystemTextJson/Converters/LongToStringJsonConverter.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
using System; | ||
using System.Buffers; | ||
using System.Buffers.Text; | ||
using System.Text.Json; | ||
using System.Text.Json.Serialization; | ||
|
||
namespace Amazon.Lambda.Serialization.SystemTextJson.Converters | ||
{ | ||
public class LongToStringJsonConverter : JsonConverter<string> | ||
{ | ||
public override string Read(ref Utf8JsonReader reader, Type type, JsonSerializerOptions options) | ||
{ | ||
if (reader.TokenType != JsonTokenType.Number && | ||
type == typeof(String)) | ||
return reader.GetString(); | ||
|
||
var span = reader.HasValueSequence ? reader.ValueSequence.ToArray() : reader.ValueSpan; | ||
|
||
if (Utf8Parser.TryParse(span, out long number, out var bytesConsumed) && span.Length == bytesConsumed) | ||
return number.ToString(); | ||
|
||
var data = reader.GetString(); | ||
|
||
throw new InvalidOperationException($"'{data}' is not a correct expected value!") | ||
{ | ||
Source = "LongToStringJsonConverter" | ||
}; | ||
} | ||
|
||
public override void Write(Utf8JsonWriter writer, string value, JsonSerializerOptions options) | ||
{ | ||
writer.WriteStringValue(value.ToString()); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
32 changes: 32 additions & 0 deletions
32
Libraries/test/EventsTests.Shared/kinesis-timewindow-event.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
{ | ||
"Records": [ | ||
{ | ||
"kinesis": { | ||
"kinesisSchemaVersion": "1.0", | ||
"partitionKey": "1", | ||
"sequenceNumber": "49590338271490256608559692538361571095921575989136588898", | ||
"data": "SGVsbG8sIHRoaXMgaXMgYSB0ZXN0Lg==", | ||
"approximateArrivalTimestamp": 1607497475.000 | ||
}, | ||
"eventSource": "aws:kinesis", | ||
"eventVersion": "1.0", | ||
"eventID": "shardId-000000000006:49590338271490256608559692538361571095921575989136588898", | ||
"eventName": "aws:kinesis:record", | ||
"invokeIdentityArn": "arn:aws:iam::123456789012:role/lambda-kinesis-role", | ||
"awsRegion": "us-east-1", | ||
"eventSourceARN": "arn:aws:kinesis:us-east-1:123456789012:stream/lambda-stream" | ||
} | ||
], | ||
"window": { | ||
"start": "2020-12-09T07:04:00Z", | ||
"end": "2020-12-09T07:06:00Z" | ||
}, | ||
"state": { | ||
"1": 282, | ||
"2": 715 | ||
}, | ||
"shardId": "shardId-000000000006", | ||
"eventSourceARN": "arn:aws:kinesis:us-east-1:123456789012:stream/lambda-stream", | ||
"isFinalInvokeForWindow": false, | ||
"isWindowTerminatedEarly": false | ||
} |