MD-escape URLs/alises/user IDs prior to parsing markdown
So that MD characters in them do not result in formatting being applied. Fixes https://github.com/vector-im/riot-web/issues/3428 Fixes https://github.com/vector-im/riot-web/issues/4674pull/21833/head
							parent
							
								
									ee5fc12cb0
								
							
						
					
					
						commit
						ee18ddb700
					
				|  | @ -55,6 +55,25 @@ function is_multi_line(node) { | |||
|     return par.firstChild != par.lastChild; | ||||
| } | ||||
| 
 | ||||
| import linkifyMatrix from './linkify-matrix'; | ||||
| import * as linkify from 'linkifyjs'; | ||||
| linkifyMatrix(linkify); | ||||
| 
 | ||||
| // Thieved from draft-js-export-markdown
 | ||||
| function escapeMarkdown(s) { | ||||
|     return s.replace(/[*_`]/g, '\\$&'); | ||||
| } | ||||
| 
 | ||||
| // Replace URLs, room aliases and user IDs with md-escaped URLs
 | ||||
| function linkifyMarkdown(s) { | ||||
|     const links = linkify.find(s); | ||||
|     links.forEach((l) => { | ||||
|         // This may replace several instances of `l.value` at once, but that's OK
 | ||||
|         s = s.replace(l.value, escapeMarkdown(l.value)); | ||||
|     }); | ||||
|     return s; | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * Class that wraps commonmark, adding the ability to see whether | ||||
|  * a given message actually uses any markdown syntax or whether | ||||
|  | @ -62,7 +81,7 @@ function is_multi_line(node) { | |||
|  */ | ||||
| export default class Markdown { | ||||
|     constructor(input) { | ||||
|         this.input = input; | ||||
|         this.input = linkifyMarkdown(input); | ||||
| 
 | ||||
|         const parser = new commonmark.Parser(); | ||||
|         this.parsed = parser.parse(this.input); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Luke Barnard
						Luke Barnard