6
0
mirror of https://github.com/ChristianLight/tutor.git synced 2025-01-07 16:04:02 +00:00

Fix android app build/auth

We had to backtrack from the latest release of the
android app, which is not compatible with the mobile api v0.5 available
in Hawthorn. This should change in ironwood.

Also, we included the correct oauth client ID in the app, which
prevented communication with the LMS.

The android app is now out of beta \o/

Close #89
This commit is contained in:
Régis Behmo 2019-02-20 16:07:18 +01:00
parent 6a5527458f
commit 1e2166dacf
11 changed files with 68 additions and 33 deletions

View File

@ -55,6 +55,7 @@ But there's a lot more to Tutor than that! For more advanced usage, please refer
dev dev
k8s k8s
webui webui
mobile
troubleshooting troubleshooting
tutor tutor
faq faq

34
docs/mobile.rst Normal file
View File

@ -0,0 +1,34 @@
.. _mobile:
Mobile Android application
==========================
With Tutor, you can build an Android mobile application for your platform. First, generate the required environment::
tutor android env
Then, build the app in debug mode::
tutor android build debug
The ``.apk`` file will then be available in ``$TUTOR_ROOT/data/android``. Transfer it to an Android phone to install the application. You should be able to sign in and view available courses.
Releasing an Android app
------------------------
**Note**: this is an untested feature.
Releasing an Android app on the Play Store requires to build the app in release mode. To do so, edit the ``$TUTOR_ROOT/config.yml`` configuration file and define the following variables::
ANDROID_RELEASE_STORE_PASSWORD
ANDROID_RELEASE_KEY_PASSWORD
ANDROID_RELEASE_KEY_ALIAS
Then, place your keystore file in ``$TUTOR_ROOT/env/android/app.keystore``. Finally, build the application with::
tutor android build release
Customising the Android app
---------------------------
Customising the application, such as the logo or the background image, is currently not supported. If you are interested by this feature, please tell us about it in the Tutor `discussion forums <https://discuss.overhang.io>`_.

View File

@ -40,16 +40,3 @@ Xqueue
------ ------
`Xqueue <https://github.com/edx/xqueue>`_ is for grading problems with external services. If you don't know what it is, you probably don't need it. `Xqueue <https://github.com/edx/xqueue>`_ is for grading problems with external services. If you don't know what it is, you probably don't need it.
Android app (beta)
------------------
The Android app for your platform can be easily built in just one command::
tutor android build debug
If all goes well, the debuggable APK for your platform should then be available in ./data/android. To obtain a release APK, you will need to obtain credentials from the app store and add them to ``config/android/gradle.properties``. Then run::
tutor android build release
Building the Android app for an Open edX platform is currently labeled as a **beta feature** because it was not fully tested yet. In particular, there is no easy mechanism for overriding the edX assets in the mobile app. This is still a work-in-progress.

View File

@ -1,6 +1,6 @@
import click import click
from . import config from . import config as tutor_config
from . import env as tutor_env from . import env as tutor_env
from . import fmt from . import fmt
from . import opts from . import opts
@ -20,7 +20,12 @@ def android():
) )
@opts.root @opts.root
def env(root): def env(root):
tutor_env.render_target(root, config.load(root), "android") config = tutor_config.load(root)
# sub.domain.com -> com.domain.sub
config["LMS_HOST_REVERSE"] = ".".join(config["LMS_HOST"].split(".")[::-1])
tutor_env.render_target(root, config, "build")
tutor_env.render_target(root, config, "android")
click.echo(fmt.info("Environment generated in {}".format(root)))
@click.group( @click.group(
help="Build the application" help="Build the application"
@ -33,10 +38,7 @@ def build():
) )
@opts.root @opts.root
def debug(root): def debug(root):
docker_run( docker_run(root)
root, "./gradlew", "assembleProdDebuggable", "&&",
"cp", "OpenEdXMobile/build/outputs/apk/prod/debuggable/*.apk", "/openedx/data/"
)
click.echo(fmt.info("The debuggable APK file is available in {}".format(tutor_env.data_path(root, "android")))) click.echo(fmt.info("The debuggable APK file is available in {}".format(tutor_env.data_path(root, "android"))))
@click.command( @click.command(
@ -56,8 +58,8 @@ def pullimage():
def docker_run(root, *command): def docker_run(root, *command):
utils.docker_run( utils.docker_run(
"--volume={}/:/openedx/config/".format(tutor_env.pathjoin(root, "android")), "--volume={}:/openedx/config/".format(tutor_env.pathjoin(root, "android")),
"--volume={}:/openedx/data".format(tutor_env.data_path(root, "android")), "--volume={}:/openedx/data/".format(tutor_env.data_path(root, "android")),
DOCKER_IMAGE, DOCKER_IMAGE,
*command *command
) )

View File

@ -19,12 +19,16 @@ migrate_forum = "bundle exec rake search:initialize && bundle exec rake search:r
migrate_notes = "./manage.py migrate" migrate_notes = "./manage.py migrate"
migrate_xqueue = "./manage.py migrate" migrate_xqueue = "./manage.py migrate"
oauth2 = """{% if ACTIVATE_NOTES %} oauth2 = """
./manage.py lms create_oauth2_client \
"http://androidapp.com" "http://androidapp.com/redirect" public \
--client_id android --client_secret {{ ANDROID_OAUTH2_SECRET }} \
--trusted
{% if ACTIVATE_NOTES %}
./manage.py lms manage_user notes notes@{{ LMS_HOST }} --staff --superuser ./manage.py lms manage_user notes notes@{{ LMS_HOST }} --staff --superuser
./manage.py lms create_oauth2_client \ ./manage.py lms create_oauth2_client \
"http://notes.openedx:8000" \ "http://notes.openedx:8000" "http://notes.openedx:8000/complete/edx-oidc/" confidential \
"http://notes.openedx:8000/complete/edx-oidc/" \
confidential \
--client_name edx-notes --client_id notes --client_secret {{ NOTES_OAUTH2_SECRET }} \ --client_name edx-notes --client_id notes --client_secret {{ NOTES_OAUTH2_SECRET }} \
--trusted --logout_uri "http://notes.openedx:8000/logout/" --username notes --trusted --logout_uri "http://notes.openedx:8000/logout/" --username notes
{% endif %}""" {% endif %}"""

View File

@ -1,5 +1,5 @@
APPLICATION_ID=com.example.yourapp APPLICATION_ID={{ LMS_HOST_REVERSE }}
RELEASE_STORE_FILE=/openedx/config/your.keystore RELEASE_STORE_FILE=/openedx/config/app.keystore
RELEASE_STORE_PASSWORD=your store password here RELEASE_STORE_PASSWORD={{ ANDROID_STORE_PASSWORD }}
RELEASE_KEY_PASSWORD=your key password here RELEASE_KEY_PASSWORD={{ ANDROID_KEY_PASSWORD }}
RELEASE_KEY_ALIAS=your key alias here RELEASE_KEY_ALIAS={{ ANDROID_RELEASE_KEY_ALIAS }}

View File

@ -3,3 +3,4 @@ ENVIRONMENT_DISPLAY_NAME: 'tutor'
PLATFORM_NAME: '{{ PLATFORM_NAME }}' PLATFORM_NAME: '{{ PLATFORM_NAME }}'
PLATFORM_DESTINATION_NAME: '{{ LMS_HOST }}' PLATFORM_DESTINATION_NAME: '{{ LMS_HOST }}'
FEEDBACK_EMAIL_ADDRESS: 'support@{{ LMS_HOST }}' FEEDBACK_EMAIL_ADDRESS: 'support@{{ LMS_HOST }}'
OAUTH_CLIENT_ID: 'android'

View File

@ -7,10 +7,12 @@
"PLATFORM_NAME": "{{ PLATFORM_NAME }}", "PLATFORM_NAME": "{{ PLATFORM_NAME }}",
"FEATURES": { "FEATURES": {
"PREVIEW_LMS_BASE": "preview.{{ LMS_HOST }}", "PREVIEW_LMS_BASE": "preview.{{ LMS_HOST }}",
"ENABLE_OAUTH2_PROVIDER": true,
"ENABLE_COURSE_DISCOVERY": true, "ENABLE_COURSE_DISCOVERY": true,
"ENABLE_COURSEWARE_SEARCH": true, "ENABLE_COURSEWARE_SEARCH": true,
"ENABLE_DASHBOARD_SEARCH": true, "ENABLE_DASHBOARD_SEARCH": true,
"ENABLE_COMBINED_LOGIN_REGISTRATION": true,
"ENABLE_MOBILE_REST_API": true,
"ENABLE_OAUTH2_PROVIDER": true,
"ENABLE_EDXNOTES": {{ "true" if ACTIVATE_NOTES else "false" }} "ENABLE_EDXNOTES": {{ "true" if ACTIVATE_NOTES else "false" }}
}, },
"LMS_ROOT_URL": "{{ "https" if ACTIVATE_HTTPS else "http" }}://{{ LMS_HOST }}", "LMS_ROOT_URL": "{{ "https" if ACTIVATE_HTTPS else "http" }}://{{ LMS_HOST }}",

View File

@ -23,7 +23,8 @@ RUN wget https://dl.google.com/android/repository/sdk-tools-linux-${ANDROID_SDK_
RUN yes | /openedx/android-sdk/tools/bin/sdkmanager "platforms;android-27" 1> /dev/null RUN yes | /openedx/android-sdk/tools/bin/sdkmanager "platforms;android-27" 1> /dev/null
# Install android app repo # Install android app repo
RUN git clone https://github.com/edx/edx-app-android /openedx/edx-app-android # release/2.16.4 is the last know release to work with hawthorn
RUN git clone https://github.com/edx/edx-app-android --branch release/2.16.4 --depth 1 /openedx/edx-app-android
WORKDIR /openedx/edx-app-android WORKDIR /openedx/edx-app-android
# Install gradle and all dependencies # Install gradle and all dependencies

View File

@ -10,3 +10,6 @@ XQUEUE_MYSQL_USERNAME: "xqueue"
OPENEDX_DOCKER_IMAGE: "regis/openedx:hawthorn" OPENEDX_DOCKER_IMAGE: "regis/openedx:hawthorn"
NGINX_HTTP_PORT: 80 NGINX_HTTP_PORT: 80
NGINX_HTTPS_PORT: 443 NGINX_HTTPS_PORT: 443
ANDROID_RELEASE_STORE_PASSWORD: "android store password"
ANDROID_RELEASE_KEY_PASSWORD: "android release key password"
ANDROID_RELEASE_KEY_ALIAS: "android release key alias"

View File

@ -12,8 +12,8 @@ NOTES_OAUTH2_SECRET: "{{ RAND24 }}"
XQUEUE_AUTH_PASSWORD: "{{ RAND8 }}" XQUEUE_AUTH_PASSWORD: "{{ RAND8 }}"
XQUEUE_MYSQL_PASSWORD: "{{ RAND8 }}" XQUEUE_MYSQL_PASSWORD: "{{ RAND8 }}"
XQUEUE_SECRET_KEY: "{{ RAND24 }}" XQUEUE_SECRET_KEY: "{{ RAND24 }}"
ANDROID_OAUTH2_SECRET: "{{ RAND24 }}"
ACTIVATE_HTTPS: false ACTIVATE_HTTPS: false
ACTIVATE_NOTES: false ACTIVATE_NOTES: false
ACTIVATE_XQUEUE: false ACTIVATE_XQUEUE: false
ID: "{{ RAND8 }}" ID: "{{ RAND8 }}"
# pouac plonk