-
Notifications
You must be signed in to change notification settings - Fork 40
/
UnityIapDemoManager.cs
151 lines (106 loc) · 4.16 KB
/
UnityIapDemoManager.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
using UnityEngine;
#if UNITY_PURCHASING
using UnityEngine.Purchasing;
using UnityEngine.Purchasing.Extension;
#endif
public class UnityIapDemoManager : MonoBehaviour
#if UNITY_PURCHASING
, IStoreCallback
#endif
{
#if UNITY_PURCHASING
public static Action<string> IAPLog;
public static string lastPurchaseToken;
public ProductCollection products => throw new NotImplementedException();
public bool useTransactionLog { get => throw new NotImplementedException(); set => throw new NotImplementedException(); }
IStore iStore;
#region Singleton
public static UnityIapDemoManager Instance { get; private set; }
private void Singleton()
{
if (Instance != null && Instance != this)
{
Destroy(this);
}
else
{
Instance = this;
}
}
#endregion
void Awake()
{
Singleton();
Screen.orientation = ScreenOrientation.LandscapeLeft;
}
void Start()
{
SignIn();
var huaweiStore = HuaweiStore.GetInstance();
iStore = huaweiStore;
iStore.Initialize(this);
List<ProductDefinition> list = new List<ProductDefinition>();
var coins100 = new ProductDefinition("coins100", ProductType.Consumable);
var coins1000 = new ProductDefinition("coins1000", ProductType.Consumable);
var removeAds = new ProductDefinition("removeAds", ProductType.NonConsumable);
var premium = new ProductDefinition("premium", ProductType.Subscription);
list.Add(coins100);
list.Add(coins1000);
list.Add(removeAds);
list.Add(premium);
ReadOnlyCollection<ProductDefinition> products = new ReadOnlyCollection<ProductDefinition>(list);
iStore.RetrieveProducts(products);
huaweiStore.LoadOwnedConsumables();
huaweiStore.LoadOwnedNonConsumables();
huaweiStore.LoadOwnedSubscriptions();
}
public void BuyProduct(string productID, ProductType productType)
{
Debug.Log($"BuyProduct {productID} , {productType}");
var product = new ProductDefinition(productID, productType);
iStore.Purchase(product, $"payload {productID}");
}
public void OnSetupFailed(InitializationFailureReason reason)
{
Debug.Log($"OnSetupFailed , reason : {reason}");
}
public void OnProductsRetrieved(List<ProductDescription> products)
{
Debug.Log($"OnProductsRetrieved {products.Count}");
foreach (var item in products)
{
Debug.Log($"transactionId: {item.transactionId} , storeSpecificId: {item.storeSpecificId}, metadata: {item.metadata} , type: {item.type}");
var productDefinition = new ProductDefinition(item.storeSpecificId, item.storeSpecificId, item.type);
iStore.FinishTransaction(productDefinition, item.transactionId);
}
}
public void OnPurchaseSucceeded(string storeSpecificId, string receipt, string transactionIdentifier)
{
Debug.Log($"storeSpecificId {storeSpecificId} ,receipt {receipt} , transactionIdentifier {transactionIdentifier}");
var productDefinition = new ProductDefinition(storeSpecificId, storeSpecificId, HuaweiStore.CurrentProduct.type);
lastPurchaseToken = HuaweiStore.PurchaseTokenOfLastPurchase;
Debug.Log($"lastPurchaseToken {lastPurchaseToken}");
iStore.FinishTransaction(productDefinition, receipt);
}
public void OnAllPurchasesRetrieved(List<Product> purchasedProducts)
{
foreach (var item in purchasedProducts)
{
Debug.Log($"transactionID: {item.transactionID} , definition: {item.definition}, hasReceipt: {item.hasReceipt} , metadata: {item.metadata}");
}
}
public void OnPurchaseFailed(PurchaseFailureDescription desc)
{
Debug.Log($"message: {desc.message} ,productId: {desc.productId} ,reason: {desc.reason} ");
}
public void SignIn()
{
Debug.Log("SignIn");
HMSAccountKitManager.Instance.SignIn();
}
public void OnSetupFailed(InitializationFailureReason reason, string message)
{
Debug.Log($"OnSetupFailed , reason : {reason} , message : {message}");
}
#endif
}