diff cagou/core/platform_/android.py @ 380:9d3481663964

android: handle new SàT specific "action" dict which may be attach to an intent: this data is used with notifications to tell the frontend which widget/target to open.
author Goffi <goffi@goffi.org>
date Tue, 04 Feb 2020 20:47:17 +0100
parents 4d660b252487
children eb3f622d8791
line wrap: on
line diff
--- a/cagou/core/platform_/android.py	Wed Jan 29 10:04:35 2020 +0100
+++ b/cagou/core/platform_/android.py	Tue Feb 04 20:47:17 2020 +0100
@@ -19,12 +19,14 @@
 import sys
 import os
 import socket
+import json
 from functools import partial
+from urllib.parse import urlparse
 from jnius import autoclass, cast
 from android import activity
 from sat.core.i18n import _
 from sat.core import log as logging
-from urllib.parse import urlparse
+from sat_frontends.tools import jid
 from cagou.core.constants import Const as C
 from cagou.core import dialog
 from cagou import G
@@ -52,6 +54,7 @@
 STATE_STOPPED = b"stopped"
 SOCKET_DIR = "/data/data/org.salutatoi.cagou/"
 SOCKET_FILE = ".socket"
+INTENT_EXTRA_ACTION = AndroidString("org.salut-a-toi.IntentAction")
 
 
 class Platform(BasePlatform):
@@ -190,7 +193,31 @@
         log.debug("on_new_intent")
         action = intent.getAction();
         intent_type = intent.getType();
-        if action == Intent.ACTION_SEND:
+        if action == Intent.ACTION_MAIN:
+            action_str = intent.getStringExtra(INTENT_EXTRA_ACTION)
+            if action_str is not None:
+                action = json.loads(action_str)
+                log.debug(f"Extra action found: {action}")
+                action_type = action.get('type')
+                if action_type == "open":
+                    try:
+                        widget = action['widget']
+                        target = action['target']
+                    except KeyError as e:
+                        log.warning(f"incomplete action {action}: {e}")
+                    else:
+                        current_profile = next(iter(G.host.profiles))
+                        Clock.schedule_once(
+                            lambda *args: G.host.doAction(
+                                widget, jid.JID(target), [current_profile]),
+                            0)
+                else:
+                    log.warning(f"unexpected action: {action}")
+
+            text = None
+            uri = None
+            path = None
+        elif action == Intent.ACTION_SEND:
             # we have receiving data to share, we parse the intent data
             # and show the share widget
             data = {}