/* TEMPLATE GENERATED TESTCASE FILE Filename: CWE90_LDAP_Injection__getParameter_Servlet_61b.java Label Definition File: CWE90_LDAP_Injection.label.xml Template File: sources-sink-61b.tmpl.java */ /* * @description * CWE: 90 LDAP Injection * BadSource: getParameter_Servlet Read data from a querystring using getParameter() * GoodSource: A hardcoded string * Sinks: * BadSink : data concatenated into LDAP search, which could result in LDAP Injection * Flow Variant: 61 Data flow: data returned from one method to another in different classes in the same package * * */ package testcases.CWE90_LDAP_Injection; import testcasesupport.*; import javax.servlet.http.*; public class CWE90_LDAP_Injection__getParameter_Servlet_61b { public String badSource(HttpServletRequest request, HttpServletResponse response) throws Throwable { String data; /* POTENTIAL FLAW: Read data from a querystring using getParameter */ data = request.getParameter("name"); return data; } /* goodG2B() - use goodsource and badsink */ public String goodG2BSource(HttpServletRequest request, HttpServletResponse response) throws Throwable { String data; /* FIX: Use a hardcoded string */ data = "foo"; return data; } }