PaymentProtocol.smali
.class public Lorg/bitcoinj/protocols/payments/PaymentProtocol;
.super Ljava/lang/Object;
.source "PaymentProtocol.java"
# static fields
.field public static final MIMETYPE_PAYMENT:Ljava/lang/String; = "application/bitcoin-payment"
.field public static final MIMETYPE_PAYMENTACK:Ljava/lang/String; = "application/bitcoin-paymentack"
.field public static final MIMETYPE_PAYMENTREQUEST:Ljava/lang/String; = "application/bitcoin-paymentrequest"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 48
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static createPayToAddressOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;)Lorg/bitcoin/protocols/payments/Protos$Output;
.registers 6
.prologue
.line 401
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$Output;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$Output$Builder;
move-result-object v0
.line 402
if-eqz p0, :cond_48
.line 403
invoke-virtual {p1}, Lorg/bitcoinj/core/Address;->getParameters()Lorg/bitcoinj/core/NetworkParameters;
move-result-object v1
.line 404
invoke-virtual {v1}, Lorg/bitcoinj/core/NetworkParameters;->hasMaxMoney()Z
move-result v2
if-eqz v2, :cond_2f
invoke-virtual {v1}, Lorg/bitcoinj/core/NetworkParameters;->getMaxMoney()Lorg/bitcoinj/core/Coin;
move-result-object v1
invoke-virtual {p0, v1}, Lorg/bitcoinj/core/Coin;->compareTo(Lorg/bitcoinj/core/Coin;)I
move-result v1
if-lez v1, :cond_2f
.line 405
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Amount too big: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 406
:cond_2f
iget-wide v2, p0, Lorg/bitcoinj/core/Coin;->value:J
invoke-virtual {v0, v2, v3}, Lorg/bitcoin/protocols/payments/Protos$Output$Builder;->setAmount(J)Lorg/bitcoin/protocols/payments/Protos$Output$Builder;
.line 410
:goto_34
invoke-static {p1}, Lorg/bitcoinj/script/ScriptBuilder;->createOutputScript(Lorg/bitcoinj/core/Address;)Lorg/bitcoinj/script/Script;
move-result-object v1
invoke-virtual {v1}, Lorg/bitcoinj/script/Script;->getProgram()[B
move-result-object v1
invoke-static {v1}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/bitcoin/protocols/payments/Protos$Output$Builder;->setScript(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$Output$Builder;
.line 411
invoke-virtual {v0}, Lorg/bitcoin/protocols/payments/Protos$Output$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$Output;
move-result-object v0
return-object v0
.line 408
:cond_48
const-wide/16 v2, 0x0
invoke-virtual {v0, v2, v3}, Lorg/bitcoin/protocols/payments/Protos$Output$Builder;->setAmount(J)Lorg/bitcoin/protocols/payments/Protos$Output$Builder;
goto :goto_34
.end method
.method public static createPaymentAck(Lorg/bitcoin/protocols/payments/Protos$Payment;Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentACK;
.registers 3
.prologue
.line 377
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;
move-result-object v0
.line 378
invoke-virtual {v0, p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;->setPayment(Lorg/bitcoin/protocols/payments/Protos$Payment;)Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;
.line 379
if-eqz p1, :cond_c
.line 380
invoke-virtual {v0, p1}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;->setMemo(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;
.line 381
:cond_c
invoke-virtual {v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$PaymentACK;
move-result-object v0
return-object v0
.end method
.method public static createPaymentMessage(Ljava/util/List;Ljava/util/List;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$Payment;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/core/Transaction;",
">;",
"Ljava/util/List",
"<",
"Lorg/bitcoin/protocols/payments/Protos$Output;",
">;",
"Ljava/lang/String;",
"[B)",
"Lorg/bitcoin/protocols/payments/Protos$Payment;"
}
.end annotation
.prologue
.line 318
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$Payment;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;
move-result-object v1
.line 319
invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_8
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_23
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoinj/core/Transaction;
.line 320
invoke-virtual {v0}, Lorg/bitcoinj/core/Transaction;->verify()V
.line 321
invoke-virtual {v0}, Lorg/bitcoinj/core/Transaction;->unsafeBitcoinSerialize()[B
move-result-object v0
invoke-static {v0}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;->addTransactions(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;
goto :goto_8
.line 323
:cond_23
if-eqz p1, :cond_39
.line 324
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_29
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_39
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoin/protocols/payments/Protos$Output;
.line 325
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;->addRefundTo(Lorg/bitcoin/protocols/payments/Protos$Output;)Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;
goto :goto_29
.line 327
:cond_39
if-eqz p2, :cond_3e
.line 328
invoke-virtual {v1, p2}, Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;->setMemo(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;
.line 329
:cond_3e
if-eqz p3, :cond_47
.line 330
invoke-static {p3}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;->setMerchantData(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;
.line 331
:cond_47
invoke-virtual {v1}, Lorg/bitcoin/protocols/payments/Protos$Payment$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$Payment;
move-result-object v0
return-object v0
.end method
.method public static createPaymentMessage(Ljava/util/List;Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$Payment;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/core/Transaction;",
">;",
"Lorg/bitcoinj/core/Coin;",
"Lorg/bitcoinj/core/Address;",
"Ljava/lang/String;",
"[B)",
"Lorg/bitcoin/protocols/payments/Protos$Payment;"
}
.end annotation
.prologue
.line 297
if-eqz p2, :cond_19
.line 298
if-nez p1, :cond_c
.line 299
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Specify refund amount if refund address is specified."
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 301
:cond_c
invoke-static {p1, p2}, Lorg/bitcoinj/protocols/payments/PaymentProtocol;->createPayToAddressOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;)Lorg/bitcoin/protocols/payments/Protos$Output;
move-result-object v0
invoke-static {v0}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
.line 300
invoke-static {p0, v0, p3, p4}, Lorg/bitcoinj/protocols/payments/PaymentProtocol;->createPaymentMessage(Ljava/util/List;Ljava/util/List;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$Payment;
move-result-object v0
.line 303
:goto_18
return-object v0
:cond_19
const/4 v0, 0x0
invoke-static {p0, v0, p3, p4}, Lorg/bitcoinj/protocols/payments/PaymentProtocol;->createPaymentMessage(Ljava/util/List;Ljava/util/List;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$Payment;
move-result-object v0
goto :goto_18
.end method
.method public static createPaymentRequest(Lorg/bitcoinj/core/NetworkParameters;Ljava/util/List;Ljava/lang/String;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/bitcoinj/core/NetworkParameters;",
"Ljava/util/List",
"<",
"Lorg/bitcoin/protocols/payments/Protos$Output;",
">;",
"Ljava/lang/String;",
"Ljava/lang/String;",
"[B)",
"Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;"
}
.end annotation
.prologue
.line 89
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
move-result-object v1
.line 90
invoke-virtual {p0}, Lorg/bitcoinj/core/NetworkParameters;->getPaymentProtocolId()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->setNetwork(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
.line 91
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_f
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_1f
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/bitcoin/protocols/payments/Protos$Output;
.line 92
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->addOutputs(Lorg/bitcoin/protocols/payments/Protos$Output;)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
goto :goto_f
.line 93
:cond_1f
if-eqz p2, :cond_24
.line 94
invoke-virtual {v1, p2}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->setMemo(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
.line 95
:cond_24
if-eqz p3, :cond_29
.line 96
invoke-virtual {v1, p3}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->setPaymentUrl(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
.line 97
:cond_29
if-eqz p4, :cond_32
.line 98
invoke-static {p4}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {v1, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->setMerchantData(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
.line 99
:cond_32
invoke-static {}, Lorg/bitcoinj/core/Utils;->currentTimeSeconds()J
move-result-wide v2
invoke-virtual {v1, v2, v3}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->setTime(J)Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;
.line 101
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
move-result-object v0
.line 102
invoke-virtual {v1}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$PaymentDetails;
move-result-object v1
invoke-virtual {v1}, Lorg/bitcoin/protocols/payments/Protos$PaymentDetails;->toByteString()Lcom/google/protobuf/ByteString;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setSerializedPaymentDetails(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 103
return-object v0
.end method
.method public static createPaymentRequest(Lorg/bitcoinj/core/NetworkParameters;Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;Ljava/lang/String;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.registers 7
.prologue
.line 71
invoke-static {p1, p2}, Lorg/bitcoinj/protocols/payments/PaymentProtocol;->createPayToAddressOutput(Lorg/bitcoinj/core/Coin;Lorg/bitcoinj/core/Address;)Lorg/bitcoin/protocols/payments/Protos$Output;
move-result-object v0
invoke-static {v0}, Lcom/google/common/collect/ImmutableList;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
move-result-object v0
invoke-static {p0, v0, p3, p4, p5}, Lorg/bitcoinj/protocols/payments/PaymentProtocol;->createPaymentRequest(Lorg/bitcoinj/core/NetworkParameters;Ljava/util/List;Ljava/lang/String;Ljava/lang/String;[B)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
move-result-object v0
return-object v0
.end method
.method public static parsePaymentAck(Lorg/bitcoin/protocols/payments/Protos$PaymentACK;)Lorg/bitcoinj/protocols/payments/PaymentProtocol$Ack;
.registers 3
.prologue
.line 388
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK;->hasMemo()Z
move-result v0
if-eqz v0, :cond_10
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentACK;->getMemo()Ljava/lang/String;
move-result-object v0
.line 389
:goto_a
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocol$Ack;
invoke-direct {v1, v0}, Lorg/bitcoinj/protocols/payments/PaymentProtocol$Ack;-><init>(Ljava/lang/String;)V
return-object v1
.line 388
:cond_10
const/4 v0, 0x0
goto :goto_a
.end method
.method public static parsePaymentRequest(Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;)Lorg/bitcoinj/protocols/payments/PaymentSession;
.registers 4
.prologue
.line 115
new-instance v0, Lorg/bitcoinj/protocols/payments/PaymentSession;
const/4 v1, 0x0
const/4 v2, 0x0
invoke-direct {v0, p0, v1, v2}, Lorg/bitcoinj/protocols/payments/PaymentSession;-><init>(Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;ZLorg/bitcoinj/crypto/TrustStoreLoader;)V
return-object v0
.end method
.method public static parseTransactionsFromPaymentMessage(Lorg/bitcoinj/core/NetworkParameters;Lorg/bitcoin/protocols/payments/Protos$Payment;)Ljava/util/List;
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lorg/bitcoinj/core/NetworkParameters;",
"Lorg/bitcoin/protocols/payments/Protos$Payment;",
")",
"Ljava/util/List",
"<",
"Lorg/bitcoinj/core/Transaction;",
">;"
}
.end annotation
.prologue
.line 343
new-instance v1, Ljava/util/ArrayList;
invoke-virtual {p1}, Lorg/bitcoin/protocols/payments/Protos$Payment;->getTransactionsCount()I
move-result v0
invoke-direct {v1, v0}, Ljava/util/ArrayList;-><init>(I)V
.line 344
invoke-virtual {p1}, Lorg/bitcoin/protocols/payments/Protos$Payment;->getTransactionsList()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_11
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2d
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
.line 345
invoke-virtual {p0}, Lorg/bitcoinj/core/NetworkParameters;->getDefaultSerializer()Lorg/bitcoinj/core/MessageSerializer;
move-result-object v3
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v0
invoke-virtual {v3, v0}, Lorg/bitcoinj/core/MessageSerializer;->makeTransaction([B)Lorg/bitcoinj/core/Transaction;
move-result-object v0
invoke-interface {v1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_11
.line 346
:cond_2d
return-object v1
.end method
.method public static signPaymentRequest(Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;)V
.registers 7
.prologue
.line 129
:try_start_0
invoke-static {}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates;->newBuilder()Lorg/bitcoin/protocols/payments/Protos$X509Certificates$Builder;
move-result-object v1
.line 130
array-length v2, p1
const/4 v0, 0x0
:goto_6
if-ge v0, v2, :cond_18
aget-object v3, p1, v0
.line 131
invoke-virtual {v3}, Ljava/security/cert/Certificate;->getEncoded()[B
move-result-object v3
invoke-static {v3}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v3
invoke-virtual {v1, v3}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates$Builder;->addCertificate(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$X509Certificates$Builder;
.line 130
add-int/lit8 v0, v0, 0x1
goto :goto_6
.line 133
:cond_18
const-string v0, "x509+sha256"
invoke-virtual {p0, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setPkiType(Ljava/lang/String;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 134
invoke-virtual {v1}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$X509Certificates;
move-result-object v0
invoke-virtual {v0}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates;->toByteString()Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {p0, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setPkiData(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 135
sget-object v0, Lcom/google/protobuf/ByteString;->EMPTY:Lcom/google/protobuf/ByteString;
invoke-virtual {p0, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setSignature(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 136
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;
move-result-object v0
.line 139
const-string v1, "RSA"
invoke-interface {p2}, Ljava/security/PrivateKey;->getAlgorithm()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_59
.line 140
const-string v1, "SHA256withRSA"
.line 144
invoke-static {v1}, Ljava/security/Signature;->getInstance(Ljava/lang/String;)Ljava/security/Signature;
move-result-object v1
.line 145
invoke-virtual {v1, p2}, Ljava/security/Signature;->initSign(Ljava/security/PrivateKey;)V
.line 146
invoke-virtual {v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->toByteArray()[B
move-result-object v0
invoke-virtual {v1, v0}, Ljava/security/Signature;->update([B)V
.line 148
invoke-virtual {v1}, Ljava/security/Signature;->sign()[B
move-result-object v0
invoke-static {v0}, Lcom/google/protobuf/ByteString;->copyFrom([B)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-virtual {p0, v0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setSignature(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 152
return-void
.line 142
:cond_59
new-instance v0, Ljava/lang/IllegalStateException;
invoke-interface {p2}, Ljava/security/PrivateKey;->getAlgorithm()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_63
.catch Ljava/security/GeneralSecurityException; {:try_start_0 .. :try_end_63} :catch_63
.line 149
:catch_63
move-exception v0
.line 151
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
.end method
.method public static verifyPaymentRequestPki(Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;Ljava/security/KeyStore;)Lorg/bitcoinj/protocols/payments/PaymentProtocol$PkiVerificationData;
.registers 9
.prologue
const/4 v0, 0x0
.line 166
.line 168
:try_start_1
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->getPkiType()Ljava/lang/String;
move-result-object v1
.line 169
const-string v2, "none"
invoke-virtual {v2, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_e
.line 221
:goto_d
return-object v0
.line 174
:cond_e
const-string v2, "x509+sha256"
invoke-virtual {v2, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_35
.line 175
const-string v1, "SHA256withRSA"
.line 181
:goto_18
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->getPkiData()Lcom/google/protobuf/ByteString;
move-result-object v2
invoke-static {v2}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates;->parseFrom(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$X509Certificates;
move-result-object v3
.line 182
invoke-virtual {v3}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates;->getCertificateCount()I
move-result v2
if-nez v2, :cond_5c
.line 183
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiData;
const-string v2, "No certificates provided in message: server config error"
invoke-direct {v1, v2}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiData;-><init>(Ljava/lang/String;)V
throw v1
:try_end_2e
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_1 .. :try_end_2e} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_1 .. :try_end_2e} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_1 .. :try_end_2e} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_1 .. :try_end_2e} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_1 .. :try_end_2e} :catch_125
.catch Ljava/security/InvalidKeyException; {:try_start_1 .. :try_end_2e} :catch_110
.catch Ljava/security/SignatureException; {:try_start_1 .. :try_end_2e} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_1 .. :try_end_2e} :catch_11e
.line 222
:catch_2e
move-exception v0
.line 224
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiData;
invoke-direct {v1, v0}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiData;-><init>(Ljava/lang/Exception;)V
throw v1
.line 176
:cond_35
:try_start_35
const-string v2, "x509+sha1"
invoke-virtual {v2, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_40
.line 177
const-string v1, "SHA1withRSA"
goto :goto_18
.line 179
:cond_40
new-instance v2, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiType;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Unsupported PKI type: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v2, v1}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$InvalidPkiType;-><init>(Ljava/lang/String;)V
throw v2
:try_end_55
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_35 .. :try_end_55} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_35 .. :try_end_55} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_35 .. :try_end_55} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_35 .. :try_end_55} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_35 .. :try_end_55} :catch_125
.catch Ljava/security/InvalidKeyException; {:try_start_35 .. :try_end_55} :catch_110
.catch Ljava/security/SignatureException; {:try_start_35 .. :try_end_55} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_35 .. :try_end_55} :catch_11e
.line 225
:catch_55
move-exception v0
.line 227
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
invoke-direct {v1, v0}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/Exception;)V
throw v1
.line 188
:cond_5c
:try_start_5c
const-string v2, "X.509"
invoke-static {v2}, Ljava/security/cert/CertificateFactory;->getInstance(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
move-result-object v4
.line 1088
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
:try_end_67
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_5c .. :try_end_67} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_5c .. :try_end_67} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_5c .. :try_end_67} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_5c .. :try_end_67} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_5c .. :try_end_67} :catch_125
.catch Ljava/security/InvalidKeyException; {:try_start_5c .. :try_end_67} :catch_110
.catch Ljava/security/SignatureException; {:try_start_5c .. :try_end_67} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_5c .. :try_end_67} :catch_11e
.line 190
:try_start_67
invoke-virtual {v3}, Lorg/bitcoin/protocols/payments/Protos$X509Certificates;->getCertificateList()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_6f
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_90
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
.line 191
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->newInput()Ljava/io/InputStream;
move-result-object v0
invoke-virtual {v4, v0}, Ljava/security/cert/CertificateFactory;->generateCertificate(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
move-result-object v0
check-cast v0, Ljava/security/cert/X509Certificate;
invoke-interface {v2, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_88
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_67 .. :try_end_88} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_67 .. :try_end_88} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_67 .. :try_end_88} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_67 .. :try_end_88} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_67 .. :try_end_88} :catch_fb
.catch Ljava/security/InvalidKeyException; {:try_start_67 .. :try_end_88} :catch_110
.catch Ljava/security/SignatureException; {:try_start_67 .. :try_end_88} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_67 .. :try_end_88} :catch_11e
goto :goto_6f
.line 228
:catch_89
move-exception v0
.line 230
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
.line 192
:cond_90
:try_start_90
invoke-virtual {v4, v2}, Ljava/security/cert/CertificateFactory;->generateCertPath(Ljava/util/List;)Ljava/security/cert/CertPath;
move-result-object v0
.line 195
new-instance v3, Ljava/security/cert/PKIXParameters;
invoke-direct {v3, p1}, Ljava/security/cert/PKIXParameters;-><init>(Ljava/security/KeyStore;)V
.line 197
const/4 v4, 0x0
invoke-virtual {v3, v4}, Ljava/security/cert/PKIXParameters;->setRevocationEnabled(Z)V
.line 200
const-string v4, "PKIX"
invoke-static {v4}, Ljava/security/cert/CertPathValidator;->getInstance(Ljava/lang/String;)Ljava/security/cert/CertPathValidator;
move-result-object v4
.line 201
invoke-virtual {v4, v0, v3}, Ljava/security/cert/CertPathValidator;->validate(Ljava/security/cert/CertPath;Ljava/security/cert/CertPathParameters;)Ljava/security/cert/CertPathValidatorResult;
move-result-object v0
check-cast v0, Ljava/security/cert/PKIXCertPathValidatorResult;
.line 202
invoke-virtual {v0}, Ljava/security/cert/PKIXCertPathValidatorResult;->getPublicKey()Ljava/security/PublicKey;
move-result-object v3
.line 204
invoke-static {v1}, Ljava/security/Signature;->getInstance(Ljava/lang/String;)Ljava/security/Signature;
move-result-object v1
.line 208
invoke-virtual {v1, v3}, Ljava/security/Signature;->initVerify(Ljava/security/PublicKey;)V
.line 209
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->toBuilder()Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
move-result-object v4
.line 210
sget-object v5, Lcom/google/protobuf/ByteString;->EMPTY:Lcom/google/protobuf/ByteString;
invoke-virtual {v4, v5}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->setSignature(Lcom/google/protobuf/ByteString;)Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;
.line 211
invoke-virtual {v4}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest$Builder;->build()Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;
move-result-object v4
invoke-virtual {v4}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->toByteArray()[B
move-result-object v4
invoke-virtual {v1, v4}, Ljava/security/Signature;->update([B)V
.line 212
invoke-virtual {p0}, Lorg/bitcoin/protocols/payments/Protos$PaymentRequest;->getSignature()Lcom/google/protobuf/ByteString;
move-result-object v4
invoke-virtual {v4}, Lcom/google/protobuf/ByteString;->toByteArray()[B
move-result-object v4
invoke-virtual {v1, v4}, Ljava/security/Signature;->verify([B)Z
move-result v1
if-nez v1, :cond_e5
.line 213
new-instance v0, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
const-string v1, "Invalid signature, this payment request is not valid."
invoke-direct {v0, v1}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_de
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_90 .. :try_end_de} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_90 .. :try_end_de} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_90 .. :try_end_de} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_90 .. :try_end_de} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_90 .. :try_end_de} :catch_fb
.catch Ljava/security/InvalidKeyException; {:try_start_90 .. :try_end_de} :catch_110
.catch Ljava/security/SignatureException; {:try_start_90 .. :try_end_de} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_90 .. :try_end_de} :catch_11e
.line 231
:catch_de
move-exception v0
.line 232
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
.line 216
:cond_e5
const/4 v1, 0x0
:try_start_e6
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/security/cert/X509Certificate;
.line 217
const/4 v4, 0x1
invoke-static {v1, v4}, Lorg/bitcoinj/crypto/X509Utils;->getDisplayNameFromCertificate(Ljava/security/cert/X509Certificate;Z)Ljava/lang/String;
move-result-object v4
.line 218
if-nez v4, :cond_103
.line 219
new-instance v0, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
const-string v1, "Could not extract name from certificate"
invoke-direct {v0, v1}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_fb
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_e6 .. :try_end_fb} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_e6 .. :try_end_fb} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_e6 .. :try_end_fb} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_e6 .. :try_end_fb} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_e6 .. :try_end_fb} :catch_fb
.catch Ljava/security/InvalidKeyException; {:try_start_e6 .. :try_end_fb} :catch_110
.catch Ljava/security/SignatureException; {:try_start_e6 .. :try_end_fb} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_e6 .. :try_end_fb} :catch_11e
.line 233
:catch_fb
move-exception v0
move-object v1, v2
.line 236
:goto_fd
new-instance v2, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
invoke-direct {v2, v0, v1}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/Exception;Ljava/util/List;)V
throw v2
.line 221
:cond_103
:try_start_103
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocol$PkiVerificationData;
invoke-virtual {v0}, Ljava/security/cert/PKIXCertPathValidatorResult;->getTrustAnchor()Ljava/security/cert/TrustAnchor;
move-result-object v0
const/4 v5, 0x0
invoke-direct {v1, v4, v3, v0, v5}, Lorg/bitcoinj/protocols/payments/PaymentProtocol$PkiVerificationData;-><init>(Ljava/lang/String;Ljava/security/PublicKey;Ljava/security/cert/TrustAnchor;Lorg/bitcoinj/protocols/payments/PaymentProtocol$1;)V
:try_end_10d
.catch Lcom/google/protobuf/InvalidProtocolBufferException; {:try_start_103 .. :try_end_10d} :catch_2e
.catch Ljava/security/cert/CertificateException; {:try_start_103 .. :try_end_10d} :catch_55
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_103 .. :try_end_10d} :catch_89
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_103 .. :try_end_10d} :catch_de
.catch Ljava/security/cert/CertPathValidatorException; {:try_start_103 .. :try_end_10d} :catch_fb
.catch Ljava/security/InvalidKeyException; {:try_start_103 .. :try_end_10d} :catch_110
.catch Ljava/security/SignatureException; {:try_start_103 .. :try_end_10d} :catch_117
.catch Ljava/security/KeyStoreException; {:try_start_103 .. :try_end_10d} :catch_11e
move-object v0, v1
goto/16 :goto_d
.line 237
:catch_110
move-exception v0
.line 239
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
invoke-direct {v1, v0}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/Exception;)V
throw v1
.line 240
:catch_117
move-exception v0
.line 242
new-instance v1, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;
invoke-direct {v1, v0}, Lorg/bitcoinj/protocols/payments/PaymentProtocolException$PkiVerificationException;-><init>(Ljava/lang/Exception;)V
throw v1
.line 243
:catch_11e
move-exception v0
.line 244
new-instance v1, Ljava/lang/RuntimeException;
invoke-direct {v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw v1
.line 233
:catch_125
move-exception v1
move-object v6, v1
move-object v1, v0
move-object v0, v6
goto :goto_fd
.end method