Fix translating URL encoded mentions of sim users
This commit is contained in:
		
							parent
							
								
									e4f66a5077
								
							
						
					
					
						commit
						83070dcf7e
					
				
					 2 changed files with 34 additions and 1 deletions
				
			
		| 
						 | 
					@ -448,7 +448,8 @@ async function eventToMessage(event, guild, di) {
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			// Handling mentions of Discord users
 | 
								// Handling mentions of Discord users
 | 
				
			||||||
			input = input.replace(/("https:\/\/matrix.to\/#\/(@[^"]+)")>/g, (whole, attributeValue, mxid) => {
 | 
								input = input.replace(/("https:\/\/matrix.to\/#\/((?:@|%40)[^"]+)")>/g, (whole, attributeValue, mxid) => {
 | 
				
			||||||
 | 
									mxid = decodeURIComponent(mxid)
 | 
				
			||||||
				if (mxUtils.eventSenderIsFromDiscord(mxid)) {
 | 
									if (mxUtils.eventSenderIsFromDiscord(mxid)) {
 | 
				
			||||||
					// Handle mention of an OOYE sim user by their mxid
 | 
										// Handle mention of an OOYE sim user by their mxid
 | 
				
			||||||
					const userID = select("sim", "user_id", {mxid: mxid}).pluck().get()
 | 
										const userID = select("sim", "user_id", {mxid: mxid}).pluck().get()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1663,6 +1663,38 @@ test("event2message: mentioning discord users works", async t => {
 | 
				
			||||||
	)
 | 
						)
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					test("event2message: mentioning discord users works when URL encoded", async t => {
 | 
				
			||||||
 | 
						t.deepEqual(
 | 
				
			||||||
 | 
							await eventToMessage({
 | 
				
			||||||
 | 
								content: {
 | 
				
			||||||
 | 
									body: "Crunch God a sample message",
 | 
				
			||||||
 | 
									format: "org.matrix.custom.html",
 | 
				
			||||||
 | 
									formatted_body: `<a href="https://matrix.to/#/%40_ooye_bojack_horseman%3Acadence.moe">Crunch God</a> a sample message`,
 | 
				
			||||||
 | 
									msgtype: "m.text"
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								event_id: "$g07oYSZFWBkxohNEfywldwgcWj1hbhDzQ1sBAKvqOOU",
 | 
				
			||||||
 | 
								origin_server_ts: 1688301929913,
 | 
				
			||||||
 | 
								room_id: "!kLRqKKUQXcibIMtOpl:cadence.moe",
 | 
				
			||||||
 | 
								sender: "@cadence:cadence.moe",
 | 
				
			||||||
 | 
								type: "m.room.message",
 | 
				
			||||||
 | 
								unsigned: {
 | 
				
			||||||
 | 
									age: 405299
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}),
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								ensureJoined: [],
 | 
				
			||||||
 | 
								messagesToDelete: [],
 | 
				
			||||||
 | 
								messagesToEdit: [],
 | 
				
			||||||
 | 
								messagesToSend: [{
 | 
				
			||||||
 | 
									username: "cadence [they]",
 | 
				
			||||||
 | 
									content: "<@771520384671416320> a sample message",
 | 
				
			||||||
 | 
									avatar_url: undefined
 | 
				
			||||||
 | 
								}]
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						)
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test("event2message: mentioning matrix users works", async t => {
 | 
					test("event2message: mentioning matrix users works", async t => {
 | 
				
			||||||
	t.deepEqual(
 | 
						t.deepEqual(
 | 
				
			||||||
		await eventToMessage({
 | 
							await eventToMessage({
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue