This document outlines the current additional information for mobile development. We should wrap this into our current tooling before release!
Please ensure that your fyne install is the latest development version (both library and "fyne" command line tool).
go get -u fyne.io/fyne fyne.io/fyne/cmd/fyne
Get and install the Andoid Native Development Kit (NDK). This is platform dependent and may be packaged
with various tools that you might already have installed (like Android Studio)
Once installed set up the appropriate path, the directory you reference should contain ndk-build
,
platforms
and toolchains
.
export ANDROID_NDK_HOME=/<path to>/android-ndk
Install XCode from the app store and sign up for an Apple Developer account. Before compiling you will need to add a device ID to your account, create a development certificate and then a provisioning profile.
Apps can then be compiled simply like the following:
fyne package -os android fyne.io/fyne/cmd/hello
For iOS apps you must also specify the bundleID of the app which must match an installed provisioning profile.
fyne package -os ios -appid=com.teamid.appid fyne.io/fyne/cmd/hello
The compiled applications above can be tested locally and even shared with developers that are part of your team. To deliver the applications to an app store or marketplace takes more work which has not yet been automated.
The above steps will create a .app folder that can be installed to your iPhone directly. These steps work on that content to prepare it for uploading to the App Store... Be sure to find the appropriate values for each of the items!
The important part of this process is to re-codesign using a distribution certificate which must match the app store provisioning profile in step 3.
mkdir Payload
cp -r myapp.app Payload/
cp ~/Library/MobileDevice/Provisioning\ Profiles/<app-store-distribution>.mobileprovision Payload/myapp.app/embedded.mobileprovision
open Payload/myapp.app/Info.plist
(and check the build etc are correct - then save)- create a new text file called entitlements.plist, enter the following content:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>application-identifier</key>
<string><teamId>.<appId></string>
</dict>
</plist>
codesign -f -vv -s "<distribution certificate name>" --entitlements entitlements.plist Payload/myapp.app/
- If you have not already done so create an app specific password for your Apple account (appleid.com)
zip -r myapp.ipa Payload/
xcrun altool --upload-app --file myapp.ipa --username <appleId> --password <app-specific-password>
The upload make take some time but once it is complete you should see the build appear alongside the appropriate entry in your app store connect metadata.
This process will be improved soon!