Skip to content

Commit

Permalink
Fix CSharp SQLI rule (#3440)
Browse files Browse the repository at this point in the history
  • Loading branch information
LewisArdern authored Aug 1, 2024
1 parent 5fbf176 commit e245327
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 13 deletions.
26 changes: 15 additions & 11 deletions csharp/lang/security/sqli/csharp-sqli.cs
Original file line number Diff line number Diff line change
Expand Up @@ -135,17 +135,21 @@ public void sqli11(string sqli)
}
}

public void sqli12(string sqli)
{
using (SqlConnection connection = new SqlConnection("Data Source=(local);Initial Catalog=Northwind;Integrated Security=SSPI;")) {
connection.Open();
SqlCommand command= connection.CreateCommand();
// ruleid: csharp-sqli
command.CommandText = sqli;
command.CommandTimeout = 15;
command.CommandType = CommandType.Text;
}
}
public void sqli2(string sqli)
{
using (SqlConnection connection = new SqlConnection("Data Source=(local);Initial Catalog=Northwind;Integrated Security=SSPI;")) {
connection.Open();
SqlCommand command= connection.CreateCommand();
// ruleid: csharp-sqli
command.CommandText = String.Format("SELECT c.name AS column_name,t.name AS type_name,c.max_length,c.precision,c.scale, CAST(CASE WHEN EXISTS(SELECT * FROM sys.index_columns AS i WHERE i.object_id=c.object_id AND i.column_id=c.column_id) THEN 1 ELSE 0 END AS BIT) AS column_indexed FROM sys.columns AS c JOIN sys.types AS t ON c.user_type_id=t.user_type_id WHERE c.object_id = OBJECT_ID('{0}') ORDER BY c.column_id;", sqli);
command.CommandTimeout = 15;
command.CommandType = CommandType.Text;
await using var connection = new SqlConnection(configuration.GetVaultConnectionString(sqli, "B", true));
await using var command = connection.CreateCommand();
// ok: csharp-sqli
command.CommandText = "SELECT 1;";
}
}

public void sqli13()
{
Expand Down
6 changes: 4 additions & 2 deletions csharp/lang/security/sqli/csharp-sqli.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,10 @@ rules:
- pattern: |
new $PATTERN($CMD,...)
- focus-metavariable: $CMD
- pattern: |
$CMD.$PATTERN = ...;
- patterns:
- pattern: |
$CMD.$PATTERN = $VALUE;
- focus-metavariable: $VALUE
- metavariable-regex:
metavariable: $PATTERN
regex: ^(SqlCommand|CommandText|OleDbCommand|OdbcCommand|OracleCommand)$
Expand Down

0 comments on commit e245327

Please sign in to comment.