Files
codeql/java/ql/test/query-tests/security/CWE-094/GroovyInjection/TemplateEngineTest.java
Owen Mansel-Chan 3693185b6b Second pass
2026-06-10 09:14:47 +02:00

31 lines
1.1 KiB
Java

import java.io.File;
import java.io.IOException;
import java.io.Reader;
import java.net.URL;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import groovy.text.TemplateEngine;
public class TemplateEngineTest extends HttpServlet {
private Object source(HttpServletRequest request) {
return request.getParameter("script"); // $ Source[java/groovy-injection]
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try {
Object script = source(request);
TemplateEngine engine = null;
engine.createTemplate(request.getParameter("script")); // $ Alert[java/groovy-injection]
engine.createTemplate((File) script); // $ Alert[java/groovy-injection]
engine.createTemplate((Reader) script); // $ Alert[java/groovy-injection]
engine.createTemplate((URL) script); // $ Alert[java/groovy-injection]
} catch (Exception e) {
}
}
}