Copyright 2015 Google Inc. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Note: while these instructions allow you to build iosched, much of the functionality that depends on server APIs won't work because in order to do that you need to configure your own project in Google Developer Console, create API keys, etc. For more information about what you need to set up, refer to Server side setup.
This is a Gradle-based project that works best with Android Studio
To build the app:
-
Install the following software: - Android SDK: http://developer.android.com/sdk/index.html - Gradle: http://www.gradle.org/downloads - Android Studio: http://developer.android.com/sdk/installing/studio.html
-
Run the Android SDK Manager by pressing the SDK Manager toolbar button in Android Studio or by running the 'android' command in a terminal window.
-
In the Android SDK Manager, ensure that the following are installed, and are updated to the latest available version: - Tools > Android SDK Platform-tools - Tools > Android SDK Tools - Tools > Android SDK Build-tools - Tools > Android SDK Build-tools - Android 6.0 > SDK Platform (API 23) - Extras > Android Support Repository - Extras > Android Support Library - Extras > Google Play services - Extras > Google Repository
-
Create a file in your working directory called local.properties, containing the path to your Android SDK. Use local.properties.example as a model.
-
Import the project in Android Studio:
- Press File > Import Project
- Navigate to and choose the settings.gradle file in this project
- Press OK
-
Add your debug keystore to the project (save it as android/debug.keystore), or modify the build.gradle file to point to your key.
-
Choose Build > Make Project in Android Studio or run the following command in the project root directory:
./gradlew clean assembleDebug
-
To install on your test device:
./gradlew installDebug
These steps are optional, in the sense that IOSched will build and run even if you don't set up the server side. However, unless you perform this setup, your build won't be able to use any of the Google APIs such as Google sign in, Google Drive integration, Google Maps integration, etc. So following the instructions in this section is highly recommended.
-
Change the project's package name to your own package name. To do that, you can set the "package" attribute of the tag in AndroidManifest.xml.
-
Create a project in the Google Developers Console, at https://cloud.google.com/console
-
Note your project's Project ID. It is a 11-12 digit sequence that appears in the URL, indicated by ########### below:
https://console.developers.google.com/project/###########/...
Write down this project ID number you will need it soon.
-
In the APIs and Auth section, enable these APIs:
- Drive API
- Google Cloud Messaging for Android
- Google Maps Android API v2
- Google+ API
- YouTube Data API v3
-
In the Credentials section, create a Client ID for Android applications with your package name and your certificate fingerprint. As a reminder, you can get your debug certificate fingerprint by issuing this command:
keytool -exportcert -alias androiddebugkey \ -keystore $HOME/.android/debug.keystore -list -v
It's also advisable to create a Client ID corresponding to your release certificate as well. To get your release certificate's fingerprint, run:
keytool -exportcert -alias your-key-name \ -keystore /path/to/your/release/keystore/file -list -v
-
Still in the Credentials section, create an API Key for Public API access. The key's type is Key for Android applications, and you should add both your debug and release certificate fingerprints in the list of accepted certificates. Note the API key you created. It's a long alphanumeric string with digits, letters and with a few underscores.
-
Enter your API Key from Step 5 into this file:
android/src/main/res/values/maps_api_key.xml
-
Enter your API key in the YOUTUBE_API_KEY constant in Config.java
Done. IOSched should now work with Google sign in, Google Drive integration and Maps integration. Note that we did NOT include setting up GCM. For more information about this, see CUSTOM.md.