mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 20:07:13 +00:00 
			
		
		
		
	Replace linkRegex with xurls library (#6261)
* Replace linkRegex with xurls library Rather than maintaining a complicated regex to match URLs for autolinking, gitea can use this existing go library that takes care of the matching with very little code change to gitea itself. After spending a while trying to find the perfect regex for all cases this library still works better as it is more flexible than a single regex ever will be. This will also fix the following issues: #5844 #3095 #3381 This passes all our current tests and I've added new ones mentioned in those issues as well. * Use xurls.StrictMatchingScheme instead of xurls.Strict This is much faster and we only care about https? links to preserve existing behavior.
This commit is contained in:
		 mrsdizzie
					mrsdizzie
				
			
				
					committed by
					
						 techknowlogick
						techknowlogick
					
				
			
			
				
	
			
			
			 techknowlogick
						techknowlogick
					
				
			
						parent
						
							01bd1fcd33
						
					
				
				
					commit
					f2de5dc8c8
				
			| @@ -104,6 +104,15 @@ func TestRender_links(t *testing.T) { | ||||
| 	test( | ||||
| 		"http://142.42.1.1/", | ||||
| 		`<p><a href="http://142.42.1.1/" rel="nofollow">http://142.42.1.1/</a></p>`) | ||||
| 	test( | ||||
| 		"https://github.com/go-gitea/gitea/?p=aaa/bbb.html#ccc-ddd", | ||||
| 		`<p><a href="https://github.com/go-gitea/gitea/?p=aaa/bbb.html#ccc-ddd" rel="nofollow">https://github.com/go-gitea/gitea/?p=aaa/bbb.html#ccc-ddd</a></p>`) | ||||
| 	test( | ||||
| 		"https://en.wikipedia.org/wiki/URL_(disambiguation)", | ||||
| 		`<p><a href="https://en.wikipedia.org/wiki/URL_(disambiguation)" rel="nofollow">https://en.wikipedia.org/wiki/URL_(disambiguation)</a></p>`) | ||||
| 	test( | ||||
| 		"https://foo_bar.example.com/", | ||||
| 		`<p><a href="https://foo_bar.example.com/" rel="nofollow">https://foo_bar.example.com/</a></p>`) | ||||
|  | ||||
| 	// Test that should *not* be turned into URL | ||||
| 	test( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user