Embedding a framework in an iMessage App
Q: How do I embed a framework in an iMessage App?
A: Xcode 8.0 does not expose the ability to embed a framework in the stub application target containing your iMessage App. If you need to use a framework in an iMessage App, you can use an alternate approach.
There are two approaches to consider. The first approach is to compile the code from the framework directly into the iMessage Extension. The second approach uses an aggregate target with a Run Script build phase to move the framework to the correct location in the app bundle. The remainder of this document focuses on the second approach, which requires familiarity with configuring targets and build settings in Xcode.
Configuring an Aggregate Target
The framework target must be a dependency of the aggregate target. The aggregate target must be a dependency of the iMessage Extension target. Configured targets are shown in Figure 1 and Figure 2.
data:image/s3,"s3://crabby-images/bdeef/bdeeff497115f76b4ec9dc20bf182482e68e5cf8" alt=""
data:image/s3,"s3://crabby-images/bdeef/bdeeff497115f76b4ec9dc20bf182482e68e5cf8" alt=""
data:image/s3,"s3://crabby-images/6e1aa/6e1aade1fee044ae8cc34cd06fd26df5d9f475d2" alt=""
data:image/s3,"s3://crabby-images/6e1aa/6e1aade1fee044ae8cc34cd06fd26df5d9f475d2" alt=""
Copying the Framework Into the App
The correct location for the framework is different for archive builds and development builds:
Archive build:
${DSTROOT}/Applications/MyMessageApp.app/Frameworks
Development build:
${BUILT_PRODUCTS_DIR}/MyMessageApp.app/Frameworks
The DEPLOYMENT_LOCATION
is YES
, the build is for an archive, and when set to NO
, the build is for development.
Configure the aggregate target with a Run Script build phase that copies the framework to the proper location, as shown in Listing 1. You must modify this script to replace MyMessageApp.app
with the name of your iMessage app bundle, and to replace MyFramework.framework
with the name of your framework.
Listing 1 Shell script to move the framework to the app bundle
if [ "${DEPLOYMENT_LOCATION}" = "YES" ] ; then |
FRAMEWORKS_DIR="${DSTROOT}/Applications/MyMessageApp.app/Frameworks" |
else |
FRAMEWORKS_DIR="${BUILT_PRODUCTS_DIR}/MyMessageApp.app/Frameworks" |
fi |
rm -rf "${FRAMEWORKS_DIR}/MyFramework.framework" |
mkdir -p "${FRAMEWORKS_DIR}" |
cp -r "${BUILT_PRODUCTS_DIR}/MyFramework.framework" "${FRAMEWORKS_DIR}" |
Code Signing Considerations
In order to run an iMessage App on a device, the framework must be code signed with the same signing identity used to sign the iMessage App.
If you are building the framework, you can do this by configuring the framework target to be code signed during its build. Figure 3 shows the build settings for this.
If you are not building the framework, or if configuring the framework to be signed during building is not an option, the shell script in Copying the Framework Into the App needs to call the codesign tool to sign the framework with the correct signing identity after copying the framework to the app.
data:image/s3,"s3://crabby-images/fb0ec/fb0ec5160d2caa06ede662521f6ae5ffd5498bb3" alt=""
data:image/s3,"s3://crabby-images/fb0ec/fb0ec5160d2caa06ede662521f6ae5ffd5498bb3" alt=""
Document Revision History
Date | Notes |
---|---|
2017-09-26 | Marked document as Legacy. Added a link to the replacement Embedding Frameworks In An App tech note. |
2017-03-21 | Marked document as Legacy. Added a link to the replacement Embedding Frameworks In An App tech note. |
Marked document as Legacy. Added a link to the replacement Embedding Frameworks In An App tech note. | |
2016-09-02 | New document that demonstrates how to embed a framework in an iMessage App |
Copyright © 2017 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2017-09-26