Skip to content

Commit

Permalink
Use Java standard SHA3 implementation (#4459)
Browse files Browse the repository at this point in the history
We get a lot of noisy security alerts about a dependency on
Bouncycastle, which was introduced historically to work around the lack
of a SHA3-256 implementation in standard Java. This PR removes the
dependency by porting its single usage (rule digests / `UNIQUE_ID`s)
over to use new features in the standard library.

The IDs produced after this change are identical to their previous form.
  • Loading branch information
Baltoli authored Jun 20, 2024
1 parent 6126739 commit 8fd58b3
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 14 deletions.
2 changes: 1 addition & 1 deletion flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@

k-framework = { haskell-backend-bins, llvm-kompile-libs }:
prev.callPackage ./nix/k.nix {
mvnHash = "sha256-6rGuU8NFSp3lQVxxPj5WREpNVPneMqPH45DFEmLiH6I=";
mvnHash = "sha256-HkAwMZq2vvrnEgT1Ksoxb5YnQ8+CMQdB2Sd/nR0OttU=";
manualMvnArtifacts = [
"org.scala-lang:scala-compiler:2.13.13"
"ant-contrib:ant-contrib:1.0b3"
Expand Down
5 changes: 0 additions & 5 deletions k-frontend/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,6 @@
<artifactId>org.eclipse.lsp4j</artifactId>
<version>0.19.0</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.69</version>
</dependency>
<dependency>
<groupId>com.google.inject</groupId>
<artifactId>guice</artifactId>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
// Copyright (c) Runtime Verification, Inc. All Rights Reserved.
package org.kframework.compile;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import java.util.HexFormat;
import java.util.List;
import org.bouncycastle.jcajce.provider.digest.SHA3;
import org.bouncycastle.util.encoders.Hex;
import org.kframework.attributes.Att;
import org.kframework.definition.RuleOrClaim;
import org.kframework.definition.Sentence;
import org.kframework.utils.errorsystem.KEMException;

public class NumberSentences {

Expand All @@ -31,17 +33,23 @@ public static Sentence number(Sentence s) {
preservedAtts.stream()
.filter(att -> s.att().contains(att))
.map(att -> Att.empty().add(att, s.att().get(att)))
.reduce(Att.empty(), (acc, elem) -> acc.addAll(elem));
.reduce(Att.empty(), Att::addAll);

String id = ruleHash(s.withAtt(a));
return s.withAtt(s.att().add(Att.UNIQUE_ID(), id));
}

private static String ruleHash(Sentence s) {
String text = new NormalizeVariables().normalize(s).toString();
SHA3.Digest256 sha3engine = new SHA3.Digest256();
byte[] digest = sha3engine.digest(text.getBytes());
String digestString = Hex.toHexString(digest);
return digestString;
try {
String text = new NormalizeVariables().normalize(s).toString();
byte[] digest = MessageDigest.getInstance("SHA3-256").digest(text.getBytes());
return HexFormat.of().formatHex(digest);
} catch (NoSuchAlgorithmException e) {
// This exception should never actually be thrown in practice; it's just a limitation of the
// Java cryptography APIs that we need to request algorithms by constant string keys and cope
// with them potentially not existing. SHA3-256 is part of the Java standard library from JDK
// 17 onwards.
throw KEMException.criticalError("Error computing rule digest (SHA3-256 unavailable)", e);
}
}
}

0 comments on commit 8fd58b3

Please sign in to comment.