gnieto 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							7565588be7 
							
						 
					 
					
						
						
							
							signatures: Prevent accepting events without at least one valid signature  
						
						... 
						
						
						
						`verify_event` has been changed recently to be more aligned with the
spec. In the previous algorithm, it returned an error if the event was
not signed by at least one of the required entities.
The new algortihm is iterating over all the signtures for the required
entities *and* skipping unknown algorithms. If an event is signed only
by unkonwn algorithms, the event would be accepted and not verifications
will happen. In order to prevent that, we check that, at least, a single
key is checked. This covers the 2nd point in: https://spec.matrix.org/v1.6/appendices/#checking-for-a-signature 
A few more test cases were added:
- The event is properly signed, but key map contains a key with an
  unknown algorithm. Under this circumstances, the event should be
  allowed.
- An event signed by multiple keys for an entity, should verify all
  those signatures
- An event signed by a single key with an unkown algorithm by the
  required entity, should fail 
						
						
					 
					
						2023-03-02 09:34:57 +00:00 
						 
				 
			
				
					
						
							
							
								Jason Volk 
							
						 
					 
					
						
						
						
						
							
						
						
							87237bf100 
							
						 
					 
					
						
						
							
							signatures: Comply with the specified signature checking algorithm.  
						
						... 
						
						
						
						Based on research https://github.com/ruma/ruma/pull/1491#issuecomment-1445042510  by @zecakeh 
						
						
					 
					
						2023-03-01 22:25:06 +01:00 
						 
				 
			
				
					
						
							
							
								Jason Volk 
							
						 
					 
					
						
						
						
						
							
						
						
							920a412da1 
							
						 
					 
					
						
						
							
							signatures: Skip keys which don't split so other keys can be used instead.  
						
						
						
						
					 
					
						2023-03-01 22:25:06 +01:00 
						 
				 
			
				
					
						
							
							
								Jason Volk 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							bcb97b139d 
							
						 
					 
					
						
						
							
							signatures: Allow additional key version-string characters in compat mode  
						
						... 
						
						
						
						This complies with the published specification by default, with optional compatibility for additional federation keys in use.
Co-authored-by: Jonathan de Jong <jonathan@automatia.nl> 
						
						
					 
					
						2023-03-01 09:54:38 +01:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							8f74ec4b1a 
							
						 
					 
					
						
						
							
							Release ruma-signatures 0.13.1  
						
						
						
						
					 
					
						2023-02-15 13:08:31 +01:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
						
						
							
						
						
							f159776f52 
							
						 
					 
					
						
						
							
							chore: Make all applicable spec links use the latest spec instead of a specific version  
						
						
						
						
					 
					
						2023-02-12 12:39:24 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							0d689f0a76 
							
						 
					 
					
						
						
							
							Release ruma-signatures 0.13.0  
						
						
						
						
					 
					
						2023-02-01 14:14:16 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							b6f0a43fa3 
							
						 
					 
					
						
						
							
							Use workspace dependencies for path dependencies  
						
						
						
						
					 
					
						2023-02-01 12:37:45 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							fe5077b1a5 
							
						 
					 
					
						
						
							
							Upgrade base64 to 0.21  
						
						
						
						
					 
					
						2023-01-31 18:01:01 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							78ef5270ba 
							
						 
					 
					
						
						
							
							Upgrade dependencies  
						
						
						
						
					 
					
						2023-01-03 11:28:47 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							536341ca7e 
							
						 
					 
					
						
						
							
							Upgrade base64 to 0.20  
						
						
						
						
					 
					
						2022-12-20 15:34:50 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							284b797e05 
							
						 
					 
					
						
						
							
							Add optional redacted_because insertion to redaction  
						
						
						
						
					 
					
						2022-12-19 12:52:15 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							ba9634f5bf 
							
						 
					 
					
						
						
							
							Update redact to take ownership of the event to be redacted  
						
						
						
						
					 
					
						2022-12-19 10:42:27 +01:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							d18bea570c 
							
						 
					 
					
						
						
							
							Use Cargo workspace dependencies  
						
						... 
						
						
						
						… for most external dependencies that are used from multiple workspace
crates. 
						
						
					 
					
						2022-11-01 11:13:21 +01:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
						
						
							
						
						
							045861441a 
							
						 
					 
					
						
						
							
							doc: Update Matrix spec links to v1.4  
						
						
						
						
					 
					
						2022-10-21 10:41:20 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							3c3c6f388f 
							
						 
					 
					
						
						
							
							Merge branch 'ruma-0.7'  
						
						
						
						
					 
					
						2022-10-18 09:14:16 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							67b2ec7d34 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.5  
						
						
						
						
					 
					
						2022-10-18 09:09:59 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							6ec7fc09ea 
							
						 
					 
					
						
						
							
							Merge branch 'ruma-0.7'  
						
						
						
						
					 
					
						2022-10-17 18:05:42 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							83d60d1fab 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.4  
						
						
						
						
					 
					
						2022-10-17 17:27:27 +02:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
						
						
							
						
						
							b538234bce 
							
						 
					 
					
						
						
							
							chore: Fix new docs warnings  
						
						
						
						
					 
					
						2022-10-12 10:31:23 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							d38fa052e2 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.3  
						
						
						
						
					 
					
						2022-09-16 12:13:19 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							4d192ff3dc 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.2  
						
						
						
						
					 
					
						2022-09-16 11:55:56 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							8460189668 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.1  
						
						
						
						
					 
					
						2022-09-14 21:28:23 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							0047b1d19b 
							
						 
					 
					
						
						
							
							Release ruma-signatures 0.12.0  
						
						
						
						
					 
					
						2022-09-12 21:08:31 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							69aa77ca5f 
							
						 
					 
					
						
						
							
							Release ruma-common 0.10.0  
						
						
						
						
					 
					
						2022-09-12 20:26:06 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							c745d3baf7 
							
						 
					 
					
						
						
							
							Fix clippy lint  
						
						
						
						
					 
					
						2022-09-02 14:07:28 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							4db337b86a 
							
						 
					 
					
						
						
							
							Consistently use dep: syntax for feature > package dependencies  
						
						... 
						
						
						
						This removes confusing implicit features from optional dependencies. 
						
						
					 
					
						2022-08-01 15:46:20 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							6b04b6c567 
							
						 
					 
					
						
						
							
							signatures: Silence unreachable lint with unstable-exhaustive-patterns  
						
						
						
						
					 
					
						2022-06-29 10:50:25 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							08002e2640 
							
						 
					 
					
						
						
							
							Fix unstable-msc2870  
						
						
						
						
					 
					
						2022-06-29 10:31:25 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							33e1a20c4b 
							
						 
					 
					
						
						
							
							signatures: Remove unused compat feature  
						
						
						
						
					 
					
						2022-06-23 12:43:53 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							a4a95e74fa 
							
						 
					 
					
						
						
							
							Address review feedback and finish canonical JSON move  
						
						
						
						
					 
					
						2022-06-23 10:18:26 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							940450b953 
							
						 
					 
					
						
						
							
							[WIP] Move redaction from ruma-signatures to ruma-common  
						
						
						
						
					 
					
						2022-06-23 10:18:26 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							402b2764fb 
							
						 
					 
					
						
						
							
							common: Move CanonicalJson out of serde mod and behind a Cargo feature  
						
						
						
						
					 
					
						2022-06-23 10:18:26 +02:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
						
						
							
						
						
							3deae8eac7 
							
						 
					 
					
						
						
							
							identifiers: Add MatrixVersionId::V10  
						
						... 
						
						
						
						According to MSC3604 
						
						
					 
					
						2022-06-21 13:38:34 +02:00 
						 
				 
			
				
					
						
							
							
								Kévin Commaille 
							
						 
					 
					
						
						
						
						
							
						
						
							75cf634413 
							
						 
					 
					
						
						
							
							signatures: Make some test assertions more helpful  
						
						
						
						
					 
					
						2022-06-14 10:01:49 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							8912182c56 
							
						 
					 
					
						
						
							
							Increase usage of implicit named arguments in format strings  
						
						
						
						
					 
					
						2022-06-03 10:06:28 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							73c2963ebd 
							
						 
					 
					
						
						
							
							Enforce consistent semicolons after ()-typed expressions in blocks  
						
						
						
						
					 
					
						2022-06-03 08:40:16 +02:00 
						 
				 
			
				
					
						
							
							
								Jonathan de Jong 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							49663f4adf 
							
						 
					 
					
						
						
							
							signatures: Update pkcs8, and add ring backwards compatibility  
						
						
						
						
					 
					
						2022-05-30 14:43:21 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							e1ebff0047 
							
						 
					 
					
						
						
							
							Set rust-version for crates/* (excl. ruma-signatures)  
						
						
						
						
					 
					
						2022-05-27 12:05:41 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							5f902851af 
							
						 
					 
					
						
						
							
							Upgrade to Rust 2021  
						
						
						
						
					 
					
						2022-05-27 12:04:23 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							2257b4daf9 
							
						 
					 
					
						
						
							
							Derive Eq for types where it makes sense  
						
						
						
						
					 
					
						2022-05-23 18:40:34 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							6805f67d75 
							
						 
					 
					
						
						
							
							signatures: Remove PartialEq impl for Ed25519Verifier  
						
						
						
						
					 
					
						2022-05-23 18:30:32 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							e1c35b3d7f 
							
						 
					 
					
						
						
							
							Release ruma-common 0.9.2  
						
						
						
						
					 
					
						2022-05-09 12:51:17 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							a36da216ec 
							
						 
					 
					
						
						
							
							Release ruma-common 0.9.1  
						
						
						
						
					 
					
						2022-05-06 17:19:57 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							94545fd52c 
							
						 
					 
					
						
						
							
							Release ruma-signatures 0.11.0  
						
						
						
						
					 
					
						2022-04-28 17:51:22 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							4e8d88617d 
							
						 
					 
					
						
						
							
							Release ruma-common 0.9.0  
						
						
						
						
					 
					
						2022-04-28 16:38:08 +02:00 
						 
				 
			
				
					
						
							
							
								Jonathan de Jong 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							cc72ddb689 
							
						 
					 
					
						
						
							
							Implement MSC2870 (Protect server ACLs from redaction)  
						
						
						
						
					 
					
						2022-04-27 10:22:43 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							6100a0fa12 
							
						 
					 
					
						
						
							
							Use new owned ID types in more places  
						
						
						
						
					 
					
						2022-04-20 10:39:36 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
						
						
							
						
						
							d855ec33d6 
							
						 
					 
					
						
						
							
							identifiers: Update ToOwned implementations to use new types  
						
						... 
						
						
						
						… and a lot of changes that cascaded from that. 
						
						
					 
					
						2022-04-20 10:39:36 +02:00 
						 
				 
			
				
					
						
							
							
								Jonas Platte 
							
						 
					 
					
						
						
							
							
						
						
						
							
						
						
							571fa90b8d 
							
						 
					 
					
						
						
							
							identifiers: Rename Error to IdParseError  
						
						... 
						
						
						
						… because it's now exported from the ruma-common crate root. 
						
						
					 
					
						2022-03-28 12:22:28 +02:00