DevSkim icon indicating copy to clipboard operation
DevSkim copied to clipboard

Rewrite Rules to use Named Group syntax

Open gfs opened this issue 4 years ago • 1 comments

http://xregexp.com/syntax/

https://docs.microsoft.com/en-us/dotnet/api/system.text.regularexpressions.regex.getgroupnames?view=netcore-3.1

Problem

To fix #184 where rules are catching Base64 encoded objects.

We may want to check that something has a maximum length for example. If you check that with the current methods, all those characters will be highlighted instead of just the MD5. You cannot do this with existing conditions because those check on the already matched data.

Proposed solution

Use named capture group syntax compatible with both the VSCode and .NET codebases.

(?<finding>CC_(MD2|MD4|MD5|SHA1) for example will highlight CC_MD2 and capture it in a property of the matches named finding

[\\s\\(\\)\\.].{0,50}(?<finding>MD2|MD4|MD5|RIPEMD|RIPEMD(128|256|160|320)|(SHA0|SHA-0|SHA1|SHA-1).{0,50}[\\s\\(;\\.) will highlight MD2 in CreateMD2Hash but not in

 let base64 = '_MD2_j+TSXwAAAABJRU5ErkJggg==';

gfs avatar Jun 05 '20 23:06 gfs

Depends on #201

gfs avatar Jul 19 '20 15:07 gfs