InvokeAI/invokeai/app/services/session_queue
psychedelicious 084cf26ed6 refactor: remove all session events
There's no longer any need for session-scoped events now that we have the session queue. Session started/completed/canceled map 1-to-1 to queue item status events, but queue item status events also have an event for failed state.

We can simplify queue and processor handling substantially by removing session events and instead using queue item events.

- Remove the session-scoped events entirely.
- Remove all event handling from session queue. The processor still needs to respond to some events from the queue: `QueueClearedEvent`, `BatchEnqueuedEvent` and `QueueItemStatusChangedEvent`.
- Pass an `is_canceled` callback to the invocation context instead of the cancel event
- Update processor logic to ensure the local instance of the current queue item is synced with the instance in the database. This prevents race conditions and ensures lifecycle callback do not get stale callbacks.
- Update docstrings and comments
- Add `complete_queue_item` method to session queue service as an explicit way to mark a queue item as successfully completed. Previously, the queue listened for session complete events to do this.

Closes #6442
2024-05-27 09:06:02 +10:00
..
__init__.py feat: queued generation (#4502) 2023-09-20 15:09:24 +10:00
session_queue_base.py refactor: remove all session events 2024-05-27 09:06:02 +10:00
session_queue_common.py feat(queue): session queue error handling 2024-05-24 20:02:24 +10:00
session_queue_sqlite.py refactor: remove all session events 2024-05-27 09:06:02 +10:00