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