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

Add support for overriding created_at timestamps for copy transform workflows #282

Merged
merged 4 commits into from
Nov 27, 2024

Conversation

Johnabell
Copy link
Contributor

We are looking at running a copy-transform on our event stream.

This involves reading all events out of one event store and filtering/transforming them before writing them to a new event store. To support this we would like to maintain the timestamps on the original events in both the events table and the streams table.

This PR make that possible by allowing the caller to override created_at when appending events to the event store.

@Johnabell Johnabell force-pushed the support-created-at-override branch from 002e3e7 to 0bc9bef Compare March 21, 2024 00:14
@Johnabell Johnabell force-pushed the support-created-at-override branch from 0bc9bef to fa9cb36 Compare March 21, 2024 00:25
@Johnabell Johnabell changed the title Add support for overriding created_at timestamps for copy transform type workflows Add support for overriding created_at timestamps for copy transform workflows Mar 21, 2024
Copy link
Contributor

@drteeth drteeth left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Johnabell I see the reason for adding this feature and the code looks reasonable to me.

@@ -527,9 +527,16 @@ defmodule EventStore do
Snapshotter.delete_snapshot(conn, source_uuid, opts)
end

@accepted_overrides [:created_at]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps created_at could be override_created_at to make the intent clear?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you think about created_at_override, just a little concerned that override_created_at might sound more like something that expects a boolean?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have renamed it created_at_override, but happy rename it to your suggestion if you prefer.

lib/event_store.ex Outdated Show resolved Hide resolved
@Johnabell Johnabell requested a review from drteeth September 19, 2024 19:27
@Johnabell Johnabell force-pushed the support-created-at-override branch from d87829f to 705a8e2 Compare September 19, 2024 19:28
@drteeth drteeth requested review from jwilger and cdegroot September 21, 2024 03:09
@@ -24,12 +24,17 @@ WITH
<% end %>
),
stream AS (
<%= if stream_id do %>
<%= cond do %>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This makes stream_id and created_at mutually exclusive. Not sure that that's a good idea?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I couldn't think of a use case for both updating stream_version and the created_at. Do you think there is a reasonable use case for this? I am happy to update this file if you think we should support this.

@drteeth drteeth merged commit 253ae6e into commanded:master Nov 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants