in_app_purchase 1.0.3  in_app_purchase: ^1.0.3 copied to clipboard
in_app_purchase: ^1.0.3 copied to clipboard
A Flutter plugin for in-app purchases. Exposes APIs for making in-app purchases through the App Store and Google Play.
1.0.3 #
- Added a "Restore purchases" button to conform to Apple's StoreKit guidelines on restoring products;
- Corrected an error in a example snippet displayed in the README.md.
1.0.2 #
- Fix ignoring "autoConsume" param in "InAppPurchase.instance.buyConsumable".
1.0.1 #
- Migrate maven repository from jcenter to mavenCentral.
1.0.0 #
- Stable release of in_app_purchase plugin.
0.6.0+1 #
- Added a reference to the in-app purchase codelab in the README.md.
0.6.0 #
As part of implementing federated architecture and making the interface compatible for other platforms this version contains the following breaking changes:
- Changes to the platform agnostic interface:
- If you used InAppPurchaseConnection.instanceto access generic In App Purchase APIs, please useInAppPurchase.instanceinstead;
- The InAppPurchaseConnection.purchaseUpdatedStreamhas been renamed toInAppPurchase.purchaseStream;
- The InAppPurchaseConnection.queryPastPurchasesmethod has been removed. Instead, you should useInAppPurchase.restorePurchases. This method emits each restored purchase on theInAppPurchase.purchaseStream, thePurchaseDetailsobject will be marked with astatusofPurchaseStatus.restored;
- The InAppPurchase.completePurchasemethod no longer returns an instanceBillingWrapperResultclass (which was Android specific). Instead it will return a completedFutureif the method executed successfully, in case of errors it will complete with anInAppPurchaseExceptiondescribing the error.
 
- If you used 
- Android specific changes:
- The Android specific InAppPurchaseConnection.consumePurchaseandInAppPurchaseConnection.enablePendingPurchasesmethods have been removed from the platform agnostic interface and moved to the Android specificInAppPurchaseAndroidPlatformAdditionclass:- InAppPurchaseAndroidPlatformAddition.enablePendingPurchasesis a static method that should be called when initializing your App. Access the method like this:- InAppPurchaseAndroidPlatformAddition.enablePendingPurchases()(make sure to add the following import:- import 'package:in_app_purchase_android/in_app_purchase_android.dart';);
- To use the InAppPurchaseAndroidPlatformAddition.consumePurchasemethod, acquire an instance using theInAppPurchase.getPlatformAdditionmethod. For example:
 
 // Acquire the InAppPurchaseAndroidPlatformAddition instance. InAppPurchaseAndroidPlatformAddition androidAddition = InAppPurchase.instance.getPlatformAddition<InAppPurchaseAndroidPlatformAddition>(); // Consume an Android purchase. BillingResultWrapper billingResult = await androidAddition.consumePurchase(purchase);- The billing_client_wrappers have been moved into the in_app_purchase_android package. They are still available through the in_app_purchase plugin but to use them it is necessary to import the correct package when using them: import 'package:in_app_purchase_android/billing_client_wrappers.dart';;
 
- The Android specific 
- iOS specific changes:
- The iOS specific methods InAppPurchaseConnection.presentCodeRedemptionSheetandInAppPurchaseConnection.refreshPurchaseVerificationDatamethods have been removed from the platform agnostic interface and moved into the iOS specificInAppPurchaseIosPlatformAdditionclass. To use them acquire an instance through theInAppPurchase.getPlatformAdditionmethod like so:
 // Acquire the InAppPurchaseIosPlatformAddition instance. InAppPurchaseIosPlatformAddition iosAddition = InAppPurchase.instance.getPlatformAddition<InAppPurchaseIosPlatformAddition>(); // Present the code redemption sheet. await iosAddition.presentCodeRedemptionSheet(); // Refresh purchase verification data. PurchaseVerificationData? verificationData = await iosAddition.refreshPurchaseVerificationData();- The store_kit_wrappers have been moved into the in_app_purchase_ios package. They are still available in the in_app_purchase plugin, but to use them it is necessary to import the correct package when using them: import 'package:in_app_purchase_ios/store_kit_wrappers.dart';;
