com.swirlds.common.crypto.Signature Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of swirlds-common Show documentation
Show all versions of swirlds-common Show documentation
Swirlds is a software platform designed to build fully-distributed applications that harness the power of the cloud without servers. Now you can develop applications with fairness in decision making, speed, trust and reliability, at a fraction of the cost of traditional server-based platforms.
/*
* Copyright (C) 2020-2024 Hedera Hashgraph, LLC
*
* 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 com.swirlds.common.crypto;
import static com.swirlds.common.crypto.SignatureType.RSA;
import static com.swirlds.common.utility.CommonUtils.hex;
import com.hedera.pbj.runtime.io.buffer.Bytes;
import com.swirlds.base.utility.ToStringBuilder;
import com.swirlds.common.io.SelfSerializable;
import com.swirlds.common.io.streams.SerializableDataInputStream;
import com.swirlds.common.io.streams.SerializableDataOutputStream;
import edu.umd.cs.findbugs.annotations.NonNull;
import java.io.IOException;
import java.util.Arrays;
import java.util.Objects;
/**
* Encapsulates a cryptographic signature along with its SignatureType.
*/
public class Signature implements SelfSerializable {
/** a unique class type identifier */
private static final long CLASS_ID = 0x13dc4b399b245c69L;
/** the current serialization version */
private static final int CLASS_VERSION = 1;
/** The type of cryptographic algorithm used to create the signature */
private SignatureType signatureType;
/** signature byte array */
private byte[] signatureBytes;
/**
* For RuntimeConstructable
*/
public Signature() {}
public Signature(final SignatureType signatureType, final byte[] signatureBytes) {
this.signatureType = signatureType;
this.signatureBytes = signatureBytes;
}
/**
* {@inheritDoc}
*/
@Override
public void deserialize(final SerializableDataInputStream in, final int version) throws IOException {
this.signatureType = SignatureType.from(in.readInt(), RSA);
this.signatureBytes = in.readByteArray(this.signatureType.signatureLength(), true);
}
/**
* {@inheritDoc}
*/
@Override
public void serialize(final SerializableDataOutputStream out) throws IOException {
out.writeInt(signatureType.ordinal());
out.writeByteArray(signatureBytes, true);
}
/**
* Get the bytes of this signature.
*/
public byte[] getSignatureBytes() {
return signatureBytes;
}
/**
* @return the bytes of this signature in an immutable instance
*/
public @NonNull Bytes getBytes() {
return Bytes.wrap(signatureBytes);
}
/**
* Get the type of this signature.
*/
@NonNull
public SignatureType getType() {
return signatureType;
}
/**
* {@inheritDoc}
*/
@Override
public long getClassId() {
return CLASS_ID;
}
/**
* {@inheritDoc}
*/
@Override
public int getVersion() {
return CLASS_VERSION;
}
/**
* {@inheritDoc}
*/
@Override
public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
if (!(obj instanceof final Signature signature)) {
return false;
}
return Arrays.equals(signatureBytes, signature.signatureBytes) && signatureType == signature.signatureType;
}
/**
* {@inheritDoc}
*/
@Override
public int hashCode() {
return Objects.hash(signatureType, Arrays.hashCode(signatureBytes));
}
/**
* {@inheritDoc}
*/
@Override
public String toString() {
return new ToStringBuilder(this)
.append("signatureType", signatureType)
.append("sigBytes", hex(signatureBytes))
.toString();
}
}