io.proximax.core.crypto.Signature Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-xpx-chain-sdk Show documentation
Show all versions of java-xpx-chain-sdk Show documentation
The ProximaX Sirius Chain Java SDK is a Java library for interacting with the Sirius Blockchain.
The newest version!
/*
* Copyright 2018 NEM
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.proximax.core.crypto;
import java.math.BigInteger;
import java.util.Arrays;
import io.proximax.core.utils.ArrayUtils;
import io.proximax.core.utils.HexEncoder;
/**
* A EC signature.
*/
public class Signature {
private static final BigInteger MAXIMUM_VALUE = BigInteger.ONE.shiftLeft(256).subtract(BigInteger.ONE);
private final byte[] r;
private final byte[] s;
/**
* Creates a new signature.
*
* @param r The r-part of the signature.
* @param s The s-part of the signature.
*/
public Signature(final BigInteger r, final BigInteger s) {
if (0 < r.compareTo(MAXIMUM_VALUE) || 0 < s.compareTo(MAXIMUM_VALUE)) {
throw new IllegalArgumentException("r and s must fit into 32 bytes");
}
this.r = ArrayUtils.toByteArray(r, 32);
this.s = ArrayUtils.toByteArray(s, 32);
}
/**
* Creates a new signature.
*
* @param bytes The binary representation of the signature.
*/
public Signature(final byte[] bytes) {
if (64 != bytes.length) {
throw new IllegalArgumentException("binary signature representation must be 64 bytes");
}
final byte[][] parts = ArrayUtils.split(bytes, 32);
this.r = parts[0];
this.s = parts[1];
}
/**
* Creates a new signature.
*
* @param r The binary representation of r.
* @param s The binary representation of s.
*/
public Signature(final byte[] r, final byte[] s) {
if (32 != r.length || 32 != s.length) {
throw new IllegalArgumentException("binary signature representation of r and s must both have 32 bytes length");
}
this.r = r;
this.s = s;
}
/**
* Gets the r-part of the signature.
*
* @return The r-part of the signature.
*/
public BigInteger getR() {
return ArrayUtils.toBigInteger(this.r);
}
/**
* Gets the r-part of the signature.
*
* @return The r-part of the signature.
*/
public byte[] getBinaryR() {
return this.r;
}
/**
* Gets the s-part of the signature.
*
* @return The s-part of the signature.
*/
public BigInteger getS() {
return ArrayUtils.toBigInteger(this.s);
}
/**
* Gets the s-part of the signature.
*
* @return The s-part of the signature.
*/
public byte[] getBinaryS() {
return this.s;
}
/**
* Gets a little-endian 64-byte representation of the signature.
*
* @return a little-endian 64-byte representation of the signature
*/
public byte[] getBytes() {
return ArrayUtils.concat(this.r, this.s);
}
@Override
public int hashCode() {
return Arrays.hashCode(this.r) ^ Arrays.hashCode(this.s);
}
@Override
public boolean equals(final Object obj) {
if (obj == null || !(obj instanceof Signature)) {
return false;
}
final Signature rhs = (Signature) obj;
return 1 == ArrayUtils.isEqualConstantTime(this.r, rhs.r) && 1 == ArrayUtils.isEqualConstantTime(this.s, rhs.s);
}
@Override
public String toString() {
return HexEncoder.getString(this.getBytes());
}
}