- Update the minimum supported Flutter version to 1.20.0.
 
- The iOS specific methods 
0.5.2 #
- Added rawPriceandcurrencyCodeto the ProductDetails model.
0.5.1+3 #
- Configured the iOS example App to make use of StoreKit Testing on iOS 14 and higher.
0.5.1+2 #
- Update README to provide a better instruction of the plugin.
0.5.1+1 #
- Fix error message when trying to consume purchase on iOS.
0.5.1 #
- [iOS] Introduce SKPaymentQueueWrapper.presentCodeRedemptionSheet
0.5.0 #
- Migrate to Google Billing Library 3.0
- Add obfuscatedProfileId,purchaseTokenin [BillingClientWrapper.launchBillingFlow].
- Breaking Change
- Removed developerPayloadin [BillingClientWrapper.acknowledgePurchase], [BillingClientWrapper.consumeAsync], [InAppPurchaseConnection.completePurchase], [InAppPurchaseConnection.consumePurchase].
- Removed isRewardedfrom [SkuDetailsWrapper].
- [SkuDetailsWrapper.introductoryPriceCycles] now returns intinstead ofString.
- Above breaking changes are inline with the breaking changes introduced in Google Play Billing 3.0 release.
- Additional information on some the changes:
 
- Removed 
 
- Add 
0.4.1 #
- Support InApp subscription upgrade/downgrade.
0.4.0 #
- Migrate to nullsafety.
- Deprecate sandboxTesting, introducesimulatesAskToBuyInSandbox.
- Breaking Change:
- Removed callbackChannelinchannels.dart, see https://github.com/flutter/flutter/issues/69225.
 
- Removed 
0.3.5+2 #
- Migrate deprecated references.
0.3.5+1 #
- Update the example app: remove the deprecated RaisedButtonandFlatButtonwidgets.
0.3.5 #
- [Android] Fixed: added support for the SERVICE_TIMEOUT (-3) response code.
0.3.4+17 #
- Update Flutter SDK constraint.
0.3.4+16 #
- Add Dartdocs to all public APIs.
0.3.4+15 #
- Update android compileSdkVersion to 29.
0.3.4+14 #
- Add test target to iOS example app Podfile
0.3.4+13 #
- Android Code Inspection and Clean up.
0.3.4+12 #
- [iOS] Fixed: finishing purchases upon payment dialog cancellation.
0.3.4+11 #
- [iOS] Fixed: crash when sending null for simulatesAskToBuyInSandbox parameter.
0.3.4+10 #
- Fixed typo 'verity' for 'verify'.
0.3.4+9 #
- [iOS] Fixed: purchase dialog not showing always.
- [iOS] Fixed: completing purchases could fail.
- [iOS] Fixed: restorePurchases caused hang (call never returned).
0.3.4+8 #
- [iOS] Fixed: purchase dialog not showing always.
- [iOS] Fixed: completing purchases could fail.
- [iOS] Fixed: restorePurchases caused hang (call never returned).
0.3.4+7 #
- iOS: Fix typo of the simulatesAskToBuyInSandboxkey.
0.3.4+6 #
- iOS: Fix the bug that prevent restored subscription transactions from being completed
0.3.4+5 #
- Added necessary README docs for getting started with Android.
0.3.4+4 #
- Update package:e2e -> package:integration_test
0.3.4+3 #
- Fixed typo 'manuelly' for 'manually'.
0.3.4+2 #
- Update package:e2e reference to use the local version in the flutter/plugins repository.
0.3.4+1 #
- iOS: Fix the bug that SKPaymentQueueWrapper.transactionsdoesn't return all transactions.
- iOS: Fix the app crashes  if InAppPurchaseConnection.instanceis called in themain().
0.3.4 #
- Expose SKError code to client apps.
0.3.3+2 #
- Post-v2 Android embedding cleanups.
0.3.3+1 #
- Update documentations for InAppPurchase.completePurchaseand update README.
0.3.3 #
- Introduce SKPaymentQueueWrapper.transactions.
0.3.2+2 #
- Fix CocoaPods podspec lint warnings.
0.3.2+1 #
- iOS: Fix only transactions with SKPaymentTransactionStatePurchased and SKPaymentTransactionStateFailed can be finished.
- iOS: Only one pending transaction of a given product is allowed.
0.3.2 #
- Remove Android dependencies fallback.
- Require Flutter SDK 1.12.13+hotfix.5 or greater.
0.3.1+2 #
- Fix potential casting crash on Android v1 embedding when registering life cycle callbacks.
- Remove hard-coded legacy xcode build setting.
0.3.1+1 #
- Add pedanticto dev_dependency.
0.3.1 #
- Android: Fix a bug where the BillingClientis disconnected when app goes to the background.
- Android: Make sure the BillingClientobject is disconnected before the activity is destroyed.
- Android: Fix minor compiler warning.
- Fix typo in CHANGELOG.
0.3.0+3 #
- Fix pendingCompletePurchase flag status to allow to complete purchases.
0.3.0+2 #
- Update te example app to avoid using deprecated api.
0.3.0+1 #
- Fixing usage example. No functional changes.
0.3.0 #
- Migrate the Google Play Libraryto 2.0.3.- Introduce a new class BillingResultWrapperwhich contains a detailed result of a BillingClient operation.- [Breaking Change]:  All the BillingClient methods that previously return a BillingResponsenow return aBillingResultWrapper, including:launchBillingFlow,startConnectionandconsumeAsync.
- [Breaking Change]:  The SkuDetailsResponseWrappernow contains abillingResultfield in place ofbillingResponsefield.
- A billingResultfield is added to thePurchasesResultWrapper.
 
