I'm getting this error from Checkmarx:
The application constructs this SQL query by embedding an untrusted string into the query without proper sanitization. The concatenated string is submitted to the database, where it is parsed and executed accordingly.
public class CurrClientEntity
{
public string C_Code { get; set; }
public string C_Id { get; set; }
}
public CurrClientEntity GetCurrClientId(string c_Code)
{
var sql = new StringBuilder(@"SELECT C_CODE,C_ID FROM TBL_CLIENT");
sql.Append(" WHERE VALID =:VALID ");
sql.Append(" AND C_CODE = :C_CODE ");
var dictionary = new Dictionary<string, object>
{
{ "@C_CODE", c_Code },
{ "@VALID", 'Y' },
};
var parameters = new DynamicParameters(dictionary);
using (IDbConnection conn = CreateConnection())
{
return conn.QueryFirstOrDefault<CurrClientEntity>(sql.ToString(), parameters);
}
}