X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=common%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Fcommon%2Fmapping%2FPortMappingVersion121.java;h=d7def4d7a61e0956c1b9be683e864b8981571e10;hb=refs%2Fchanges%2F41%2F93641%2F8;hp=382d96149b418797a554e68a2189490a7c9c4628;hpb=d2c98d6f9b59339d0b8ff741fc42682cbc97f90b;p=transportpce.git diff --git a/common/src/main/java/org/opendaylight/transportpce/common/mapping/PortMappingVersion121.java b/common/src/main/java/org/opendaylight/transportpce/common/mapping/PortMappingVersion121.java index 382d96149..d7def4d7a 100644 --- a/common/src/main/java/org/opendaylight/transportpce/common/mapping/PortMappingVersion121.java +++ b/common/src/main/java/org/opendaylight/transportpce/common/mapping/PortMappingVersion121.java @@ -10,10 +10,7 @@ package org.opendaylight.transportpce.common.mapping; import com.google.common.util.concurrent.FluentFuture; import edu.umd.cs.findbugs.annotations.SuppressFBWarnings; -import java.math.BigInteger; -import java.nio.charset.StandardCharsets; import java.util.ArrayList; -import java.util.Base64; import java.util.Collection; import java.util.Collections; import java.util.Comparator; @@ -90,11 +87,6 @@ public class PortMappingVersion121 { private final DeviceTransactionManager deviceTransactionManager; private final OpenRoadmInterfaces openRoadmInterfaces; - //FNV1 64 bit hash constants - private static final BigInteger FNV_PRIME = new BigInteger("100000001b3", 16); - private static final BigInteger FNV_INIT = new BigInteger("cbf29ce484222325", 16); - private static final BigInteger FNV_MOD = new BigInteger("2").pow(64); - public PortMappingVersion121(DataBroker dataBroker, DeviceTransactionManager deviceTransactionManager, OpenRoadmInterfaces openRoadmInterfaces) { this.dataBroker = dataBroker; @@ -699,7 +691,7 @@ public class PortMappingVersion121 { .setSupportingCircuitPackName(circuitPackName) .setSupportingPort(port.getPortName()) .setPortDirection(port.getPortDirection().getName()) - .setLcpHashVal(fnv(nodeIdLcp)); + .setLcpHashVal(FnvUtils.fnv1_64(nodeIdLcp)); if (port.getPortQual() != null) { mpBldr.setPortQual(port.getPortQual().getName()); } @@ -877,25 +869,4 @@ public class PortMappingVersion121 { } return nodeInfoBldr.build(); } - - /** - * Implements the FNV-1 64bit algorithm. - * FNV-1 128bit would be ideal for 16 bytes but we need an overhead for Base64 encoding. - * Otherwise, the hash cannot be stored in a UTF-8 string. - * https://www.wikiwand.com/en/Fowler%E2%80%93Noll%E2%80%93Vo_hash_function#/FNV-1_hash - * https://github.com/pmdamora/fnv-cracker-app/blob/master/src/main/java/passwordcrack/cracking/HashChecker.java - * @param stringdata the String to be hashed - * @return the base64 formatted hash string - */ - private String fnv(String stringdata) { - BigInteger hash = FNV_INIT; - byte[] data = stringdata.getBytes(StandardCharsets.UTF_8); - - for (byte b : data) { - hash = hash.multiply(FNV_PRIME).mod(FNV_MOD); - hash = hash.xor(BigInteger.valueOf((int) b & 0xff)); - } - - return Base64.getEncoder().encodeToString(hash.toByteArray()); - } }