- [Breaking Change]:  All the BillingClient methods that previously return a 
- Other Updates to the "billing_client_wrappers":
- Updates to the PurchaseWrapper: AdddeveloperPayload,purchaseStateandisAcknowledgedfields.
- Updates to the SkuDetailsWrapper: AddoriginalPriceandoriginalPriceAmountMicrosfields.
- [Breaking Change]: The BillingClient.queryPurchaseHistoryis updated to return aPurchasesHistoryResult, which contains a list ofPurchaseHistoryRecordWrapperinstead ofPurchaseWrapper. APurchaseHistoryRecordWrapperobject has the same fields and values as APurchaseWrapperobject, except that aPurchaseHistoryRecordWrapperobject does not containisAutoRenewing,orderIdandpackageName.
- Add a new BillingClient.acknowledgePurchaseAPI. Starting from this version, the developer has to acknowledge any purchase on Android using this API within 3 days of purchase, or the user will be refunded. Note that if a product is "consumed" viaBillingClient.consumeAsync, it is implicitly acknowledged.
- [Breaking Change]:  Added enablePendingPurchasesinBillingClientWrapper. The application has to call this method before callingBillingClientWrapper.startConnection. See enablePendingPurchases for more information.
 
- Updates to the 
- Updates to the "InAppPurchaseConnection":
- [Breaking Change]: InAppPurchaseConnection.completePurchasenow returns aFuture<BillingResultWrapper>instead ofFuture<void>. A new optional parameter{String developerPayload}has also been added to the API. On Android, this API does not throw an exception anymore, it instead acknowledge the purchase. If a purchase is not completed within 3 days on Android, the user will be refunded.
- [Breaking Change]: InAppPurchaseConnection.consumePurchasenow returns aFuture<BillingResultWrapper>instead ofFuture<BillingResponse>. A new optional parameter{String developerPayload}has also been added to the API.
- A new boolean field pendingCompletePurchasehas been added to thePurchaseDetailsclass. Which can be used as an indicator of whether to callInAppPurchaseConnection.completePurchaseon the purchase.
- [Breaking Change]:  Added enablePendingPurchasesinInAppPurchaseConnection. The application has to call this method when initializing theInAppPurchaseConnectionon Android. See enablePendingPurchases for more information.
 
- [Breaking Change]: 
- Misc: Some documentation updates reflecting the BillingClientmigration and some documentation fixes.
- Refer to Google Play Billing Library Release Note for a detailed information on the update.
 
