ZTCoreKit SDK for iOS
The ZTCoreKit for iOS provides a library and documentation for developers to build connected mobile applications using Zhortech services and modules.
TOC
INSTALLATION
To get started with the ZTCoreKit SDK for iOS, check out the Developer Guide for iOS. You can set up the SDK and start building a new project, or you integrate the SDK in an existing project. You can also run the samples to get a sense of how the SDK works.
To use the ZTCoreKit SDK for iOS, you will need the following installed on your development machine:
- Xcode 11.0 or later
- iOS 13 or later
Include the SDK for iOS in an Existing Application
There is example project example applications which showcase how to use the ZTCoreKit SDK for iOS. Please note that the code in these sample applications is not of production quality.
There are several ways to integrate the ZTCoreKit Mobile SDK for iOS into your own project:
You should use ONE and only one of these ways to import the ZTCoreKit Mobile SDK. Importing the SDK in multiple ways loads duplicate copies of the SDK into the project and causes compiler/linker errors.
CocoaPods
The ZTCoreKit Mobile SDK for iOS is available through CocoaPods. If you have not installed CocoaPods, install CocoaPods by running the command:
$ gem install cocoapods $ pod setup
Depending on your system settings, you may have to use
sudo
for installingcocoapods
as follows:$ sudo gem install cocoapods $ pod setup
In your project directory (the directory where your
*.xcodeproj
file is), run the following to create aPodfile
in your project.$ pod init
Edit the podfile to include the pods you want to integrate into your project. For example, ZTCoreKit is
a must
framework and is required to connect to shoes.ZTBalistonKit
is used when working withSafety
products. As a result, your podfile might look something like this:target 'YourTarget' do pod 'ZTCoreKit', :git => 'https://github.com/zhortech/ztcorekit-ios-sdk.git', :branch => 'master' end
Please add post install script at the end of
Podfile
if there is problem to use library:
post_install do |installer|
installer.pods_project.targets.each do |target|
target.build_configurations.each do |config|
config.build_settings['BUILD_LIBRARY_FOR_DISTRIBUTION'] = 'YES'
end
end
end
For a complete list of our pods, check out the .podspec files in the root directory of this project.
Then run the following command:
$ pod install --repo-update
To open your project, open the newly generated
*.xcworkspace
file in your project’s directory with XCode.Note: Do NOT use
*.xcodeproj
. If you open up a project file instead of a workspace, you may receive the following error:ld: library not found for -lPods-ZTCoreKit clang: error: linker command failed with exit code 1 (use -v to see invocation)
Swift Package Manager
- The Swift Package Manager is a tool for automating the distribution of Swift code and is integrated into the
swift
compiler. Xcode with Swift tools version of 5.3 is required for ZTCoreKit. Earlier Xcode versions don’t support Swift packages with resources. To check your current Swift tools version run in your terminal:
xcrun swift -version
Note
In some cases you can have multiple Swift tools versions installed.
Follow the official Apple SPM guide instructions for more details.\n
To use Swift Package Manager, in Xcode add the https://github.com/zhortech/ztcorekit-ios-sdk dependency and choose the
Exact
version.Set your project Target if not preselected :
- Select your target and note that
ZTCoreKit
is automatically linked as a framework to your project target. Done!
Frameworks
Download the latest SDK.
With your project open in Xcode, select your Target. Under General tab, find Embedded Binaries and then click the + button.
Click the Add Other… button, navigate to the
ZTCoreKit.framework
file and select it. Check the Destination: Copy items if needed checkbox when prompted. Add the frameworks that you need for you specific use case. For example, if you are using ZTCoreKit, you will want to add the following framework:
* `ZTCoreKit.framework`
Under the Build Phases tab in your Target, click the + button on the top left and then select New Run Script Phase. Then setup the build phase as follows. Make sure this phase is below the
Embed Frameworks
phase.Shell /bin/sh bash "${BUILT_PRODUCTS_DIR}/${FRAMEWORKS_FOLDER_PATH}/ZTCoreKit.framework/strip-frameworks.sh" Show environment variables in build log: Checked Run script only when installing: Not checked Input Files: Empty Output Files: Empty
Update the SDK to a Newer Version
When we release a new version of the SDK, you can pick up the changes as described below.
CocoaPods
Run the following command in your project directory. CocoaPods automatically picks up the new changes.
$ pod update
Note: If your pod is having an issue, you can delete
Podfile.lock
andPods/
then runpod install
to cleanly install the SDK.
Swift Package Manager
- You can update to the latest version of any packages you depend on at any time by selecting File ▸ Swift Packages ▸ Update to Latest Package Versions.
Frameworks
- In Xcode’s Project Navigator, type “ZT” to find the ZT frameworks that were manually added to your project. Manually select all of the ZT frameworks and hit delete on your keyboard. Then select Move to Trash. If you were following the example from above which uses ZTBalistonKit, you would remove:
* `ZTCoreKit.framework`
* `ZTBalistonKit.framework`
- Follow the installation process above to include the new version of the SDK.
HOW TO USE IT
Getting Started
- Add capabilities into application:
declared by adding the UIBackgroundModes key to your Info.plist file and setting the key’s value to an array containing one of the following strings:
bluetooth-central—The app communicates with Bluetooth low energy peripherals using the Core Bluetooth framework.
bluetooth-peripheral—The app shares data using the Core Bluetooth framework.
When an app that implements the central role includes the UIBackgroundModes key with the bluetooth-central value in its Info.plist file, the Core Bluetooth framework allows your app to run in the background to perform certain Bluetooth-related tasks. While your app is in the background you can still discover and connect to peripherals, and explore and interact with peripheral data.
Import the ZTCoreKit header in the application delegate.
import ZTCoreKit
Create a default service configuration by adding the following code snippet in the
application:didFinishLaunchingWithOptions:
application delegate method.ZTSettings.shared.environment = .dev //should be changed according to current environment (.dev / .staging / .production / ) ZTCore.shared.setup(apiKey: 'YOUR_KEY', secret: 'YOUR_SECRET', appId: 'YOUR_APPLICATION_ID')
Associated application’s user with portal user or create new user in portal. It is important point.
ZTApi.shared.linkUser(userId: applicationUser.id, attributes: applicationUser.asDictionary()])
Note: Most of the service client classes have a singleton method to get a default instance. The naming convention is .shared
(e.g. ZTCore.shared
in the above code snippet). This singleton method creates a service client with ZTCore
, which you set up in step 2 and maintains a strong reference to the client.
User
ZTCoreSDK creates and stores shoes data for device under a unique id called the appUserId
.
Application has to identify user before using core features.
Usually it is done after signup or signin so unique user id can be passed to backend together with user attributes (like name, email or other attributes).
ZTApi.shared.linkUser(userId: String, attributes: [String: Any]])
Note: If attributes
include key uid
- be sure it is the same as passed into userId
or better don’t pass such key uid
in attributes
parameter.
It will create user object in portal for new user or associate user with current session to allows viewing activities in future.
Scan
You can scan for certain product type ZTProductType
.
New peripheral is returned in callback ConnectResultBlock
when it is discovered:
ZTCore.shared.scan(for: .safety) { (device, error) in
debugPrint("new device discovered:\(String(describing: device))")
}
The scan process is automatically stopped once you start the connection command. To stop scanning call stopScan
:
ZTCore.shared.stopScan()
Connect
There are 2 ways to connect to peripheral.
You can connect using QR code or data matrix code with or without a timeout set, after a timeout you receive a .timeout
error.
ZTCore.shared.connectWithCode(code, timeout: 15) { [weak self] (device, error) in
if error != nil {
debugPrint(String(describing: error))
} else {
debugPrint(String(describing: device))
}
}
Auto Reconnect
By default, ZTSettings autoConnect
is true and ZTCoreKit will always try to automatically reconnect after an unexpected disconnection.
ZTCoreKit will only set autoConnect
to false after calling disconnect()
and the disconnection is successful.
Disconnection
Disconnection can be explicit or unexpected. If you need to disconnect from peripheral, use this method:
device.disconnect()
Unexpected can be due for different reasons: device out of range, low battery, device reset etc
Observers
Connection observer
Connection event observer:
The ZTCore.shared.bleManager.onDeviceStateChange
informs you about change in a device connection state.
A connection event is defined by different states:
- a peripheral was connected after a
connect
command or after automatic reconnection - when there is error occurred during a connection
- when a peripheral was disconnected
BLE observer
Bluetooth state event observer:
The ZTCore.shared.bleManager.onBluetoothStateChange
informs you about change in a device connection state.
Bluetooth device discovery observer:
The ZTCore.shared.bleManager.onDeviceDiscovered
informs you about discovering new ZTDevice.
Battery observer
The ZTCore.shared.connectedDevice?.onBatteryValueUpdated
informs you about change in a battery levels.
Firmware errors observer
Device firmware error observer:
The ZTCore.shared.connectedDevice?.onFirmwareError
informs you about possible errors like:
- “differentFirmware” when different firmware versions on left and right insoles and DFU must be done for insoles to work
- “memsError” so DFU must be done for insoles to work
- “leftNoConnected” when left insole in sleep mode or its battery is 0 so it is not connected to right insole
Autoconnection
The autoconnection is managed by the ZTSettings.shared.autoConnect
configuration.
Autoconnection may not work if application has no Bluetooth permission to run in background.
Logging
As of version 0.0.30 of this SDK, logging can be controlled by setting approriate logging level. It allows to see network requests and additional information from ZTCoreKit.
Changing Log Levels
Swift
ZTSettings.shared.logLevel = .info
The following logging level options are available:
.all
.debug
.info
.error
.fatal
We recommend setting the log level to .error
before publishing to the Apple App Store.
DOCUMENTATION
Jazzy doc is available here
SAMPLE APPLICATION
A sample application can be download here.
Talk to Us
Visit GitHub Issues to leave feedback or create any issue.
Author
Zhortech
License
See the LICENSE file for more info.