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

Archiving a stream in the same transaction as appending events to it leaves stream events unarchived #2982

Closed
AtomYcX opened this issue Feb 22, 2024 · 5 comments
Labels

Comments

@AtomYcX
Copy link

AtomYcX commented Feb 22, 2024

When a stream fetched using optimistic concurrency via FetchForWriting<T> is archived using IDocumentSession.Events.ArchiveStream() any events that have been appended in the same transaction prior to calling ArchiveStream() remain with is_archived = false in the mt_events table, even though the stream itself is marked as archived in mt_streams.

Reproduction steps:

  1. Fetch a stream using IDocumentSession.Events.FetchForWriting<T>
  2. Append one or more events to the stream using IEventStream<T>.AppendMany
  3. Archive the stream using IDocumentSession.Events.ArchiveStream
  4. Commit the transaction using IDocumentSession.SaveChangesAsync
@jeremydmiller jeremydmiller added this to the 7.0.1 milestone Feb 28, 2024
@Xzelsius
Copy link
Contributor

Xzelsius commented Mar 4, 2024

Isn't this intended?
At least we thought so and use this behavior when we "hard-delete" something.

  1. Append "hard delete" event to stream
  2. Archive the same stream

this results in
"hard delete" event in unarchived state
all affected projections are run
stream itself and all previous events are archived

This allows us to rerun projection that have to delete data for the hard delete event.
But if the hard delete event is archived too, the event would be ignored during rebuilding the projection.

Once a day we cleanup archived streams from the database.

@jeremydmiller
Copy link
Member

@Xzelsius There's a switch on most of the built in projections to utilize archived events in rebuilds. You shouldn't use it willy nilly, but it's there

@jeremydmiller jeremydmiller removed this from the 7.0.1 milestone May 14, 2024
@jeremydmiller
Copy link
Member

@AtomYcX I'm going to address this by adding documentation to the effect that, yes, this is legal. @Xzelsius talked this over with me off to the side, and there is a valid use case for doing this. Maybe there could be a separate action for "archive all new events too"?

But also, what was your use case? Why did you both append and try to archive at the same time?

@tiagomsg
Copy link

tiagomsg commented Nov 4, 2024

Hi @jeremydmiller,

Our use case aligns with what @Xzelsius described above about "hard deleting" a stream.
We have some aggregates that we want to completely remove from projections and from any future rebuilds of those projections. Hence, we were appending a "deleted" event and archiving the stream.

Think the 1st question of #3258 more accurately describes our problem. Happy to close this in favor of it.

@jeremydmiller
Copy link
Member

I think the advent of the Archived event type might make this unnecessary and I just don't want to change the existing behavior if somebody is depending on it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants