complete wallet validation

This commit is contained in:
Craig Raw 2020-05-15 13:42:58 +02:00
parent f6414a4475
commit 6b1f7d0174
2 changed files with 18 additions and 5 deletions

View file

@ -109,7 +109,11 @@ public class Keystore {
return false;
}
if(keyDerivation.getDerivationPath() == null || !KeyDerivation.isValid(keyDerivation.getDerivationPath())) {
if(label.isEmpty() || label.replace(" ", "").length() > 16) {
return false;
}
if(keyDerivation.getDerivationPath() == null || keyDerivation.getDerivationPath().isEmpty() || !KeyDerivation.isValid(keyDerivation.getDerivationPath())) {
return false;
}

View file

@ -7,10 +7,7 @@ import com.sparrowwallet.drongo.policy.PolicyType;
import com.sparrowwallet.drongo.protocol.ScriptType;
import org.bouncycastle.crypto.params.KeyParameter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.*;
public class Wallet {
@ -99,6 +96,10 @@ public class Wallet {
return false;
}
if(containsDuplicateKeystoreLabels()) {
return false;
}
for(Keystore keystore : keystores) {
if(!keystore.isValid()) {
return false;
@ -119,6 +120,14 @@ public class Wallet {
return Arrays.stream(ScriptType.values()).anyMatch(scriptType -> !scriptType.equals(this.scriptType) && scriptType.getAccount(derivationPath) > -1);
}
public boolean containsDuplicateKeystoreLabels() {
if(keystores.size() <= 1) {
return false;
}
return !keystores.stream().map(Keystore::getLabel).allMatch(new HashSet<>()::add);
}
public Wallet copy() {
Wallet copy = new Wallet(name);
copy.setPolicyType(policyType);