annotate libervia/backend/plugins/plugin_misc_android.py @ 4180:b86912d3fd33

plugin IP: fix use of legacy URL + coroutine use: An https:/salut-a-toi.org URL was used to retrieve external IP, but it's not valid anymore, resulting in an exception. This feature is currently disabled. Also moved several methods from legacy inline callbacks to coroutines.
author Goffi <goffi@goffi.org>
date Sat, 09 Dec 2023 14:30:54 +0100
parents 4b842c1fb686
children 0d7bb4df2343
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
1 #!/usr/bin/env python3
3137
559a625a236b fixed shebangs
Goffi <goffi@goffi.org>
parents: 3136
diff changeset
2
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
3 # SAT plugin for file tansfer
3479
be6d91572633 date update
Goffi <goffi@goffi.org>
parents: 3245
diff changeset
4 # Copyright (C) 2009-2021 Jérôme Poisson (goffi@goffi.org)
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
5
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
6 # This program is free software: you can redistribute it and/or modify
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
7 # it under the terms of the GNU Affero General Public License as published by
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
8 # the Free Software Foundation, either version 3 of the License, or
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
9 # (at your option) any later version.
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
10
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
11 # This program is distributed in the hope that it will be useful,
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
14 # GNU Affero General Public License for more details.
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
15
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
16 # You should have received a copy of the GNU Affero General Public License
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
18
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
19 import sys
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
20 import os
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
21 import os.path
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
22 import json
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
23 from pathlib import Path
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
24 from zope.interface import implementer
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
25 from twisted.names import client as dns_client
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
26 from twisted.python.procutils import which
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
27 from twisted.internet import defer
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
28 from twisted.internet import reactor
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
29 from twisted.internet import protocol
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
30 from twisted.internet import abstract
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
31 from twisted.internet import error as int_error
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
32 from twisted.internet import _sslverify
4071
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
33 from libervia.backend.core.i18n import _, D_
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
34 from libervia.backend.core.constants import Const as C
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
35 from libervia.backend.core.log import getLogger
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
36 from libervia.backend.core import exceptions
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
37 from libervia.backend.tools.common import async_process
4b842c1fb686 refactoring: renamed `sat` package to `libervia.backend`
Goffi <goffi@goffi.org>
parents: 4051
diff changeset
38 from libervia.backend.memory import params
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
39
2624
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
40
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
41 log = getLogger(__name__)
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
42
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
43 PLUGIN_INFO = {
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
44 C.PI_NAME: "Android",
2145
33c8c4973743 core (plugins): added missing contants + use of new constants in PLUGIN_INFO
Goffi <goffi@goffi.org>
parents: 2100
diff changeset
45 C.PI_IMPORT_NAME: "android",
33c8c4973743 core (plugins): added missing contants + use of new constants in PLUGIN_INFO
Goffi <goffi@goffi.org>
parents: 2100
diff changeset
46 C.PI_TYPE: C.PLUG_TYPE_MISC,
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
47 C.PI_RECOMMENDATIONS: ["XEP-0352"],
2145
33c8c4973743 core (plugins): added missing contants + use of new constants in PLUGIN_INFO
Goffi <goffi@goffi.org>
parents: 2100
diff changeset
48 C.PI_MAIN: "AndroidPlugin",
33c8c4973743 core (plugins): added missing contants + use of new constants in PLUGIN_INFO
Goffi <goffi@goffi.org>
parents: 2100
diff changeset
49 C.PI_HANDLER: "no",
2624
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
50 C.PI_DESCRIPTION: D_(
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
51 """Manage Android platform specificities, like pause or notifications"""
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
52 ),
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
53 }
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
54
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
55 if sys.platform != "android":
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
56 raise exceptions.CancelError("this module is not needed on this platform")
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
57
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
58
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
59 import re
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
60 import certifi
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
61 from plyer import vibrator
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
62 from android import api_version
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
63 from plyer.platforms.android import activity
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
64 from plyer.platforms.android.notification import AndroidNotification
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
65 from jnius import autoclass
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
66 from android.broadcast import BroadcastReceiver
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
67 from android import python_act
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
68
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
69
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
70 Context = autoclass('android.content.Context')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
71 ConnectivityManager = autoclass('android.net.ConnectivityManager')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
72 MediaPlayer = autoclass('android.media.MediaPlayer')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
73 AudioManager = autoclass('android.media.AudioManager')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
74
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
75 # notifications
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
76 AndroidString = autoclass('java.lang.String')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
77 PendingIntent = autoclass('android.app.PendingIntent')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
78 Intent = autoclass('android.content.Intent')
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
79
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
80 # DNS
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
81 # regex to find dns server prop with "getprop"
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
82 RE_DNS = re.compile(r"^\[net\.[a-z0-9]+\.dns[0-4]\]: \[(.*)\]$", re.MULTILINE)
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
83 SystemProperties = autoclass('android.os.SystemProperties')
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
84
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
85 #: delay between a pause event and sending the inactive indication to server, in seconds
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
86 #: we don't send the indication immediately because user can be just checking something
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
87 #: quickly on an other app.
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
88 CSI_DELAY = 30
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
89
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
90 PARAM_RING_CATEGORY = "Notifications"
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
91 PARAM_RING_NAME = "sound"
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
92 PARAM_RING_LABEL = D_("sound on notifications")
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
93 RING_OPTS = {
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
94 "normal": D_("Normal"),
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
95 "never": D_("Never"),
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
96 }
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
97 PARAM_VIBRATE_CATEGORY = "Notifications"
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
98 PARAM_VIBRATE_NAME = "vibrate"
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
99 PARAM_VIBRATE_LABEL = D_("Vibrate on notifications")
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
100 VIBRATION_OPTS = {
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
101 "always": D_("Always"),
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
102 "vibrate": D_("In vibrate mode"),
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
103 "never": D_("Never"),
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
104 }
3480
7550ae9cfbac Renamed the project from "Salut à Toi" to "Libervia":
Goffi <goffi@goffi.org>
parents: 3479
diff changeset
105 SOCKET_DIR = "/data/data/org.libervia.cagou/"
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
106 SOCKET_FILE = ".socket"
3057
f91d0e6d9b13 plugin android: fixed encoding in states after Python 3 port
Goffi <goffi@goffi.org>
parents: 3028
diff changeset
107 STATE_RUNNING = b"running"
f91d0e6d9b13 plugin android: fixed encoding in states after Python 3 port
Goffi <goffi@goffi.org>
parents: 3028
diff changeset
108 STATE_PAUSED = b"paused"
f91d0e6d9b13 plugin android: fixed encoding in states after Python 3 port
Goffi <goffi@goffi.org>
parents: 3028
diff changeset
109 STATE_STOPPED = b"stopped"
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
110 STATES = (STATE_RUNNING, STATE_PAUSED, STATE_STOPPED)
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
111 NET_TYPE_NONE = "no network"
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
112 NET_TYPE_WIFI = "wifi"
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
113 NET_TYPE_MOBILE = "mobile"
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
114 NET_TYPE_OTHER = "other"
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
115 INTENT_EXTRA_ACTION = AndroidString("org.salut-a-toi.IntentAction")
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
116
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
117
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
118 @implementer(_sslverify.IOpenSSLTrustRoot)
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
119 class AndroidTrustPaths:
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
120
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
121 def _addCACertsToContext(self, context):
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
122 # twisted doesn't have access to Android root certificates
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
123 # we use certifi to work around that (same thing is done in Kivy)
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
124 context.load_verify_locations(certifi.where())
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
125
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
126
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
127 def platformTrust():
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
128 return AndroidTrustPaths()
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
129
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
130
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
131 class Notification(AndroidNotification):
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
132 # We extend plyer's AndroidNotification instead of creating directly with jnius
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
133 # because it already handles issues like backward compatibility, and we just want to
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
134 # slightly modify the behaviour.
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
135
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
136 @staticmethod
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
137 def _set_open_behavior(notification, sat_action):
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
138 # we reproduce plyer's AndroidNotification._set_open_behavior
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
139 # bu we add SàT specific extra action data
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
140
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
141 app_context = activity.getApplication().getApplicationContext()
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
142 notification_intent = Intent(app_context, python_act)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
143
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
144 notification_intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
145 notification_intent.setAction(Intent.ACTION_MAIN)
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
146 notification_intent.add_category(Intent.CATEGORY_LAUNCHER)
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
147 if sat_action is not None:
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
148 action_data = AndroidString(json.dumps(sat_action).encode())
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
149 log.debug(f"adding extra {INTENT_EXTRA_ACTION} ==> {action_data}")
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
150 notification_intent = notification_intent.putExtra(
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
151 INTENT_EXTRA_ACTION, action_data)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
152
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
153 # we use PendingIntent.FLAG_UPDATE_CURRENT here, otherwise extra won't be set
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
154 # in the new intent (the old ACTION_MAIN intent will be reused). This differs
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
155 # from plyers original behaviour which set no flag here
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
156 pending_intent = PendingIntent.getActivity(
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
157 app_context, 0, notification_intent, PendingIntent.FLAG_UPDATE_CURRENT
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
158 )
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
159
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
160 notification.setContentIntent(pending_intent)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
161 notification.setAutoCancel(True)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
162
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
163 def _notify(self, **kwargs):
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
164 # we reproduce plyer's AndroidNotification._notify behaviour here
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
165 # and we add handling of "sat_action" attribute (SàT specific).
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
166 # we also set, where suitable, default values to empty string instead of
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
167 # original None, as a string is expected (in plyer the empty string is used
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
168 # in the generic "notify" method).
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
169 sat_action = kwargs.pop("sat_action", None)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
170 noti = None
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
171 message = kwargs.get('message', '').encode('utf-8')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
172 ticker = kwargs.get('ticker', '').encode('utf-8')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
173 title = AndroidString(
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
174 kwargs.get('title', '').encode('utf-8')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
175 )
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
176 icon = kwargs.get('app_icon', '')
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
177
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
178 if kwargs.get('toast', False):
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
179 self._toast(message)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
180 return
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
181 else:
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
182 noti = self._build_notification(title)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
183
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
184 noti.setContentTitle(title)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
185 noti.setContentText(AndroidString(message))
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
186 noti.setTicker(AndroidString(ticker))
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
187
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
188 self._set_icons(noti, icon=icon)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
189 self._set_open_behavior(noti, sat_action)
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
190
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
191 self._open_notification(noti)
2868
5546613f5007 plugin android: workaround to seek() bug, fixing file upload:
Goffi <goffi@goffi.org>
parents: 2856
diff changeset
192
5546613f5007 plugin android: workaround to seek() bug, fixing file upload:
Goffi <goffi@goffi.org>
parents: 2856
diff changeset
193
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
194 class FrontendStateProtocol(protocol.Protocol):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
195
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
196 def __init__(self, android_plugin):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
197 self.android_plugin = android_plugin
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
198
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
199 def dataReceived(self, data):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
200 if data in STATES:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
201 self.android_plugin.state = data
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
202 else:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
203 log.warning("Unexpected data: {data}".format(data=data))
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
204
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
205
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
206 class FrontendStateFactory(protocol.Factory):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
207
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
208 def __init__(self, android_plugin):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
209 self.android_plugin = android_plugin
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
210
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
211 def buildProtocol(self, addr):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
212 return FrontendStateProtocol(self.android_plugin)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
213
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
214
2624
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
215
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
216 class AndroidPlugin(object):
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
217
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
218 params = """
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
219 <params>
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
220 <individual>
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
221 <category name="{category_name}" label="{category_label}">
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
222 <param name="{ring_param_name}" label="{ring_param_label}" type="list" security="0">
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
223 {ring_options}
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
224 </param>
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
225 <param name="{vibrate_param_name}" label="{vibrate_param_label}" type="list" security="0">
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
226 {vibrate_options}
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
227 </param>
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
228 </category>
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
229 </individual>
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
230 </params>
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
231 """.format(
2624
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
232 category_name=PARAM_VIBRATE_CATEGORY,
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
233 category_label=D_(PARAM_VIBRATE_CATEGORY),
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
234 vibrate_param_name=PARAM_VIBRATE_NAME,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
235 vibrate_param_label=PARAM_VIBRATE_LABEL,
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
236 vibrate_options=params.make_options(VIBRATION_OPTS, "always"),
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
237 ring_param_name=PARAM_RING_NAME,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
238 ring_param_label=PARAM_RING_LABEL,
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
239 ring_options=params.make_options(RING_OPTS, "normal"),
2624
56f94936df1e code style reformatting using black
Goffi <goffi@goffi.org>
parents: 2562
diff changeset
240 )
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
241
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
242 def __init__(self, host):
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
243 log.info(_("plugin Android initialization"))
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
244 log.info(f"using Android API {api_version}")
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
245 self.host = host
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
246 self._csi = host.plugins.get('XEP-0352')
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
247 self._csi_timer = None
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
248 host.memory.update_params(self.params)
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
249 try:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
250 os.mkdir(SOCKET_DIR, 0o700)
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
251 except OSError as e:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
252 if e.errno == 17:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
253 # dir already exists
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
254 pass
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
255 else:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
256 raise e
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
257 self._state = None
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
258 factory = FrontendStateFactory(self)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
259 socket_path = os.path.join(SOCKET_DIR, SOCKET_FILE)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
260 try:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
261 reactor.listenUNIX(socket_path, factory)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
262 except int_error.CannotListenError as e:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
263 if e.socketError.errno == 98:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
264 # the address is already in use, we need to remove it
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
265 os.unlink(socket_path)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
266 reactor.listenUNIX(socket_path, factory)
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
267 else:
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
268 raise e
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
269 # we set a low priority because we want the notification to be sent after all
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
270 # plugins have done their job
4051
c23cad65ae99 core: renamed `messageReceived` trigger to `message_received`
Goffi <goffi@goffi.org>
parents: 4037
diff changeset
271 host.trigger.add("message_received", self.message_received_trigger, priority=-1000)
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
272
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
273 # profiles autoconnection
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
274 host.bridge.add_method(
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
275 "profile_autoconnect_get",
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
276 ".plugin",
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
277 in_sign="",
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
278 out_sign="s",
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
279 method=self._profile_autoconnect_get,
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
280 async_=True,
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
281 )
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
282
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
283 # audio manager, to get ring status
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
284 self.am = activity.getSystemService(Context.AUDIO_SERVICE)
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
285
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
286 # sound notification
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
287 media_dir = Path(host.memory.config_get("", "media_dir"))
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
288 assert media_dir is not None
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
289 notif_path = media_dir / "sounds" / "notifications" / "music-box.mp3"
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
290 self.notif_player = MediaPlayer()
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
291 self.notif_player.setDataSource(str(notif_path))
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
292 self.notif_player.setAudioStreamType(AudioManager.STREAM_NOTIFICATION)
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
293 self.notif_player.prepare()
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
294
3245
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
295 # SSL fix
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
296 _sslverify.platformTrust = platformTrust
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
297 log.info("SSL Android patch applied")
2a0a16b906ac plugin android: use `certifi` SSL root certicates
Goffi <goffi@goffi.org>
parents: 3172
diff changeset
298
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
299 # DNS fix
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
300 defer.ensureDeferred(self.update_resolver())
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
301
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
302 # Connectivity handling
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
303 self.cm = activity.getSystemService(Context.CONNECTIVITY_SERVICE)
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
304 self._net_type = None
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
305 d = defer.ensureDeferred(self._check_connectivity())
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
306 d.addErrback(host.log_errback)
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
307
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
308 # XXX: we need to keep a reference to BroadcastReceiver to avoid
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
309 # "XXX has no attribute 'invoke'" error (looks like the same issue as
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
310 # https://github.com/kivy/pyjnius/issues/59)
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
311 self.br = BroadcastReceiver(
3654
3910ad643e9d plugin android: use `callFromThread` instead of `callLater`:
Goffi <goffi@goffi.org>
parents: 3480
diff changeset
312 callback=lambda *args, **kwargs: reactor.callFromThread(
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
313 self.on_connectivity_change
3654
3910ad643e9d plugin android: use `callFromThread` instead of `callLater`:
Goffi <goffi@goffi.org>
parents: 3480
diff changeset
314 ),
3910ad643e9d plugin android: use `callFromThread` instead of `callLater`:
Goffi <goffi@goffi.org>
parents: 3480
diff changeset
315 actions=["android.net.conn.CONNECTIVITY_CHANGE"]
3910ad643e9d plugin android: use `callFromThread` instead of `callLater`:
Goffi <goffi@goffi.org>
parents: 3480
diff changeset
316 )
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
317 self.br.start()
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
318
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
319 @property
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
320 def state(self):
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
321 return self._state
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
322
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
323 @state.setter
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
324 def state(self, new_state):
3057
f91d0e6d9b13 plugin android: fixed encoding in states after Python 3 port
Goffi <goffi@goffi.org>
parents: 3028
diff changeset
325 log.debug(f"frontend state has changed: {new_state.decode()}")
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
326 previous_state = self._state
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
327 self._state = new_state
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
328 if new_state == STATE_RUNNING:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
329 self._on_running(previous_state)
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
330 elif new_state == STATE_PAUSED:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
331 self._on_paused(previous_state)
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
332 elif new_state == STATE_STOPPED:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
333 self._on_stopped(previous_state)
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
334
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
335 @property
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
336 def cagou_active(self):
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
337 return self._state == STATE_RUNNING
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
338
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
339 def _on_running(self, previous_state):
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
340 if previous_state is not None:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
341 self.host.bridge.bridge_reactivate_signals()
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
342 self.set_active()
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
343
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
344 def _on_paused(self, previous_state):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
345 self.host.bridge.bridge_deactivate_signals()
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
346 self.set_inactive()
2841
90115cf4e731 plugin android: improved state handling:
Goffi <goffi@goffi.org>
parents: 2771
diff changeset
347
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
348 def _on_stopped(self, previous_state):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
349 self.set_inactive()
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
350
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
351 def _notify_message(self, mess_data, client):
2856
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
352 """Send notification when suitable
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
353
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
354 notification is sent if:
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
355 - there is a message and it is not a groupchat
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
356 - message is not coming from ourself
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
357 """
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
358 if (mess_data["message"] and mess_data["type"] != C.MESS_TYPE_GROUPCHAT
26d6ac4e4a66 plugin android: don't send notification if message comes from ourself (from an other device)
Goffi <goffi@goffi.org>
parents: 2841
diff changeset
359 and not mess_data["from"].userhostJID() == client.jid.userhostJID()):
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
360 message = next(iter(mess_data["message"].values()))
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
361 try:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
362 subject = next(iter(mess_data["subject"].values()))
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
363 except StopIteration:
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
364 subject = D_("new message from {contact}").format(
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
365 contact = mess_data['from'])
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
366
3154
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
367 notification = Notification()
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
368 notification._notify(
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
369 title=subject,
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
370 message=message,
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
371 sat_action={
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
372 "type": "open",
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
373 "widget": "chat",
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
374 "target": mess_data["from"].userhost(),
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
375 },
f2d3ab4390a3 plugin android: attach an action dict to notification:
Goffi <goffi@goffi.org>
parents: 3137
diff changeset
376 )
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
377
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
378 ringer_mode = self.am.getRingerMode()
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
379 vibrate_mode = ringer_mode == AudioManager.RINGER_MODE_VIBRATE
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
380
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
381 ring_setting = self.host.memory.param_get_a(
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
382 PARAM_RING_NAME,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
383 PARAM_RING_CATEGORY,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
384 profile_key=client.profile
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
385 )
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
386
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
387 if ring_setting != 'never' and ringer_mode == AudioManager.RINGER_MODE_NORMAL:
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
388 self.notif_player.start()
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
389
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
390 vibration_setting = self.host.memory.param_get_a(
3106
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
391 PARAM_VIBRATE_NAME,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
392 PARAM_VIBRATE_CATEGORY,
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
393 profile_key=client.profile
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
394 )
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
395 if (vibration_setting == 'always'
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
396 or vibration_setting == 'vibrate' and vibrate_mode):
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
397 try:
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
398 vibrator.vibrate()
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
399 except Exception as e:
7f7cdc6ecfd8 plugin android: sound notification + change settings:
Goffi <goffi@goffi.org>
parents: 3095
diff changeset
400 log.warning("Can't use vibrator: {e}".format(e=e))
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
401 return mess_data
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
402
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
403 def message_received_trigger(self, client, message_elt, post_treat):
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
404 if not self.cagou_active:
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
405 # we only send notification is the frontend is not displayed
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
406 post_treat.addCallback(self._notify_message, client)
2100
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
407
fbeeba721954 plugin android: first draft:
Goffi <goffi@goffi.org>
parents:
diff changeset
408 return True
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
409
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
410 # Profile autoconnection
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
411
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
412 def _profile_autoconnect_get(self):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
413 return defer.ensureDeferred(self.profile_autoconnect_get())
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
414
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
415 async def _get_profiles_autoconnect(self):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
416 autoconnect_dict = await self.host.memory.storage.get_ind_param_values(
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
417 category='Connection', name='autoconnect_backend',
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
418 )
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
419 return [p for p, v in autoconnect_dict.items() if C.bool(v)]
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
420
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
421 async def profile_autoconnect_get(self):
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
422 """Return profile to connect automatically by frontend, if any"""
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
423 profiles_autoconnect = await self._get_profiles_autoconnect()
3124
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
424 if not profiles_autoconnect:
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
425 return None
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
426 if len(profiles_autoconnect) > 1:
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
427 log.warning(
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
428 f"More that one profiles with backend autoconnection set found, picking "
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
429 f"up first one (full list: {profiles_autoconnect!r})")
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
430 return profiles_autoconnect[0]
b86060901278 plugin android: added a `profileAutoconnectGet` method:
Goffi <goffi@goffi.org>
parents: 3106
diff changeset
431
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
432 # CSI
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
433
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
434 def _set_inactive(self):
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
435 self._csi_timer = None
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
436 for client in self.host.get_clients(C.PROF_KEY_ALL):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
437 self._csi.set_inactive(client)
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
438
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
439 def set_inactive(self):
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
440 if self._csi is None or self._csi_timer is not None:
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
441 return
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
442 self._csi_timer = reactor.callLater(CSI_DELAY, self._set_inactive)
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
443
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
444 def set_active(self):
2872
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
445 if self._csi is None:
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
446 return
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
447 if self._csi_timer is not None:
6b00f88316bf plugin android: use XEP-0352 to indicate (in)active state:
Goffi <goffi@goffi.org>
parents: 2868
diff changeset
448 self._csi_timer.cancel()
2882
0c54970d8e6e plugin android: fixed csi_timer reset in setActive + crash on call of isActive before session initialisation
Goffi <goffi@goffi.org>
parents: 2872
diff changeset
449 self._csi_timer = None
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
450 for client in self.host.get_clients(C.PROF_KEY_ALL):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
451 self._csi.set_active(client)
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
452
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
453 # Connectivity
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
454
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
455 async def _handle_network_change(self, net_type):
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
456 """Notify the clients about network changes.
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
457
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
458 This way the client can disconnect/reconnect transport, or change delays
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
459 """
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
460 log.debug(f"handling network change ({net_type})")
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
461 if net_type == NET_TYPE_NONE:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
462 for client in self.host.get_clients(C.PROF_KEY_ALL):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
463 client.network_disabled()
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
464 else:
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
465 # DNS servers may have changed
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
466 await self.update_resolver()
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
467 # client may be there but disabled (e.g. with stream management)
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
468 for client in self.host.get_clients(C.PROF_KEY_ALL):
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
469 log.debug(f"enabling network for {client.profile}")
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
470 client.network_enabled()
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
471
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
472 # profiles may have been disconnected and then purged, we try
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
473 # to reconnect them in case
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
474 profiles_autoconnect = await self._get_profiles_autoconnect()
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
475 for profile in profiles_autoconnect:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
476 if not self.host.is_connected(profile):
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
477 log.info(f"{profile} is not connected, reconnecting it")
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
478 try:
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
479 await self.host.connect(profile)
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
480 except Exception as e:
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
481 log.error(f"Can't connect profile {profile}: {e}")
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
482
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
483 async def _check_connectivity(self):
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
484 active_network = self.cm.getActiveNetworkInfo()
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
485 if active_network is None:
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
486 net_type = NET_TYPE_NONE
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
487 else:
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
488 net_type_android = active_network.getType()
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
489 if net_type_android == ConnectivityManager.TYPE_WIFI:
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
490 net_type = NET_TYPE_WIFI
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
491 elif net_type_android == ConnectivityManager.TYPE_MOBILE:
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
492 net_type = NET_TYPE_MOBILE
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
493 else:
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
494 net_type = NET_TYPE_OTHER
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
495
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
496 if net_type != self._net_type:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
497 log.info("connectivity has changed")
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
498 self._net_type = net_type
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
499 if net_type == NET_TYPE_NONE:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
500 log.info("no network active")
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
501 elif net_type == NET_TYPE_WIFI:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
502 log.info("WIFI activated")
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
503 elif net_type == NET_TYPE_MOBILE:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
504 log.info("mobile data activated")
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
505 else:
3028
ab2696e34d29 Python 3 port:
Goffi <goffi@goffi.org>
parents: 3018
diff changeset
506 log.info("network activated (type={net_type_android})"
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
507 .format(net_type_android=net_type_android))
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
508 else:
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
509 log.debug("_check_connectivity called without network change ({net_type})"
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
510 .format(net_type = net_type))
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
511
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
512 # we always call _handle_network_change even if there is not connectivity change
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
513 # to be sure to reconnect when necessary
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
514 await self._handle_network_change(net_type)
3125
c3ce8c997fdf plugin android: reconnect profiles with autoconnect if network is activated:
Goffi <goffi@goffi.org>
parents: 3124
diff changeset
515
2887
9aadf11b315b plugin android: check connectivity
Goffi <goffi@goffi.org>
parents: 2882
diff changeset
516
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
517 def on_connectivity_change(self):
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
518 log.debug("on_connectivity_change called")
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
519 d = defer.ensureDeferred(self._check_connectivity())
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
520 d.addErrback(self.host.log_errback)
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
521
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
522 async def update_resolver(self):
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
523 # There is no "/etc/resolv.conf" on Android, which confuse Twisted and makes
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
524 # SRV record checking unusable. We fixe that by checking DNS server used, and
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
525 # updating Twisted's resolver accordingly
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
526 dns_servers = await self.get_dns_servers()
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
527
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
528 log.info(
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
529 "Patching Twisted to use Android DNS resolver ({dns_servers})".format(
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
530 dns_servers=', '.join([s[0] for s in dns_servers]))
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
531 )
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
532 dns_client.theResolver = dns_client.createResolver(servers=dns_servers)
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
533
4037
524856bd7b19 massive refactoring to switch from camelCase to snake_case:
Goffi <goffi@goffi.org>
parents: 3654
diff changeset
534 async def get_dns_servers(self):
3162
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
535 servers = []
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
536
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
537 if api_version < 26:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
538 # thanks to A-IV at https://stackoverflow.com/a/11362271 for the way to go
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
539 log.debug("Old API, using SystemProperties to find DNS")
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
540 for idx in range(1, 5):
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
541 addr = SystemProperties.get(f'net.dns{idx}')
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
542 if abstract.isIPAddress(addr):
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
543 servers.append((addr, 53))
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
544 else:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
545 log.debug(f"API {api_version} >= 26, using getprop to find DNS")
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
546 # use of getprop inspired by various solutions at
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
547 # https://stackoverflow.com/q/3070144
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
548 # it's the most simple option, and it fit wells with async_process
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
549 getprop_paths = which('getprop')
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
550 if getprop_paths:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
551 try:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
552 getprop_path = getprop_paths[0]
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
553 props = await async_process.run(getprop_path)
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
554 servers = [(ip, 53) for ip in RE_DNS.findall(props.decode())
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
555 if abstract.isIPAddress(ip)]
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
556 except Exception as e:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
557 log.warning(f"Can't use \"getprop\" to find DNS server: {e}")
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
558 if not servers:
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
559 # FIXME: Cloudflare's 1.1.1.1 seems to have a better privacy policy, to be
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
560 # checked.
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
561 log.warning(
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
562 "no server found, we have to use factory Google DNS, this is not ideal "
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
563 "for privacy"
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
564 )
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
565 servers.append(('8.8.8.8', 53), ('8.8.4.4', 53))
b5c058c7692e core (xmpp), plugin android: fixed DNS, SRV handling on Android:
Goffi <goffi@goffi.org>
parents: 3154
diff changeset
566 return servers