Shopify’s Mobile Buy SDK makes it simple to sell physical products inside your mobile app. With a few lines of code, you can connect your app with the Shopify platform and let your users buy your products using Apple Pay or their credit card.
Official documentation can be found on the Mobile Buy SDK for iOS page.
API docs (.docset
) can be generated with the Documentation
scheme or viewed online at Cocoadocs: http://cocoadocs.org/docsets/Mobile-Buy-SDK/.
The SDK includes a pre-compiled [.docset](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK/docs/com.shopify.Mobile-Buy-SDK.docset) that can be used in API documentation browser apps such as Dash.
- Drag the
Mobile Buy SDK.xcodeproj
into your existing project - Add the
Buy
target as aTarget Dependancy
in theBuild Phases
of your project's target - Add the
Buy
(second target on the list is the Dynamic framework) target in theEmbedded Binaries
section inBuild Phases
See the [Sample Apps](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/) for an example of Dynamic Framework usage.
If you would like to not include the Mobile Buy SDK Project within your existing project, you can link directly to the Buy.framework
.
- Open the
Mobile Buy SDK.xcodeproj
and build theStatic Universal Framework
scheme - Drag the
Buy.framework
that was just created fromMobile Buy SDK Sample Apps
into theLinked Frameworks and Libraries
section for the target you want to add the framework to. Check Copy items if needed so the framework is copied to your project - In the
Build Settings
tab, add-all_load
toOther Linker Flags
Add the following line to your podfile:
pod "Mobile-Buy-SDK"
Then run pod install
#import "Buy.h"
Add the following line to your Cartfile
github "Shopify/mobile-buy-sdk-ios"
Then run carthage update
Import the module
@import Buy;
Initialize the BUYClient
with your credentials from the Mobile App Channel
BUYClient *client = [[BUYClient alloc] initWithShopDomain:@"yourshop.myshopify.com"
apiKey:@"aaaaaaaaaaaaaaaaaa"
channelId:@"99999"];
// Fetch your products
[self.client getProductsPage:1 completion:^(NSArray *products, NSUInteger page, BOOL reachedEnd, NSError *error) {
if (error) {
NSLog(@"Error retrieving products: %@", error.userInfo);
} else {
for (BUYProduct *product in products) {
NSLog(@"%@", product.title);
}
}
}];
Consult the Usage Section of the Integration Guide on how to create a cart, and checkout with the SDK.
Clone this repo or download as .zip and open Mobile Buy SDK.xcodeproj
.
The workspace includes the Mobile Buy SDK project.
The Mobile Buy SDK includes a number of targets and schemes:
-
Buy: This is the Mobile Buy SDK dynamic framework. Please refer to the installation section above
-
Buy Static (target only): This is the Mobile Buy SDK static framework. This build is based on the current build configuration. To build a universal framework that can run on a device and on the Simulator and to be included in your app, please refer to the
Static Universal Framework
target below -
Static Universal Framework: This builds a static framework from the
Buy Static
target using thebuild_universal.sh
script in theStatic Universal Framework
target and copies the built framework in the/Mobile Buy SDK Sample Apps
folder. This is a fat binary that includes arm and i386 slices. Build this target if you have made any changes to the framework that you want to test with the sample apps as the sample apps do not build the framework directly but embed the already built framework -
Mobile Buy SDK Tests: Tests for the Mobile Buy SDK framework. See instructions below
-
Documentation: This generates appledoc documentation for the framework
The repo includes 3 sample apps. Each sample apps embeds the dynamic framework and includes readme files with more information:
- [Advanced Sample App](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/Sample App Advanced/README.md)
- [Swift Sample App](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/Sample App Swift/README.md)
- [Web Sample App](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/Sample App Web/README.md)
We suggest you take a look at the Advanced Sample App and test your shop with the sample app before you begin. If you run into any issues, the Advanced Sample App is also a great resource for debugging integration issues and checkout.
The SDK includes an easy-to-use product view to make selling simple in any app. The BUYProductViewController
displays any product, it's images, price and details and includes a variant selection flow. It will even handle Apple Pay and web checkout automatically:
You can also theme the BUYProductViewController
to better match your app and products being displayed:
The [Advanced Sample App](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/Sample App Advanced/) includes a demo of the BUYProductViewController
. Documentation on how to use the BUYProductViewController
is also available [here](https://github.com/Shopify/mobile-buy-sdk-ios/tree/master/Mobile Buy SDK Sample Apps/Sample App Advanced/PRODUCT_VIEW_README.md).
To run the Mobile Buy SDK integration tests against an actual shop, you will need a Shopify shop that is publicly accessible (not password protected). Please note that the integration tests will create an order on that shop. This is to validate that the SDK works properly with Shopify. Modify the test_shop_data.json file to contain your shop's credentials and the required product IDs, gift cards, and discounts as necessary.
If the credentials in the test_shop_data.json are empty, running the integration tests will use using mocked respoonses. The mocked responses are defined in mocked_responses.json. Do not check in credentials in this file.
Alternatively, you can edit the Mobile Buy SDK Tests
scheme and add the following arguments to the Environment Variables:
shop_domain
: Your shop's domain, for example:abetterlookingshop.myshopify.com
api_key
: The API provided when setting up the Mobile App channel on Shopify Admin: https://your_shop_id.myshopify.com/admin/mobile_app/integrationchannel_id
: The Channel ID provided with the API Key abovegift_card_code_11
,gift_card_code_25
,gift_card_code_50
: Three valid Gift Card codes for your shopexpired_gift_card_code
: An expired Gift Card codeexpired_gift_card_id
: The ID for the expired Gift Cardproduct_ids_comma_separated
: a comma seperated list of product IDs (2 is suitable) to use for the cart
We welcome contributions. Follow the steps in CONTRIBUTING file
The Mobile Buy SDK is provided under an MIT Licence. See the LICENSE file