- Introduce a new class 
0.2.2+6 #
- Correct a comment.
0.2.2+5 #
- Update version of json_annotation to ^3.0.0 and json_serializable to ^3.2.0. Resolve conflicts with other packages e.g. flutter_tools from sdk.
0.2.2+4 #
- Remove the deprecated author:field from pubspec.yaml
- Migrate the plugin to the pubspec platforms manifest.
- Require Flutter SDK 1.10.0 or greater.
0.2.2+3 #
- Fix failing pedantic lints. None of these fixes should have any change in functionality.
0.2.2+2 #
- Include lifecycle dependency as a compileOnly one on Android to resolve potential version conflicts with other transitive libraries.
0.2.2+1 #
- Android: Use android.arch.lifecycle instead of androidx.lifecycle:lifecycle in build.gradleto support apps that has not been migrated to AndroidX.
0.2.2 #
- Support the v2 Android embedder.
- Update to AndroidX.
- Migrate to using the new e2e test binding.
- Add a e2e test.
0.2.1+5 #
- Define clang module for iOS.
- Fix iOS build warning.
0.2.1+4 #
- Update and migrate iOS example project.
0.2.1+3 #
- Android : Improved testability.
0.2.1+2 #
- Android: Require a non-null Activity to use the launchBillingFlowmethod.
0.2.1+1 #
- Remove skipped driver test.
0.2.1 #
- iOS: Add currencyCode to priceLocale on productDetails.
0.2.0+8 #
- Add dependency on androidx.annotation:annotation:1.0.0.
0.2.0+7 #
- Make Gradle version compatible with the Android Gradle plugin version.
0.2.0+6 #
- Add missing hashCodeimplementations.
0.2.0+5 #
- iOS: Support unsupported UserInfo value types on NSError.
0.2.0+4 #
- Fixed code error in README.mdand adjusted links to work on Pub.
0.2.0+3 #
- Update the README.mdso that the code samples compile with the latest Flutter/Dart version.
0.2.0+2 #
- Fix a google_play_connection purchase update listener regression introduced in 0.2.0+1.
0.2.0+1 #
- Fix an issue the type is not casted before passing to PurchasesResultWrapper.fromJson.
0.2.0 #
- [Breaking Change] Rename 'PurchaseError' to 'IAPError'.
- [Breaking Change] Rename 'PurchaseSource' to 'IAPSource'.
0.1.1+3 #
- Expanded description in pubspec.yamland fixed typo inREADME.md.
0.1.1+2 #
- Add missing template type parameter to invokeMethodcalls.
- Bump minimum Flutter version to 1.5.0.
- Replace invokeMethod with invokeMapMethod wherever necessary.
0.1.1+1 #
- Make AdditionalSteps(Used in the unit test) a void function.
0.1.1 #
- Some error messages from iOS are slightly changed.
- ProductDetailsResponsereturned by- queryProductDetails()now contains an- PurchaseErrorobject that represents any error that might occurred during the request.
- If the device is not connected to the internet, queryPastPurchases()on iOS now have the error stored in the response instead of throwing.
- Clean up minor iOS warning.
- Example app shows how to handle error when calling queryProductDetails()andqueryProductDetails().
0.1.0+4 #
- Change the buymethods to returnFuture<bool>instead ofvoidin order to propagatelaunchBillingFlowfailures up throughgoogle_play_connection.
0.1.0+3 #
- Guard against multiple onSetupFinished() calls.
0.1.0+2 #
- Fix bug where error only purchases updates weren't propagated correctly in
google_play_connection.dart.
0.1.0+1 #
- Add more consumable handling to the example app.
0.1.0 #
Beta release.
- Ability to list products, load previous purchases, and make purchases.
- Simplified Dart API that's been unified for ease of use.
- Platform-specific APIs more directly exposing StoreKitandBillingClient.
Includes:
- 5ba657dc [in_app_purchase] Remove extraneous download logic (#1560)
- 01bb8796 [in_app_purchase] Minor doc updates (#1555)
- 1a4d493f [in_app_purchase] Only fetch owned purchases (#1540)
- d63c51cf [in_app_purchase] Add auto-consume errors to PurchaseDetails (#1537)
- 959da97f [in_app_purchase] Minor doc updates (#1536)
- b82ae1a6 [in_app_purchase] Rename the unified API (#1517)
- d1ad723a [in_app_purchase]remove SKDownloadWrapper and related code. (#1474)
- 7c1e8b8a [in_app_purchase]make payment unified APIs (#1421)
- 80233db6 [in_app_purchase] Add references to the original object for PurchaseDetails and ProductDetails (#1448)
- 8c180f0d [in_app_purchase]load purchase (#1380)
- e9f141bc [in_app_purchase] Iap refactor (#1381)
- d3b3d60c add driver test command to cirrus (#1342)
- aee12523 [in_app_purchase] refactoring and tests (#1322)
- 6d7b4592 [in_app_purchase] Adds Dart BillingClient APIs for loading purchases (#1286)
- 5567a9c8 [in_app_purchase]retrieve receipt (#1303)
- 3475f1b7 [in_app_purchase]restore purchases (#1299)
- a533148d [in_app_purchase] payment queue dart ios (#1249)
- 10030840 [in_app_purchase] Minor bugfixes and code cleanup (#1284)
- 347f508d [in_app_purchase] Fix CI formatting errors. (#1281)
- fad02d87 [in_app_purchase] Java API for querying purchases (#1259)
- bc501915 [In_app_purchase]SKProduct related fixes (#1252)
- f92ba3a1 IAP make payment objc (#1231)
- 62b82522 [IAP] Add the Dart API for launchBillingFlow (#1232)
- b40a4acf [IAP] Add Java call for launchBillingFlow (#1230)
- 4ff06cd1 [In_app_purchase]remove categories (#1222)
- 0e72ca56 [In_app_purchase]fix requesthandler crash (#1199)
- 81dff2be Iap getproductlist basic draft (#1169)
- db139b28 Iap iOS add payment dart wrappers (#1178)
- 2e5fbb9b Fix the param map passed down to the platform channel when calling querySkuDetails (#1194)
- 4a84bac1 Mark some packages as unpublishable (#1193)
- 51696552 Add a gradle warning to the AndroidX plugins (#1138)
- 832ab832 Iap add payment objc translators (#1172)
- d0e615cf Revert "IAP add payment translators in objc (#1126)" (#1171)
- 09a5a36e IAP add payment translators in objc (#1126)
- a100fbf9 Expose nslocale and expose currencySymbol instead of currencyCode to match android (#1162)
- 1c982efd Using json serializer for skproduct wrapper and related classes (#1147)
- 3039a261 Iap productlist ios (#1068)
- 2a1593da [IAP] Update dev deps to match flutter_driver (#1118)
- 9f87cbe5 [IAP] Update README (#1112)
- 59e84d85 Migrate independent plugins to AndroidX (#1103)
- a027ccd6 [IAP] Generate boilerplate serializers (#1090)
- 909cf1c2 [IAP] Fetch SkuDetails from Google Play (#1084)
- 6bbaa7e5 [IAP] Add missing license headers (#1083)
- 5347e877 [IAP] Clean up Dart unit tests (#1082)
- fe03e407 [IAP] Check if the payment processor is available (#1057)
- 43ee28cf Fix Manifest versionCode not found(#1076)
- 4d702ad7 Supress strong_mode_implicit_dynamic_methodforinvokeMethodcalls. (#1065)
- 809ccde7 Doc and build script updates to the IAP plugin (#1024)
- 052b71a9 Update the IAP README (#933)
- 54f9c4e2 Upgrade Android Gradle Plugin to 3.2.1 (#916)
- ced3e99d Set all gradle-wrapper versions to 4.10.2 (#915)
- eaa1388b Reconfigure Cirrus to use clang 7 (#905)
- 9b153920 Update gradle dependencies. (#881)
- 1aef7d92 Enable lint unnecessary_new (#701)
0.0.2 #
- Added missing flutter_test package dependency.
- Added missing flutter version requirements.
0.0.1 #
- Initial release.