Expand description
§storekit-rs
Safe Rust bindings for Apple’s StoreKit framework on macOS.
Status: v0.3.0 adds an
async_apimodule gated on--features async, wrapping StoreKit 2’s Swift async APIs as RustFutures viadoom_fish_utils::completion.
§Quick start
use storekit::prelude::*;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let products = Product::products_for(["com.example.pro.monthly"])?;
for product in products {
println!("{} — {}", product.display_name, product.display_price);
}
println!("payments enabled: {}", AppStore::can_make_payments()?);
Ok(())
}§Highlights
Product::products_for(...),Product::purchase(...),Product::purchase_in_window(...),Product::latest_transaction(), andProduct::current_entitlements()- Product formatting/localization helpers expose
StoreKitformat styles,SubscriptionPeriodconvenience constructors, and enum/unitlocalized_description()helpers PurchaseOptioncovers quantity, app-account tokens, custom payloads, promotional offers, win-back offers, and storefront-change policiesTransactionexposesall,current_entitlements,updates,unfinished, filtered product streams,latest_for,current_entitlement_for, verification, finishing, refund helpers, and advanced-commerce infoSubscriptionInfo::status_for(...),status_for_transaction(...),SubscriptionStatus::updates(), andSubscriptionStatus::all()surface renewal state plus status streamsPurchaseIntent::intents()andExternalPurchase{,Link,CustomLink}cover the newerStoreKitpurchase-intent and regulatory-link familiesAppStorenow includes merchandising presentation, age-rating lookups, and advanced-commerce product purchase supportStoreKitError::typed()recovers typedStoreKit, purchase, refund-request, and invalid-request framework errorsStorefront::current()andStorefront::updates()wrap theStoreKitstorefront APIsAppTransaction::shared()andAppTransaction::refresh()expose app-level verification resultsReceiptValidatorreads the local app receipt and decodes JWS payloads without publishing or mutating store stateStoreContext::current()summarizes bundle, receipt, payment, and device-verification context for headless tooling
§Examples
The crate ships with numbered examples for each logical area:
01_product_lookup02_transaction_stream03_app_store_context04_storefront_current05_subscription_types06_subscription_info_status07_refund_request08_receipt_validator09_message_support10_app_transaction11_store_context12_renewal_info13_renewal_state14_purchase_option15_verification_result16_purchase_intent17_external_purchase18_advanced_commerce19_typed_errors20_async_products(requires--features async)21_async_app_transaction(requires--features async)22_async_storefront(requires--features async)
Run them all with:
for ex in examples/*.rs; do cargo run --example "$(basename "$ex" .rs)"; done§Async API
Enable the async feature to access StoreKit 2’s async Swift APIs as standard Rust Futures:
[dependencies]
storekit = { version = "0.3", features = ["async"] }
pollster = "0.3" # or any async runtimeuse storekit::async_api::AsyncProducts;
fn main() {
let products = pollster::block_on(async {
AsyncProducts::fetch(["com.example.pro"])
.expect("invalid identifier")
.await
});
println!("{:?}", products);
}The following async types are available: [AsyncProducts], [AsyncPurchase], [AsyncAppStore], [AsyncAppTransaction], [AsyncStorefront].
§Notes
StoreKit.Messageis unavailable on macOS, so the message module reportsNotSupportedthere.- Refund, review, and offer-code presentation helpers still require an
NSViewController-backed window; headless callers getNotSupportedinstead of hanging. - Window-based purchase and merchandising APIs accept caller-owned
NSWindowHandlevalues when the host app has anAppKitwindow to lend toStoreKit. - The crate does not publish or call
cargo publish; release tagging is separate from drip-publisher rollout.
§License
Licensed under either of Apache-2.0 or MIT at your option.
Re-exports§
pub use advanced_commerce::AdvancedCommerceProduct;pub use advanced_commerce::AdvancedCommercePurchaseOption;pub use advanced_commerce::AppStoreMerchandisingKind;pub use advanced_commerce::AppStoreMerchandisingPresentationResult;pub use advanced_commerce::RenewalInfoAdvancedCommerceInfo;pub use advanced_commerce::RenewalInfoAdvancedCommerceItem;pub use advanced_commerce::RenewalInfoAdvancedCommercePriceIncreaseInfo;pub use advanced_commerce::RenewalInfoAdvancedCommercePriceIncreaseStatus;pub use advanced_commerce::TransactionAdvancedCommerceInfo;pub use advanced_commerce::TransactionAdvancedCommerceItem;pub use advanced_commerce::TransactionAdvancedCommerceItemDetails;pub use advanced_commerce::TransactionAdvancedCommerceOffer;pub use advanced_commerce::TransactionAdvancedCommerceOfferReason;pub use advanced_commerce::TransactionAdvancedCommerceRefund;pub use advanced_commerce::TransactionAdvancedCommerceRefundReason;pub use advanced_commerce::TransactionAdvancedCommerceRefundType;pub use app_store::AppStore;pub use app_store::AppStoreEnvironment;pub use app_store::AppStorePlatform;pub use app_transaction::AppTransaction;pub use error::InvalidRequestError;pub use error::ProductPurchaseError;pub use error::ProductPurchaseErrorCode;pub use error::RefundRequestError;pub use error::RefundRequestErrorCode;pub use error::StoreKitApiError;pub use error::StoreKitApiErrorCode;pub use error::StoreKitError;pub use error::StoreKitFrameworkError;pub use error::TypedStoreKitError;pub use error::VerificationErrorCode;pub use error::VerificationFailure;pub use external_purchase::ExternalPurchase;pub use external_purchase::ExternalPurchaseCustomLink;pub use external_purchase::ExternalPurchaseCustomLinkNoticeResult;pub use external_purchase::ExternalPurchaseCustomLinkNoticeType;pub use external_purchase::ExternalPurchaseCustomLinkToken;pub use external_purchase::ExternalPurchaseLink;pub use external_purchase::ExternalPurchaseNoticeResult;pub use message::Message;pub use message::MessageReason;pub use message::MessageStream;pub use product::Product;pub use product::ProductType;pub use purchase_intent::PurchaseIntent;pub use purchase_intent::PurchaseIntentStream;pub use purchase_option::PurchaseOption;pub use purchase_option::PurchaseResult;pub use receipt_validator::AppReceipt;pub use receipt_validator::ReceiptValidator;pub use refund::Refund;pub use refund::RefundRequestStatus;pub use renewal_info::ExpirationReason;pub use renewal_info::PriceIncreaseStatus;pub use renewal_info::RenewalInfo;pub use renewal_state::RenewalState;pub use store_context::StoreContext;pub use storefront::Storefront;pub use storefront::StorefrontStream;pub use subscription::SubscriptionOffer;pub use subscription::SubscriptionOfferType;pub use subscription::SubscriptionPaymentMode;pub use subscription::SubscriptionPeriod;pub use subscription::SubscriptionPeriodUnit;pub use subscription_info::SubscriptionInfo;pub use subscription_info::SubscriptionStatus;pub use transaction::OfferPaymentMode;pub use transaction::OfferType;pub use transaction::OwnershipType;pub use transaction::RevocationReason;pub use transaction::Transaction;pub use transaction::TransactionData;pub use transaction::TransactionOffer;pub use transaction::TransactionReason;pub use transaction::TransactionStream;pub use verification_result::VerificationMetadata;pub use verification_result::VerificationResult;pub use window::NSWindowHandle;
Modules§
- advanced_
commerce - app_
store - app_
transaction - async_
api async - Async API for
StoreKit— Tier 1 Future wrappers. - error
- external_
purchase - message
- prelude
- Common imports.
- product
- purchase_
intent - purchase_
option - receipt_
validator - refund
- renewal_
info - renewal_
state - store_
context - storefront
- subscription
- subscription_
info - transaction
- verification_
result - window