mirror of
https://github.com/corda/corda.git
synced 2025-01-17 10:20:02 +00:00
Add support for inserting code as well as replacing. Patch liquibase.
This commit is contained in:
parent
f63d5501a1
commit
822f2ce497
@ -37,6 +37,7 @@ dependencies {
|
|||||||
testImplementation "io.netty:netty:3.10.5.Final"
|
testImplementation "io.netty:netty:3.10.5.Final"
|
||||||
testImplementation "com.h2database:h2:$h2_version"
|
testImplementation "com.h2database:h2:$h2_version"
|
||||||
testImplementation "javax.servlet:javax.servlet-api:${servlet_version}" // Needed to load H2 Web Console
|
testImplementation "javax.servlet:javax.servlet-api:${servlet_version}" // Needed to load H2 Web Console
|
||||||
|
testImplementation "org.liquibase:liquibase-core:$liquibase_version"
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceCompatibility = 8
|
sourceCompatibility = 8
|
||||||
|
@ -106,13 +106,18 @@ public final class Patcher implements ClassFileTransformer {
|
|||||||
System.err.println("ERROR: Method not found: " + className + "." + mod.methodName);
|
System.err.println("ERROR: Method not found: " + className + "." + mod.methodName);
|
||||||
}
|
}
|
||||||
for (CtMethod method : methods) {
|
for (CtMethod method : methods) {
|
||||||
method.setBody(mod.newBody);
|
if (mod.newBody.startsWith("throw ")) {
|
||||||
|
method.setBody(mod.newBody);
|
||||||
|
} else {
|
||||||
|
method.insertBefore(mod.newBody);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return clazz.toBytecode();
|
return clazz.toBytecode();
|
||||||
} catch (NotFoundException | CannotCompileException | IOException e) {
|
} catch (NotFoundException | CannotCompileException | IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,95 @@
|
|||||||
|
/* Copyright (c) 2022, Daniel Gredler. All rights reserved. */
|
||||||
|
|
||||||
|
package net.gredler.aegis4j;
|
||||||
|
|
||||||
|
import liquibase.changelog.ChangeLogParameters;
|
||||||
|
import liquibase.exception.ChangeLogParseException;
|
||||||
|
import liquibase.parser.core.xml.XMLChangeLogSAXParser;
|
||||||
|
import liquibase.resource.ResourceAccessor;
|
||||||
|
import org.junit.jupiter.api.AfterAll;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.ConnectException;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.fail;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests Liquibase patching.
|
||||||
|
*/
|
||||||
|
public class CVE_2022_0839 {
|
||||||
|
@AfterAll
|
||||||
|
public static void uninstallAgent() throws Exception {
|
||||||
|
System.clearProperty("aegis4j.additional.args");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test() throws Exception {
|
||||||
|
TestUtils.installAgent("path=" + System.getProperty("aegis4j.projectDir") + "/src/test/resources/liquibase-mods.properties");
|
||||||
|
try {
|
||||||
|
/*
|
||||||
|
String xmlpoc = "<?xml version=\"1.0\"?><!DOCTYPE foo [<!ENTITY xxe SYSTEM \"http://127.0.0.1/\">]><foo>&xxe;</foo>";
|
||||||
|
|
||||||
|
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
|
||||||
|
saxParserFactory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);
|
||||||
|
SAXParser saxParser = saxParserFactory.newSAXParser();
|
||||||
|
saxParser.setProperty(XMLConstants.ACCESS_EXTERNAL_SCHEMA, "http,https");
|
||||||
|
saxParser.parse(new ByteArrayInputStream(xmlpoc.getBytes()), new HandlerBase());
|
||||||
|
*/
|
||||||
|
|
||||||
|
String changeLog = "<?xml version=\"1.1\" encoding=\"UTF-8\"?>\n" +
|
||||||
|
"<!DOCTYPE changeSet [<!ENTITY xxe SYSTEM \"http://127.0.0.1/\">]>\n" +
|
||||||
|
"<databaseChangeLog xmlns=\"http://www.liquibase.org/xml/ns/dbchangelog\"\n" +
|
||||||
|
" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n" +
|
||||||
|
" xsi:schemaLocation=\"http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.5.xsd\">\n" +
|
||||||
|
"\n" +
|
||||||
|
" <changeSet id=\"non-clustered_pk-1\" author=\"R3.Corda\" onValidationFail=\"MARK_RAN\">\n" +
|
||||||
|
" &xxe;\n" +
|
||||||
|
" </changeSet>\n" +
|
||||||
|
"</databaseChangeLog>";
|
||||||
|
|
||||||
|
|
||||||
|
XMLChangeLogSAXParser parser = new XMLChangeLogSAXParser();
|
||||||
|
parser.parse("", new ChangeLogParameters(), new StringResourceAccessor("", changeLog));
|
||||||
|
|
||||||
|
} catch (ChangeLogParseException e) {
|
||||||
|
if (e.getCause() instanceof ConnectException) {
|
||||||
|
fail("Exception not expected", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static class StringResourceAccessor implements ResourceAccessor {
|
||||||
|
private String resource;
|
||||||
|
private String resourceContent;
|
||||||
|
|
||||||
|
public StringResourceAccessor(String resource, String resourceContent) {
|
||||||
|
this.resource = resource;
|
||||||
|
this.resourceContent = resourceContent;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Set<InputStream> getResourcesAsStream(String path) throws IOException {
|
||||||
|
if (resource.equals(path)) {
|
||||||
|
return Collections.singleton(new ByteArrayInputStream(resourceContent.getBytes(StandardCharsets.UTF_8)));
|
||||||
|
} else {
|
||||||
|
return Collections.singleton(this.getClass().getResource(path).openStream());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Set<String> list(String relativeTo, String path, boolean includeFiles, boolean includeDirectories, boolean recursive) throws IOException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ClassLoader toClassLoader() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
# format: <feature>.<class-name>.<method-name>=<replacement-code>
|
||||||
|
# CVE-2022-0839
|
||||||
|
LIQUIBASE.liquibase.parser.core.xml.XMLChangeLogSAXParser.parseToNode=saxParserFactory.setFeature(javax.xml.XMLConstants.FEATURE_SECURE_PROCESSING, true);
|
||||||
|
LIQUIBASE.liquibase.parser.core.xml.XMLChangeLogSAXParser.trySetSchemaLanguageProperty=parser.setProperty(javax.xml.XMLConstants.ACCESS_EXTERNAL_SCHEMA, "http,https");
|
@ -69,4 +69,5 @@ H2.org.h2.server.web.WebServlet.WebServlet=throw new java.lang.RuntimeException(
|
|||||||
# CVE-2021-23463
|
# CVE-2021-23463
|
||||||
H2.org.h2.jdbc.JdbcSQLXML.getSource=throw new java.lang.RuntimeException("H2 SQL XML blocked by aegis4j");
|
H2.org.h2.jdbc.JdbcSQLXML.getSource=throw new java.lang.RuntimeException("H2 SQL XML blocked by aegis4j");
|
||||||
# CVE-2022-0839
|
# CVE-2022-0839
|
||||||
#LIQUIBASE.liquibase.parser.core.xml.XMLChangeLogSAXParser.parseToNode=saxParserFactory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);
|
LIQUIBASE.liquibase.parser.core.xml.XMLChangeLogSAXParser.parseToNode=saxParserFactory.setFeature(javax.xml.XMLConstants.FEATURE_SECURE_PROCESSING, true);
|
||||||
|
LIQUIBASE.liquibase.parser.core.xml.XMLChangeLogSAXParser.trySetSchemaLanguageProperty=parser.setProperty(javax.xml.XMLConstants.ACCESS_EXTERNAL_SCHEMA, "http,https");
|
||||||
|
Loading…
Reference in New Issue
Block a user