Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DocumentDB support #706

Merged
merged 27 commits into from
Oct 19, 2023
Merged
Changes from 1 commit
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
00d166c
insert event draft
morgan1371 Sep 22, 2023
fd9d60f
abstract change event
morgan1371 Sep 23, 2023
c85df32
Added documentdb delete event
EduardoRSO Sep 23, 2023
55bce52
Added support to change event drop
EduardoRSO Sep 26, 2023
04b46b5
Added support to dropDatabase Event
EduardoRSO Oct 2, 2023
d921903
Merge branch 'awslabs:main' into feature/documentdb-insert-support
nichmorgan Oct 3, 2023
3e1a07b
- MongoDB v6.0 Change Event Fields removed
morgan1371 Oct 3, 2023
79370a3
Merge branch 'feature/documentdb-insert-support' into feature/documen…
morgan1371 Oct 3, 2023
9e63dc1
replace event support
nichmorgan Oct 9, 2023
c76c9d8
added support to invalidate event in documentdb
lucabarcelos Oct 9, 2023
2e1d493
Adding DocumentDB Rename event.
ViniciusBrisotti Oct 10, 2023
3c579b1
run cargo fmt
lucabarcelos Oct 10, 2023
1e00076
Excluding 'to' parameter
ViniciusBrisotti Oct 10, 2023
093136c
Add DocumentDB Update event
Kamorst Oct 10, 2023
81333df
fixed 'to' parameter and run cargo fmt
lucabarcelos Oct 11, 2023
d2a50a5
Refactoring 'Rename' event declaration as a single type not a commum …
ViniciusBrisotti Oct 11, 2023
dbc86b0
InsertNs renamed to DatabaseCollection for code reuse
nichmorgan Oct 12, 2023
423f196
unused field removed
nichmorgan Oct 12, 2023
c385aad
cfg fix
nichmorgan Oct 12, 2023
212b4c1
Merge branch 'feature/documentdb-support' into feature/documentdb-upd…
Oct 13, 2023
3b56c7f
Merge branch 'feature/documentdb-support' into feature/documentdb-inv…
Oct 13, 2023
9239d27
Merge branch 'feature/documentdb-support' into origin/feature/documen…
Oct 13, 2023
f81c573
fix lines
nichmorgan Oct 18, 2023
8b03bf3
Merge branch 'main' into feature/documentdb-support
nichmorgan Oct 18, 2023
6900c7c
fmt and makefile fixed
nichmorgan Oct 19, 2023
ddd61ee
Merge branch 'main' into feature/documentdb-support
nichmorgan Oct 19, 2023
26313f5
makefile reord
nichmorgan Oct 19, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add DocumentDB Update event
Kamorst committed Oct 10, 2023
commit 093136c7c46ed2c2fead6cec1311e02e84e8094b
1 change: 1 addition & 0 deletions lambda-events/src/event/documentdb/events/mod.rs
Original file line number Diff line number Diff line change
@@ -3,3 +3,4 @@ pub mod delete_event;
pub mod drop_event;
pub mod insert_event;
pub mod replace_event;
pub mod update_event;
19 changes: 19 additions & 0 deletions lambda-events/src/event/documentdb/events/update_event.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
use serde::{Deserialize, Serialize};

use super::commom_types::{AnyDocument, DocumentId, DocumentKeyId, InsertNs, Timestamp};

#[derive(Clone, Debug, Default, Deserialize, Eq, PartialEq, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct ChangeUpdateEvent {
#[serde(rename = "_id")]
id: DocumentId,
#[serde(default)]
cluster_time: Option<Timestamp>,
document_key: DocumentKeyId,
#[serde(rename = "lsid")]
ls_id: Option<String>,
ns: InsertNs,
// operation_type: String,
#[serde(default)]
txn_number: Option<AnyDocument>,
}
14 changes: 13 additions & 1 deletion lambda-events/src/event/documentdb/mod.rs
Original file line number Diff line number Diff line change
@@ -2,7 +2,7 @@ pub mod events;

use self::events::{
delete_event::ChangeDeleteEvent, drop_event::ChangeDropEvent, insert_event::ChangeInsertEvent,
replace_event::ChangeReplaceEvent,
replace_event::ChangeReplaceEvent, update_event::ChangeUpdateEvent,
};
use serde::{Deserialize, Serialize};

@@ -13,6 +13,7 @@ pub enum ChangeEvent {
Delete(ChangeDeleteEvent),
Drop(ChangeDropEvent),
Replace(ChangeReplaceEvent),
Update(ChangeUpdateEvent),
}

#[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)]
@@ -80,4 +81,15 @@ mod test {

assert_eq!(parsed, reparsed);
}

#[test]
fn example_documentdb_update_event() {
let data = include_bytes!("../../fixtures/example-documentdb-update-event.json");

let parsed: Event = serde_json::from_slice(data).unwrap();
let output: String = serde_json::to_string(&parsed).unwrap();
let reparsed: Event = serde_json::from_slice(output.as_bytes()).unwrap();

assert_eq!(parsed, reparsed);
}
}
29 changes: 29 additions & 0 deletions lambda-events/src/fixtures/example-documentdb-update-event.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
{
"eventSourceArn": "arn:aws:rds:us-east-1:123456789012:cluster:canaryclusterb2a659a2-qo5tcmqkcl03",
"events": [
{
"event": {
"_id": {
"_data": "0163eeb6e7000000090100000009000041e1"
},
"clusterTime": {
"$timestamp": {
"t": 1676588775,
"i": 9
}
},
"documentKey": {
"_id": {
"$oid": "63eeb6e7d418cd98afb1c1d7"
}
},
"ns": {
"db": "test_database",
"coll": "test_collection"
},
"operationType": "update"
}
}
],
"eventSource": "aws:docdb"
}