Cordova: Difference between revisions

From NSB App Studio
Jump to navigation Jump to search
No edit summary
 
(42 intermediate revisions by the same user not shown)
Line 1: Line 1:
Apache Cordova is a free and open source tool for make iOS and Android apps. First step is to create the project using a development tool such as AppStudio. The project is then compiled into .ipa and .apk files by Cordova.
Apache Cordova is a mobile application development framework originally created by Nitobi. Adobe Systems purchased Nitobi in 2011, rebranded it as PhoneGap, and later released the open source version of the software as Apache Cordova. Apache discontinued PhoneGap in 2020.
[VoltBuilder] is a web service which uses Cordova. It's much easier to use than Cordova itself. Here is information on [[VoltBuilder|Using VoltBuilder to build Native Apps]].
Cordova is recommended for users
* Who want to build locally on their own system.
* Who have requirements that VoltBuilder cannot satisfy.
* Who have the technical expertise to install the toolchain.
=== Is a Mac required? ===
If you're only going to make Android apps, no Mac is needed.
There are several steps to producing an iOS app which can only be done on a Mac:
* Getting a signing certificate requires the macOS Keychain app
* Signing the .ipa file requires XCode
* Setting the .mobileprovision file requires XCode
* Uploading the app to the iTunes Store does not require a Mac: VoltBuilder can do this for you.
As of the last update to this page, the minimum requirement for a Mac is that it runs macOS Catalina (10.15.4). This is required for XCode 11.4, which contains the libraries to create iOS 13.4 apps. Any Mac which can run Catalina should have sufficient speed, memory and storage. Keep in mind that XCode needs 17 gigs of storage.
It's possible to use a service such as [https://www.macincloud.com/ MacInCloud] instead of an actual Mac.
Android apps can be made on both Windows and MacOS.


=== Prerequisites ===
=== Prerequisites ===


==== Windows ====
Download and install Node. (This also installs npm.)
Android Studio and SDK
https://nodejs.org/en/download/


==== MacOS ====
Cordova Android Requirements (not needed if you are only doing iOS):
Android Studio and SDK
(About 7 gigs on Windows, 8 gigs on Mac)
XCode 11
https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#installing-the-requirements
 
Installing the Android toolchain can be tricky. It's fragile: all the environmental variables and paths must be correctly set up. There doesn't seem to be an easy way to check and fix problems.
 
==== macOS/iOS ====
 
