.class public final Lcom/amazon/device/iap/internal/b/d/d; .super Lcom/amazon/device/iap/internal/b/d/b; .source "SourceFile" # static fields .field private static final b:Ljava/lang/String; .field private static final c:Ljava/util/Date; # direct methods .method static constructor ()V .locals 3 .line 36 const-class v0, Lcom/amazon/device/iap/internal/b/d/d; invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String; move-result-object v0 sput-object v0, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 37 new-instance v0, Ljava/util/Date; const-wide/16 v1, 0x0 invoke-direct {v0, v1, v2}, Ljava/util/Date;->(J)V sput-object v0, Lcom/amazon/device/iap/internal/b/d/d;->c:Ljava/util/Date; return-void .end method .method public constructor (Lcom/amazon/device/iap/internal/b/e;)V .locals 2 const-string v0, "1.0" const/4 v1, 0x1 .line 46 invoke-direct {p0, p1, v0, v1}, Lcom/amazon/device/iap/internal/b/d/b;->(Lcom/amazon/device/iap/internal/b/e;Ljava/lang/String;Z)V return-void .end method # virtual methods .method public a(Lcom/amazon/venezia/command/SuccessResult;)Z .locals 11 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/Exception; } .end annotation const-string v0, "fail to verify receipt, requestId:" .line 52 invoke-interface {p1}, Lcom/amazon/venezia/command/SuccessResult;->getData()Ljava/util/Map; move-result-object p1 sget-object v1, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 53 new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "data: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v1, v2}, Lcom/amazon/device/iap/internal/util/e;->a(Ljava/lang/String;Ljava/lang/String;)V const-string v1, "userId" .line 55 invoke-interface {p1, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/lang/String; const-string v2, "requestId" .line 56 invoke-interface {p1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; const-string v2, "marketplace" .line 57 invoke-interface {p1, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; .line 58 new-instance v3, Ljava/util/ArrayList; invoke-direct {v3}, Ljava/util/ArrayList;->()V const-string v4, "receipts" .line 61 invoke-interface {p1, v4}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v4 check-cast v4, Ljava/lang/String; .line 62 new-instance v5, Lorg/json/JSONArray; invoke-direct {v5, v4}, Lorg/json/JSONArray;->(Ljava/lang/String;)V const/4 v4, 0x0 move v6, v4 .line 64 :goto_0 invoke-virtual {v5}, Lorg/json/JSONArray;->length()I move-result v7 const/4 v8, 0x0 if-ge v6, v7, :cond_1 .line 66 :try_start_0 invoke-virtual {v5, v6}, Lorg/json/JSONArray;->getJSONObject(I)Lorg/json/JSONObject; move-result-object v7 .line 69 invoke-static {v7, v1, v8}, Lcom/amazon/device/iap/internal/util/a;->a(Lorg/json/JSONObject;Ljava/lang/String;Ljava/lang/String;)Lcom/amazon/device/iap/model/Receipt; move-result-object v7 .line 70 invoke-interface {v3, v7}, Ljava/util/List;->add(Ljava/lang/Object;)Z .line 74 sget-object v8, Lcom/amazon/device/iap/model/ProductType;->ENTITLED:Lcom/amazon/device/iap/model/ProductType; invoke-virtual {v7}, Lcom/amazon/device/iap/model/Receipt;->getProductType()Lcom/amazon/device/iap/model/ProductType; move-result-object v9 if-ne v8, v9, :cond_0 .line 75 invoke-static {}, Lcom/amazon/device/iap/internal/c/c;->a()Lcom/amazon/device/iap/internal/c/c; move-result-object v8 invoke-virtual {v7}, Lcom/amazon/device/iap/model/Receipt;->getReceiptId()Ljava/lang/String; move-result-object v9 invoke-virtual {v7}, Lcom/amazon/device/iap/model/Receipt;->getSku()Ljava/lang/String; move-result-object v7 invoke-virtual {v8, v1, v9, v7}, Lcom/amazon/device/iap/internal/c/c;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V :try_end_0 .catch Lcom/amazon/device/iap/internal/b/a; {:try_start_0 .. :try_end_0} :catch_1 .catch Lcom/amazon/device/iap/internal/b/d; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 goto :goto_4 :catchall_0 move-exception v7 goto :goto_1 :catch_0 move-exception v7 goto :goto_2 :catch_1 move-exception v7 goto :goto_3 :goto_1 sget-object v8, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 84 new-instance v9, Ljava/lang/StringBuilder; invoke-direct {v9}, Ljava/lang/StringBuilder;->()V invoke-virtual {v9, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String; move-result-object v7 invoke-virtual {v9, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v8, v7}, Lcom/amazon/device/iap/internal/util/e;->b(Ljava/lang/String;Ljava/lang/String;)V goto :goto_4 :goto_2 sget-object v8, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 82 new-instance v9, Ljava/lang/StringBuilder; invoke-direct {v9}, Ljava/lang/StringBuilder;->()V invoke-virtual {v9, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Lcom/amazon/device/iap/internal/b/d;->a()Ljava/lang/String; move-result-object v7 invoke-virtual {v9, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v8, v7}, Lcom/amazon/device/iap/internal/util/e;->b(Ljava/lang/String;Ljava/lang/String;)V goto :goto_4 :goto_3 sget-object v8, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 80 new-instance v9, Ljava/lang/StringBuilder; invoke-direct {v9}, Ljava/lang/StringBuilder;->()V const-string v10, "fail to parse receipt, requestId:" invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Lcom/amazon/device/iap/internal/b/a;->a()Ljava/lang/String; move-result-object v7 invoke-virtual {v9, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v8, v7}, Lcom/amazon/device/iap/internal/util/e;->b(Ljava/lang/String;Ljava/lang/String;)V :cond_0 :goto_4 add-int/lit8 v6, v6, 0x1 goto :goto_0 :cond_1 const-string v0, "revocations" .line 88 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; .line 89 new-instance v5, Lorg/json/JSONArray; invoke-direct {v5, v0}, Lorg/json/JSONArray;->(Ljava/lang/String;)V .line 98 :goto_5 invoke-virtual {v5}, Lorg/json/JSONArray;->length()I move-result v0 if-ge v4, v0, :cond_2 .line 100 :try_start_1 invoke-virtual {v5, v4}, Lorg/json/JSONArray;->getString(I)Ljava/lang/String; move-result-object v0 .line 101 invoke-static {}, Lcom/amazon/device/iap/internal/c/c;->a()Lcom/amazon/device/iap/internal/c/c; move-result-object v6 invoke-virtual {v6, v1, v0}, Lcom/amazon/device/iap/internal/c/c;->a(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object v6 .line 102 new-instance v7, Lcom/amazon/device/iap/internal/model/ReceiptBuilder; invoke-direct {v7}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->()V invoke-virtual {v7, v0}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->setSku(Ljava/lang/String;)Lcom/amazon/device/iap/internal/model/ReceiptBuilder; move-result-object v0 sget-object v7, Lcom/amazon/device/iap/model/ProductType;->ENTITLED:Lcom/amazon/device/iap/model/ProductType; invoke-virtual {v0, v7}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->setProductType(Lcom/amazon/device/iap/model/ProductType;)Lcom/amazon/device/iap/internal/model/ReceiptBuilder; move-result-object v0 invoke-virtual {v0, v8}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->setPurchaseDate(Ljava/util/Date;)Lcom/amazon/device/iap/internal/model/ReceiptBuilder; move-result-object v0 sget-object v7, Lcom/amazon/device/iap/internal/b/d/d;->c:Ljava/util/Date; invoke-virtual {v0, v7}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->setCancelDate(Ljava/util/Date;)Lcom/amazon/device/iap/internal/model/ReceiptBuilder; move-result-object v0 invoke-virtual {v0, v6}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->setReceiptId(Ljava/lang/String;)Lcom/amazon/device/iap/internal/model/ReceiptBuilder; move-result-object v0 invoke-virtual {v0}, Lcom/amazon/device/iap/internal/model/ReceiptBuilder;->build()Lcom/amazon/device/iap/model/Receipt; move-result-object v0 .line 109 invoke-interface {v3, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z :try_end_1 .catch Lorg/json/JSONException; {:try_start_1 .. :try_end_1} :catch_2 goto :goto_6 :catch_2 sget-object v0, Lcom/amazon/device/iap/internal/b/d/d;->b:Ljava/lang/String; .line 111 new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "fail to parse JSON[" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v7, "] in \"" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; const-string v7, "\"" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/amazon/device/iap/internal/util/e;->b(Ljava/lang/String;Ljava/lang/String;)V :goto_6 add-int/lit8 v4, v4, 0x1 goto :goto_5 :cond_2 const-string v0, "cursor" .line 116 invoke-interface {p1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; const-string v4, "hasMore" .line 117 invoke-interface {p1, v4}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; const-string v4, "true" .line 118 invoke-virtual {v4, p1}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result p1 .line 120 invoke-virtual {p0}, Lcom/amazon/device/iap/internal/b/i;->b()Lcom/amazon/device/iap/internal/b/e; move-result-object v4 .line 121 new-instance v5, Lcom/amazon/device/iap/internal/model/UserDataBuilder; invoke-direct {v5}, Lcom/amazon/device/iap/internal/model/UserDataBuilder;->()V invoke-virtual {v5, v1}, Lcom/amazon/device/iap/internal/model/UserDataBuilder;->setUserId(Ljava/lang/String;)Lcom/amazon/device/iap/internal/model/UserDataBuilder; move-result-object v1 invoke-virtual {v1, v2}, Lcom/amazon/device/iap/internal/model/UserDataBuilder;->setMarketplace(Ljava/lang/String;)Lcom/amazon/device/iap/internal/model/UserDataBuilder; move-result-object v1 invoke-virtual {v1}, Lcom/amazon/device/iap/internal/model/UserDataBuilder;->build()Lcom/amazon/device/iap/model/UserData; move-result-object v1 .line 122 new-instance v2, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; invoke-direct {v2}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->()V invoke-virtual {v4}, Lcom/amazon/device/iap/internal/b/e;->c()Lcom/amazon/device/iap/model/RequestId; move-result-object v5 invoke-virtual {v2, v5}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->setRequestId(Lcom/amazon/device/iap/model/RequestId;)Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; move-result-object v2 sget-object v5, Lcom/amazon/device/iap/model/PurchaseUpdatesResponse$RequestStatus;->SUCCESSFUL:Lcom/amazon/device/iap/model/PurchaseUpdatesResponse$RequestStatus; invoke-virtual {v2, v5}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->setRequestStatus(Lcom/amazon/device/iap/model/PurchaseUpdatesResponse$RequestStatus;)Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; move-result-object v2 invoke-virtual {v2, v1}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->setUserData(Lcom/amazon/device/iap/model/UserData;)Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; move-result-object v1 invoke-virtual {v1, v3}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->setReceipts(Ljava/util/List;)Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; move-result-object v1 invoke-virtual {v1, p1}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->setHasMore(Z)Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder; move-result-object p1 invoke-virtual {p1}, Lcom/amazon/device/iap/internal/model/PurchaseUpdatesResponseBuilder;->build()Lcom/amazon/device/iap/model/PurchaseUpdatesResponse; move-result-object p1 .line 129 invoke-static {}, Lcom/amazon/device/iap/internal/c/a;->a()Lcom/amazon/device/iap/internal/c/a; move-result-object v1 invoke-virtual {p1}, Lcom/amazon/device/iap/model/PurchaseUpdatesResponse;->getUserData()Lcom/amazon/device/iap/model/UserData; move-result-object v2 invoke-virtual {v2}, Lcom/amazon/device/iap/model/UserData;->getUserId()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Lcom/amazon/device/iap/internal/c/a;->b(Ljava/lang/String;)Ljava/util/Set; move-result-object v1 .line 132 invoke-virtual {p1}, Lcom/amazon/device/iap/model/PurchaseUpdatesResponse;->getReceipts()Ljava/util/List; move-result-object v2 invoke-interface {v2, v1}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z .line 133 invoke-virtual {v4}, Lcom/amazon/device/iap/internal/b/e;->d()Lcom/amazon/device/iap/internal/b/h; move-result-object v1 invoke-virtual {v1, p1}, Lcom/amazon/device/iap/internal/b/h;->a(Ljava/lang/Object;)V .line 134 invoke-virtual {v4}, Lcom/amazon/device/iap/internal/b/e;->d()Lcom/amazon/device/iap/internal/b/h; move-result-object p1 const-string v1, "newCursor" invoke-virtual {p1, v1, v0}, Lcom/amazon/device/iap/internal/b/h;->a(Ljava/lang/String;Ljava/lang/Object;)V const/4 p1, 0x1 return p1 .end method