summaryrefslogtreecommitdiffstats
path: root/bluetooth.py
diff options
context:
space:
mode:
authorEdi Feschiyan <edi.feschiyan@konsulko.com>2020-03-12 18:38:18 +0200
committerEdi Feschiyan <edi.feschiyan@konsulko.com>2020-03-12 18:38:18 +0200
commit1cd18d024c69369a6e502db4cd1d1acddf1e0958 (patch)
treed205e82ec918f080e05cba5b00a48ee01132cf01 /bluetooth.py
parentba673345466a365adb107a32dc4143390d4032eb (diff)
fixed wrong argument in websocket - sending string instead int in json for aglbaseservice
Diffstat (limited to 'bluetooth.py')
-rw-r--r--bluetooth.py64
1 files changed, 48 insertions, 16 deletions
diff --git a/bluetooth.py b/bluetooth.py
index 13ab0c9..c5394bb 100644
--- a/bluetooth.py
+++ b/bluetooth.py
@@ -1,10 +1,12 @@
import asyncio
+import json
+import os
from random import randint
from aglbaseservice import AGLBaseService
Verbs = ['subscribe', 'unsubscribe', 'managed_objects', 'adapter_state', 'default_adapter', 'avrcp_controls',
'connect', 'disconnect', 'pair', 'cancel_pairing', 'confirm_pairing', 'remove_device']
-
+AdapterStateParams = ['discovery', 'discoverable', 'powered', ]
BTEventType = ['adapter_changes', 'device_changes', 'media', 'agent']
class BluetoothService(AGLBaseService):
@@ -12,27 +14,30 @@ class BluetoothService(AGLBaseService):
def __init__(self, ip, port):
super().__init__(api='Bluetooth-Manager', ip=ip, port=port)
- async def subscribe(self, event='location'):
- super().subscribe(event=event)
+ async def subscribe(self, event='device_changes'):
+ await super().subscribe(event=event)
- async def unsubscribe(self, event='location'):
- super().unsubscribe(event=event)
+ async def unsubscribe(self, event='device_changes'):
+ await super().unsubscribe(event=event)
async def managed_objects(self):
verb = 'managed_objects'
msgid = randint(0, 999999)
msg = f'[2,"{msgid}","{self.api}/{verb}",""]'
- print(msg)
+ # print(msg)
await self.send(msg)
return await self.receive()
- async def adapter_state(self, param = None, value = None):
+ async def adapter_state(self, param=None, value=None):
verb = 'adapter_state'
msgid = randint(0, 999999)
if param:
- p = str({'adapter': param})
+ p = {'adapter': param}
+ if isinstance(value, dict):
+ p = {**p, **value}
+
# msg = f'[2,"{msgid}","{self.api}/{verb}","{param}": {value if value is not None else ""}]'
- msg = f'[2,"{msgid}","{self.api}/{verb}", {p}]'
+ msg = f'[2,"{msgid}","{self.api}/{verb}", {json.dumps(p)}]'
else:
msg = f'[2,"{msgid}","{self.api}/{verb}", ""]'
@@ -44,21 +49,48 @@ class BluetoothService(AGLBaseService):
verb = 'default_adapter'
msgid = randint(0, 999999)
msg = f'[2,"{msgid}","{self.api}/{verb}",""]'
- print(msg)
+ # print(msg)
await self.send(msg)
return await self.receive()
async def avrcp_controls(self):
pass
+ async def connect(self, device):
+ verb = 'connect'
+ msgid = randint(0, 999999)
+ d = {'device': device}
+ msg = f'[2,"{msgid}","{self.api}/{verb}","{json.dumps(d)}"]'
+
+ async def disconnect(self, device):
+ verb = 'disconnect'
+ msgid = randint(0, 999999)
+ d = {'device': device}
+ msg = f'[2,"{msgid}","{self.api}/{verb}","{json.dumps(d)}"]'
+
+ async def pair(self, device):
+ verb = 'pair'
+ msgid = randint(0, 999999)
+ d = {'device': device}
+ msg = f'[2,"{msgid}","{self.api}/{verb}","{json.dumps(d)}"]'
+
+ async def cancel_pairing(self):
+ verb = 'cancel_pairing'
+ msgid = randint(0, 999999)
+ msg = f'[2,"{msgid}","{self.api}/{verb}",""]'
+
+ async def confirm_pairing(self, pincode):
+ verb = 'confirm_pairing'
+ msgid = randint(0, 999999)
+ d = {'pincode': pincode}
+ msg = f'[2,"{msgid}","{self.api}/{verb}","{json.dumps(d)}"]'
async def main(loop):
- BTS = await BluetoothService(ip='192.168.234.202', port='30005')
- #print(await BTS.managed_objects())
- print(await BTS.adapter_state('hci0', '{"discoverable": true}'))
- await asyncio.sleep(delay=1)
- print(await BTS.adapter_state('hci0'))
- print(await BTS.adapter_state('hci1', '""'))
+ addr = os.environ.get('AGL_TGT_IP', 'localhost')
+ port = os.environ.get('AGL_TGT_PORT', '30005')
+
+ BTS = await BluetoothService(ip=addr, port=port)
+ print(await BTS.adapter_state('hci1', {'uuids': ['0000110e-0000-1000-8000-00805f9b34fb']}))
if __name__ == '__main__':
loop = asyncio.get_event_loop()