mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 15:49:34 +00:00 
			
		
		
		
	 32bad3feb3
			
		
	
	32bad3feb3
	
	
		
			
	
		
	
	
		
			Some checks are pending
		
		
	
	ZITADEL CI/CD / core (push) Waiting to run
				ZITADEL CI/CD / console (push) Waiting to run
				ZITADEL CI/CD / version (push) Waiting to run
				ZITADEL CI/CD / compile (push) Blocked by required conditions
				ZITADEL CI/CD / core-unit-test (push) Blocked by required conditions
				ZITADEL CI/CD / core-integration-test (push) Blocked by required conditions
				ZITADEL CI/CD / lint (push) Blocked by required conditions
				ZITADEL CI/CD / container (push) Blocked by required conditions
				ZITADEL CI/CD / e2e (push) Blocked by required conditions
				ZITADEL CI/CD / release (push) Blocked by required conditions
				Code Scanning / CodeQL-Build (go) (push) Waiting to run
				Code Scanning / CodeQL-Build (javascript) (push) Waiting to run
				# Which Problems Are Solved Milestones used existing events from a number of aggregates. OIDC session is one of them. We noticed in load-tests that the reduction of the oidc_session.added event into the milestone projection is a costly business with payload based conditionals. A milestone is reached once, but even then we remain subscribed to the OIDC events. This requires the projections.current_states to be updated continuously. # How the Problems Are Solved The milestone creation is refactored to use dedicated events instead. The command side decides when a milestone is reached and creates the reached event once for each milestone when required. # Additional Changes In order to prevent reached milestones being created twice, a migration script is provided. When the old `projections.milestones` table exist, the state is read from there and `v2` milestone aggregate events are created, with the original reached and pushed dates. # Additional Context - Closes https://github.com/zitadel/zitadel/issues/8800