* Membership in [https://developer.apple.com/programs/ Apple's Developer program]. ($99USD/yr)
* XCode 11 from App Store (about 16 gigs)<br>
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/index.html#installing-the-requirements
* mobileprovision file (from Apple Developer site)
* signing certificate (from Apple Developer site)
 
=== How to make an app using Cordova ===
# Install the [[Cordova#Prerequisites|Prerequisites]].
# Make your app as usual with AppStudio.
# In your Project Properties, set the '[[Cordova#Cordova_Commands|Cordova command]]' in the VoltBuilder and Cordova section. 'Emulate ios' and 'emulate android' are good for testing.
# If you have an Android device connected by a USB cable, use 'run android --debug'. It's faster than the emulator.
# From the Run menu, select Make Native App with Cordova.
# The app should load and run on the emulator or device.
# To run on an iOS device, it will [[Cordova#Signing_iOS_Apps|need to be signed]].
 
=== Signing Android Apps ===
 
Unsigned apps will run fine in the emulator and on devices. They are especially useful for debugging - you can use Chrome to [https://developers.google.com/web/tools/chrome-devtools/remote-debugging/ Remote Debug your app].
 
If you want to submit your app to the Google Play or Android store, you will need to sign it using a keystore file. AppStudio generates that file automatically from your [[Cordova#Android|build.json]] file. You'll need to supply the correct values in that.
 
=== Signing iOS Apps ===
 
Both Debug and Release builds need to be signed to run on iOS devices.
 
The debug and release builds need separate codeSignIdentity and provisioningProfile settings, downloaded from Apple.
 
You can also leave these values unmodified in AppStudio and supply the information to Xcode instead.
 
Complete information on signing iOS apps with Cordoba is here:<br>
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/#signing-an-app


=== Cordova Commands ===
=== Cordova Commands ===
Line 15: Line 77:
! Command !! Windows !! macOS
! Command !! Windows !! macOS
|-
|-
| emulate ios || Nothing || Opens app in iOS Emulator.
| emulate ios || Nothing || Opens app in iOS Simulator.
|-
|-
| emulate android || Opens app in Android Emulator || Creates debug apk and opens in Android Emulator
| emulate android || Opens app in Android Emulator || Creates debug apk and opens in Android Emulator
|-
|-
| run ios --debug || Nothing || Creates debug ipa and opens app on Emulator or USB connected device. provisioningProfile and developmentTeam must be supplied in [[Cordova#iOS|build.json]].
| run ios --debug || Nothing || Creates debug ipa and opens app on Simulator or USB connected device. provisioningProfile and developmentTeam must be supplied in [[Cordova#iOS|build.json]].
|-
|-
| run android --debug || Opens app on USB connected device || Creates debug apk and opens on USB connected device
| run android --debug || Opens app on USB connected device || Creates debug apk and opens on USB connected device
|-
|-
| run ios --release || Nothing || Creates signed ipa and opens app on Emulator or USB connected device. codeSignIdentity, provisioningProfile and developmentTeam must be supplied in [[Cordova#iOS|build.json]].
| run ios --release || Nothing || Creates signed ipa and opens app on Simulator or USB connected device. codeSignIdentity, provisioningProfile and developmentTeam must be supplied in [[Cordova#iOS|build.json]].
|-
| run android --release || Creates signed .apk || Creates signed .apk
| run android --release || Creates signed .apk || Creates signed .apk
|-
|-
| Create cordova directory only || Creates all files, but does run a Cordova command.
| Create cordova directory only || Creates all files, but does not run a Cordova command. || Creates all files, but does not run a Cordova command.
|-
|-
| Create and open in Xcode || Nothing || Creates all files, then launches in XCode.
| Create and open in Xcode || Nothing || Creates all files, then launches in XCode.
Line 48: Line 111:
=== Cordova build.json ===
=== Cordova build.json ===


This file contains parameters for signing apps.
This file contains parameters for signing apps. It's in Project Properties, in the 'VoltBuilder and Cordova' section. When you run Cordova, it gets copied into the cordova folder and instructs Cordova how to sign the app.


==== Android ====
==== Android ====
Here's the default Android section in build.json. Only a 'release' section is provided - no debug section is provided since the defaults will work fine in almost all cases.
<pre>
{
  "android": {
    "release": {
      "keystore": "certificates/android.keystore",
      "storePassword": "mypassword",
      "alias": "key0",
      "password": "mypassword",
      "keystoreType": "",
      "dname": "cn=Eric Cartman, o=appstudio c=us"
    }
  }
}</pre>
For more options, see the Cordova documentation:<br>
https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#signing-an-app
https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#signing-an-app
The dname field stands for Designated Name. You should customize it with your values. There is more information on Dnames here: https://docs.oracle.com/javase/6/docs/technotes/tools/solaris/keytool.html#DName


==== iOS ====
==== iOS ====
Here's the default iOS section in build.json. Both a debug and release section are required.
<pre>
  "ios": {
    "debug": {
      "codeSignIdentity": "iPhone Developer",
      "provisioningProfile": "8b3aafc5-e001-4bbe-ac6f-bc6df8ab2534",
      "developmentTeam": "J36MEHTA7K",
      "packageType": "development",
      "automaticProvisioning": true,
      "buildFlag": [
        "EMBEDDED_CONTENT_CONTAINS_SWIFT = YES",
        "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES=NO",
        "LD_RUNPATH_SEARCH_PATHS = \"@executable_path/Frameworks\""
      ]
    },
    "release": {
      "codeSignIdentity": "iPhone Developer",
      "developmentTeam": "J36MEHTA7K",
      "packageType": "app-store",
      "automaticProvisioning": true,
      "buildFlag": [
        "EMBEDDED_CONTENT_CONTAINS_SWIFT = YES",
        "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES=NO",
        "LD_RUNPATH_SEARCH_PATHS = \"@executable_path/Frameworks\""
      ]
    }
</pre>
These are the fields you need to worry about:
* '''codeSignIdentity''' is the name of the certificate downloaded from Apple. It appears in the macOS Keystore app. Get your certificate from [https://developer.apple.com/ Apple's Developer site] in the 'Certificates, Identifiers and Profiles' sections, under 'Certificates'.
* '''provisioningProfile''' is the UUID of the mobileprovision file. Download it from Apple and double click on it. Xcode will update your system so XCode can find it. Get the UUID by opening the mobileprovision file itself in an editor and finding UUID. Get your mobileprovision from [https://developer.apple.com/ Apple's Developer site] in the 'Certificates, Identifiers and Profiles' sections, under 'Profiles'. You will also need to set up devices in 'Devices' and create an Identifier in 'Identifiers'. The App ID must match the id in [[Submitting_to_the_Google_Play_and_Amazon_Stores#Config.xml|config.xml]].
* '''developmentTeam''' is your Team ID. Log into [https://developer.apple.com/ Apple's Developer site] and check the Membership page.
For more options, see the Cordova documentation:<br>
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/index.html#signing-an-app
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/index.html#signing-an-app

Latest revision as of 14:21, 2 December 2024

Apache Cordova is a free and open source tool for make iOS and Android apps. First step is to create the project using a development tool such as AppStudio. The project is then compiled into .ipa and .apk files by Cordova.

Apache Cordova is a mobile application development framework originally created by Nitobi. Adobe Systems purchased Nitobi in 2011, rebranded it as PhoneGap, and later released the open source version of the software as Apache Cordova. Apache discontinued PhoneGap in 2020.

[VoltBuilder] is a web service which uses Cordova. It's much easier to use than Cordova itself. Here is information on Using VoltBuilder to build Native Apps.

Cordova is recommended for users

  • Who want to build locally on their own system.
  • Who have requirements that VoltBuilder cannot satisfy.
  • Who have the technical expertise to install the toolchain.

Is a Mac required?

If you're only going to make Android apps, no Mac is needed.

There are several steps to producing an iOS app which can only be done on a Mac:

  • Getting a signing certificate requires the macOS Keychain app
  • Signing the .ipa file requires XCode
  • Setting the .mobileprovision file requires XCode
  • Uploading the app to the iTunes Store does not require a Mac: VoltBuilder can do this for you.

As of the last update to this page, the minimum requirement for a Mac is that it runs macOS Catalina (10.15.4). This is required for XCode 11.4, which contains the libraries to create iOS 13.4 apps. Any Mac which can run Catalina should have sufficient speed, memory and storage. Keep in mind that XCode needs 17 gigs of storage.

It's possible to use a service such as MacInCloud instead of an actual Mac.

Android apps can be made on both Windows and MacOS.

Prerequisites

Download and install Node. (This also installs npm.) https://nodejs.org/en/download/

Cordova Android Requirements (not needed if you are only doing iOS): (About 7 gigs on Windows, 8 gigs on Mac) https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#installing-the-requirements

Installing the Android toolchain can be tricky. It's fragile: all the environmental variables and paths must be correctly set up. There doesn't seem to be an easy way to check and fix problems.

macOS/iOS

https://cordova.apache.org/docs/en/latest/guide/platforms/ios/index.html#installing-the-requirements

  • mobileprovision file (from Apple Developer site)
  • signing certificate (from Apple Developer site)

How to make an app using Cordova

  1. Install the Prerequisites.
  2. Make your app as usual with AppStudio.
  3. In your Project Properties, set the 'Cordova command' in the VoltBuilder and Cordova section. 'Emulate ios' and 'emulate android' are good for testing.
  4. If you have an Android device connected by a USB cable, use 'run android --debug'. It's faster than the emulator.
  5. From the Run menu, select Make Native App with Cordova.
  6. The app should load and run on the emulator or device.
  7. To run on an iOS device, it will need to be signed.

Signing Android Apps

Unsigned apps will run fine in the emulator and on devices. They are especially useful for debugging - you can use Chrome to Remote Debug your app.

If you want to submit your app to the Google Play or Android store, you will need to sign it using a keystore file. AppStudio generates that file automatically from your build.json file. You'll need to supply the correct values in that.

Signing iOS Apps

Both Debug and Release builds need to be signed to run on iOS devices.

The debug and release builds need separate codeSignIdentity and provisioningProfile settings, downloaded from Apple.

You can also leave these values unmodified in AppStudio and supply the information to Xcode instead.

Complete information on signing iOS apps with Cordoba is here:
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/#signing-an-app

Cordova Commands

Command Windows macOS
emulate ios Nothing Opens app in iOS Simulator.
emulate android Opens app in Android Emulator Creates debug apk and opens in Android Emulator
run ios --debug Nothing Creates debug ipa and opens app on Simulator or USB connected device. provisioningProfile and developmentTeam must be supplied in build.json.
run android --debug Opens app on USB connected device Creates debug apk and opens on USB connected device
run ios --release Nothing Creates signed ipa and opens app on Simulator or USB connected device. codeSignIdentity, provisioningProfile and developmentTeam must be supplied in build.json.
run android --release Creates signed .apk Creates signed .apk
Create cordova directory only Creates all files, but does not run a Cordova command. Creates all files, but does not run a Cordova command.
Create and open in Xcode Nothing Creates all files, then launches in XCode.

The full list of command options is in the Cordova documentation.

You can also enter the commands manually. Open a terminal window in {your project}/cordova, and enter one of the commands above or others:

$ cordova platform
Installed platforms:
  android 8.1.0
  ios 5.1.1
Available platforms: 
  browser ^6.0.0
  electron ^1.0.0
  osx ^5.0.0
  windows ^7.0.0

Cordova build.json

This file contains parameters for signing apps. It's in Project Properties, in the 'VoltBuilder and Cordova' section. When you run Cordova, it gets copied into the cordova folder and instructs Cordova how to sign the app.

Android

Here's the default Android section in build.json. Only a 'release' section is provided - no debug section is provided since the defaults will work fine in almost all cases.

{
  "android": {
    "release": {
      "keystore": "certificates/android.keystore",
      "storePassword": "mypassword",
      "alias": "key0",
      "password": "mypassword",
      "keystoreType": "",
      "dname": "cn=Eric Cartman, o=appstudio c=us"
    }
  }
}

For more options, see the Cordova documentation:
https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#signing-an-app

The dname field stands for Designated Name. You should customize it with your values. There is more information on Dnames here: https://docs.oracle.com/javase/6/docs/technotes/tools/solaris/keytool.html#DName

iOS

Here's the default iOS section in build.json. Both a debug and release section are required.

  "ios": {
    "debug": {
      "codeSignIdentity": "iPhone Developer",
      "provisioningProfile": "8b3aafc5-e001-4bbe-ac6f-bc6df8ab2534",
      "developmentTeam": "J36MEHTA7K",
      "packageType": "development",
      "automaticProvisioning": true,
      "buildFlag": [
        "EMBEDDED_CONTENT_CONTAINS_SWIFT = YES",
        "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES=NO",
        "LD_RUNPATH_SEARCH_PATHS = \"@executable_path/Frameworks\""
      ]
    },
    "release": {
      "codeSignIdentity": "iPhone Developer",
      "developmentTeam": "J36MEHTA7K",
      "packageType": "app-store",
      "automaticProvisioning": true,
      "buildFlag": [
        "EMBEDDED_CONTENT_CONTAINS_SWIFT = YES",
        "ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES=NO",
        "LD_RUNPATH_SEARCH_PATHS = \"@executable_path/Frameworks\""
      ]
    }

These are the fields you need to worry about:

  • codeSignIdentity is the name of the certificate downloaded from Apple. It appears in the macOS Keystore app. Get your certificate from Apple's Developer site in the 'Certificates, Identifiers and Profiles' sections, under 'Certificates'.
  • provisioningProfile is the UUID of the mobileprovision file. Download it from Apple and double click on it. Xcode will update your system so XCode can find it. Get the UUID by opening the mobileprovision file itself in an editor and finding UUID. Get your mobileprovision from Apple's Developer site in the 'Certificates, Identifiers and Profiles' sections, under 'Profiles'. You will also need to set up devices in 'Devices' and create an Identifier in 'Identifiers'. The App ID must match the id in config.xml.

For more options, see the Cordova documentation:
https://cordova.apache.org/docs/en/latest/guide/platforms/ios/index.html#signing-an-app