network.nerve.base.signture.P2PHKSignature Maven / Gradle / Ivy
/*
* MIT License
*
* Copyright (c) 2017-2019 nuls.io
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
package network.nerve.base.signture;
import com.google.common.primitives.UnsignedBytes;
import network.nerve.base.basic.NulsByteBuffer;
import network.nerve.base.basic.NulsOutputStreamBuffer;
import network.nerve.base.data.BaseNulsData;
import network.nerve.base.data.NulsHash;
import network.nerve.base.data.NulsSignData;
import network.nerve.core.basic.Result;
import network.nerve.core.crypto.ECKey;
import network.nerve.core.exception.NulsException;
import network.nerve.core.log.Log;
import network.nerve.core.parse.SerializeUtils;
import java.io.IOException;
import java.util.Arrays;
import java.util.Comparator;
public class P2PHKSignature extends BaseNulsData {
public static final int SERIALIZE_LENGTH = 110;
private NulsSignData signData;
private byte[] publicKey;
public P2PHKSignature() {
}
public P2PHKSignature(byte[] signBytes, byte[] publicKey) {
this.signData = new NulsSignData();
try {
this.signData.parse(signBytes, 0);
} catch (NulsException e) {
Log.error(e);
}
this.publicKey = publicKey;
}
public P2PHKSignature(NulsSignData signData, byte[] publicKey) {
this.signData = signData;
this.publicKey = publicKey;
}
public NulsSignData getSignData() {
return signData;
}
public void setSignData(NulsSignData signData) {
this.signData = signData;
}
public byte[] getPublicKey() {
return publicKey;
}
public void setPublicKey(byte[] publicKey) {
this.publicKey = publicKey;
}
public Result verifySign(NulsHash digestData) {
boolean b = ECKey.verify(digestData.getBytes(), signData.getSignBytes(), this.getPublicKey());
if (b) {
return new Result(true);
} else {
return new Result(false);
}
}
public byte[] getSignerHash160() {
return SerializeUtils.sha256hash160(getPublicKey());
}
public static P2PHKSignature createFromBytes(byte[] bytes) throws NulsException {
P2PHKSignature sig = new P2PHKSignature();
sig.parse(bytes, 0);
return sig;
}
public byte[] getBytes() {
try {
return this.serialize();
} catch (IOException e) {
Log.error(e);
return null;
}
}
/**
* serialize important field
*/
@Override
protected void serializeToStream(NulsOutputStreamBuffer stream) throws IOException {
stream.write(publicKey.length);
stream.write(publicKey);
stream.writeNulsData(signData);
}
@Override
public void parse(NulsByteBuffer byteBuffer) throws NulsException {
int length = byteBuffer.readByte();
this.publicKey = byteBuffer.readBytes(length);
this.signData = new NulsSignData();
this.signData.parse(byteBuffer);
}
@Override
public int size() {
int size = 1 + publicKey.length;
size += SerializeUtils.sizeOfNulsData(signData);
return size;
}
public Result verifySignature(NulsHash digestData) {
boolean b = ECKey.verify(digestData.getBytes(), signData.getSignBytes(), publicKey);
if (b) {
return new Result(true);
} else {
return new Result(false);
}
}
@Override
public int hashCode() {
int result = 17;
result = 31 * result + Arrays.hashCode(signData.getSignBytes());
return result;
}
@Override
public boolean equals(Object obj) {
if (obj == null) {
return false;
}
if (!(obj instanceof P2PHKSignature)) {
return false;
}
return Arrays.equals(this.signData.getSignBytes(), ((P2PHKSignature) obj).signData.getSignBytes());
}
public static final Comparator PUBKEY_COMPARATOR = new Comparator() {
private Comparator comparator = UnsignedBytes.lexicographicalComparator();
@Override
public int compare(P2PHKSignature k1, P2PHKSignature k2) {
return comparator.compare(k1.getPublicKey(), k2.getPublicKey());
}
};
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy