Skip to content

rokmetro/neom-app

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

NEOM U App

The official mobile app of NEOM U. Powered by the Rokwire Platform.

Requirements

Flutter v3.24.0

Android Studio 2021.3.1+

xCode 15.2

CocoaPods 1.15.0+

Build

Clone this repo

git clone --recurse-submodules https://github.com/rokmetro/neom-app.git

Make sure app flutter plugin persists

Rokwire app flutter plugin is used by the NEOM U app. It should be located in the plugin subdirectory of the application's root project directory. If it does not exist you need to clone it manually.

cd neom-app.git
git clone https://github.com/rokwire/app-flutter-plugin.git plugin

Make sure libs repo persists

Rokwire app libs directory is used by the NEOM U app for private external libraries. It should be located in the libs subdirectory of the application's root project directory. If it does not exist you need to clone it manually.

cd neom-app
git clone https://github.com/rokwire/illinois-app-libs.git libs

font_awesome_flutter plugin:

If font_awesome_flutter pro repo is not available then use the regular font_awesome_flutter plugin. Comment the lines in pubspec.yaml:

# font_awesome_flutter: '>= 4.7.0' # comment if published plugin is used

...
# dependency_overrides:
#  font_awesome_flutter:
#    path: plugin/plugins/font_awesome_flutter

For more details, please see app-flutter-plugin's README.md file.

Supply the following private configuration files:

• .travis.yml

Obsolete, not used after version 2.0 inclusive.

• secrets.tar.enc

Obsolete, not used after version 2.0 inclusive.

• assets/config.keys.json (for versions after 3.0 inclusive)

JSON data with the following format:

{
	"key":"...",
	"iv":"..."
}

key and iv fields contain strings that are base64 encoded randomly generated 16-bytes AES128 key and IV. These keys are used for decryption of assets/configs.json.enc from the application assets as well as for the decryption of secretKeys enctypted string in app config.

• assets/configs.json.enc

  1. JSON data with the following format:
{
  "production": {
    "config_url": "https://core.prod.api.rokmetro.com/core/services/application/configs",
    "api_key": "XXXXXXXX-XXXX-XXXX-XXXXXXXXXXXXXXXXX"
  },
  "dev": {
    "config_url": "https://core.dev.api.rokmetro.com/core/services/application/configs",
    "api_key": "XXXXXXXX-XXXX-XXXX-XXXXXXXXXXXXXXXXX"
  },
  "test": {
    "config_url": "https://core.stage.api.rokmetro.com/core/services/application/configs",
    "api_key": "XXXXXXXX-XXXX-XXXX-XXXXXXXXXXXXXXXXX"
  }
}
  1. For versions prior to 3.0:
    • Generate random 16-bytes AES128 key.
    • AES encrypt the JSON string, CBC mode, PKCS7 padding, using the AES.
    • Create a data blob that contains the AES key at the beginning followed by the encrypted data.
    • Get a base64 encoded string of the data blob and save it as assets/configs.json.enc.

Alternatively, you can use AESCrypt.encode from /lib/utils/Crypt.dart to generate content of assets/configs.json.enc.

  1. For versions after 3.0 inclusive:
    • AES encrypt the JSON string, CBC mode, PKCS7 padding, using the key and IV from assets/config.keys.json.
    • Get a base64 encoded string of the encryption result and save it as assets/configs.json.enc.

• ios/Resources/Runner/GoogleService-Info-Debug.plist

• ios/Resources/Runner/GoogleService-Info-Release.plist

• ios/Resources/Neom/GoogleService-Info-Debug.plist

• ios/Resources/Neom/GoogleService-Info-Release.plist

The Firebase configuration file for iOS generated from Google Firebase console.

• android/app/src/neom/keys.properties

Contains:

  • GoogleMaps API key for the NEOM flavor.
  • Origo configuration specific keys and ids.
googleMapsApiKey=XXXXXXXXXXXXXXXXXXXXXX-XXXXXXXXXXXXXXXX
origoAppId=XXXXXXXXXXXXXXXXX
origoLockServiceCode=X
origoAidFilter1=XXXXXXXXXXXXXXXXXXXX
origoAidFilter2=XXXXXXXXXXXXXXXXXXXXXXXXXX

• android/app/src/neom/dev/google-services.json

• android/app/src/neom/prod/google-services.json

• android/app/src/neom/tst/google-services.json

The Firebase configuration file for Android generated from Google Firebase console.

Build the project

$ sh ./scripts/prebuild_neom.sh
$ flutter build apk --no-tree-shake-icons --flavor NeomProd -t lib/mainProd.dart
$ flutter build apk --no-tree-shake-icons --flavor NeomDev -t lib/mainDev.dart
$ flutter build apk --no-tree-shake-icons --flavor NeomTst -t lib/mainTest.dart

$ flutter build ios --no-tree-shake-icons --flavor NeomProd -t lib/mainProd.dart
$ flutter build ios --no-tree-shake-icons --flavor NeomDev -t lib/mainDev.dart
$ flutter build ios --no-tree-shake-icons --flavor NeomTst -t lib/mainTest.dart

NB: Product environments: Prod/Dev/Test

--flavor NeomProd -t lib/mainProd.dart
--flavor NeomDev -t lib/mainDev.dart
--flavor NeomTst -t lib/mainTest.dart

NB: For versions prior to 4.2 you may omit the no-tree-shake-icons build parameter.

NB: You may need to update singing & capabilities content for Runner project by opening ios/Runner.xcworkspace from xCode

Documentation

About

Source code repository of the "NEOM U" App

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Dart 95.7%
  • Objective-C 2.8%
  • Java 1.2%
  • Shell 0.1%
  • Ruby 0.1%
  • JavaScript 0.1%