forked from homeworkc/lazycast
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmice.py
executable file
·216 lines (161 loc) · 7.5 KB
/
mice.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
#!/usr/bin/env python2
"""
This software is part of lazycast, a simple wireless display receiver for Raspberry Pi
Copyright (C) 2020 Hsun-Wei Cho
Modified from the p2p_group_add example of wpa_supplicant
# Tests p2p_group_add
######### MAY NEED TO RUN AS SUDO #############
Using any part of the code in commercial products is prohibited.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
"""
import dbus
import sys, os
import time
import gobject
import threading
import socket
from dbus.mainloop.glib import DBusGMainLoop
from time import sleep
from threading import Event
##################### Settings #####################
hostname = socket.gethostname()
# hostname = 'raspberrypi'
# If ./mice.py and ./project.py do not run on the same machine,
# hostname and ipstr should be the those of the machine running ./project.py
ipstr = ''
# ipstr = '192.168.1.5'
concurrent = 0
# 0: Accept MICE connection only
# 1: Accept MICE and wifi p2p connections
event = Event()
ippipe = os.popen('hostname -I')
ipstrs = ippipe.read()
ippipe.close()
ipstrs = ipstrs[:ipstrs.find(' \n')]
ipelems = ipstrs.split(' ')
if len(ipelems)>1 and ipstr == '':
print('Warning:')
print('This machine has multiple IP addresses:')
for ipelem in ipelems:
print(ipelem)
ipstr = ipelems[0]
print('A PC will try to connect to '+ipstr+' directly if mDNS fails')
print('Set the variable "ipstr" in mice.py to another IP manually if '+ipstr+' does not work')
def groupStarted(properties):
print "groupStarted: " + str(properties)
g_obj = dbus.SystemBus().get_object('fi.w1.wpa_supplicant1',properties['group_object'])
res = g_obj.GetAll('fi.w1.wpa_supplicant1.Group', dbus_interface=dbus.PROPERTIES_IFACE, byte_arrays=True)
print "Group properties: " + str(res)
hostnamehex = hostname.encode('hex')
hostnamemessage = '2002'+'{:04X}'.format(len(hostname))+hostnamehex
ipmessage = ''
if ipstr != '':
# The spec supportes multiple ip attributes. However, Windows will only try the first one
iphex = ipstr.encode('hex')
ipmessage = '2005'+'{:04X}'.format(len(iphex)/2)+iphex
capandhostmessage = '0001372001000105' + hostnamemessage + ipmessage
innerarray = []
for c in capandhostmessage.decode('hex'):
innerarray.append(dbus.Byte(c))
g_obj.Set('fi.w1.wpa_supplicant1.Group', 'WPSVendorExtensions',
dbus.Array([dbus.Array(innerarray, signature=dbus.Signature('ay'))], signature=dbus.Signature('ay')),dbus_interface=dbus.PROPERTIES_IFACE)
g_obj = dbus.SystemBus().get_object('fi.w1.wpa_supplicant1',properties['group_object'])
res = g_obj.GetAll('fi.w1.wpa_supplicant1.Group', dbus_interface=dbus.PROPERTIES_IFACE, byte_arrays=True)
print "Group properties: " + str(res)
event.set()
def WpsFailure(status, etc):
print("WPS Authentication Failure".format(status))
print(etc)
os._exit(0)
class P2P_Group_Add (threading.Thread):
# Needed Variables
global bus
global wpas_object
global interface_object
global interfacep2pdevice
global interface_name
global wpas
global wpas_dbus_interface
global path
# Dbus Paths
global wpas_dbus_opath
global wpas_dbus_interfaces_opath
global wpas_dbus_interfaces_interface
global wpas_dbus_interfaces_p2pdevice
# Constructor
def __init__(self,interface_name,wpas_dbus_interface):
# Initializes variables and threads
self.interface_name = interface_name
self.wpas_dbus_interface = wpas_dbus_interface
# Initializes thread and daemon allows for ctrl-c kill
threading.Thread.__init__(self)
self.daemon = True
# Generating interface/object paths
self.wpas_dbus_opath = "/" + self.wpas_dbus_interface.replace(".","/")
self.wpas_wpas_dbus_interfaces_opath = self.wpas_dbus_opath + "/Interfaces"
self.wpas_dbus_interfaces_interface = self.wpas_dbus_interface + ".Interface"
self.wpas_dbus_interfaces_p2pdevice = self.wpas_dbus_interfaces_interface + ".P2PDevice"
# Getting interfaces and objects
DBusGMainLoop(set_as_default=True)
self.bus = dbus.SystemBus()
self.wpas_object = self.bus.get_object(self.wpas_dbus_interface, self.wpas_dbus_opath)
self.wpas = dbus.Interface(self.wpas_object, self.wpas_dbus_interface)
# Try to see if supplicant knows about interface
# If not, throw an exception
try:
self.path = self.wpas.GetInterface(self.interface_name)
except dbus.DBusException as exc:
error = 'Error:\n Interface ' + self.interface_name + ' was not found'
print(error)
usage()
os._exit(0)
self.interface_object = self.bus.get_object(self.wpas_dbus_interface, self.path)
self.interfacep2pdevice = dbus.Interface(self.interface_object, self.wpas_dbus_interfaces_p2pdevice)
self.bus.add_signal_receiver(groupStarted, dbus_interface=self.wpas_dbus_interfaces_p2pdevice,
signal_name="GroupStarted")
self.bus.add_signal_receiver(WpsFailure, dbus_interface=self.wpas_dbus_interfaces_p2pdevice,
signal_name="WpsFailed")
def setarguments(self):
props = self.interface_object.GetAll(self.wpas_dbus_interfaces_p2pdevice,dbus_interface=dbus.PROPERTIES_IFACE)
print(props)
print ''
dbus.Interface(self.interface_object, dbus_interface=dbus.PROPERTIES_IFACE).Set(self.wpas_dbus_interfaces_p2pdevice, 'P2PDeviceConfig',dbus.Dictionary({ 'DeviceName' : hostname},signature='sv'))
dbus.Interface(self.interface_object, dbus_interface=dbus.PROPERTIES_IFACE).Set(self.wpas_dbus_interfaces_p2pdevice, 'P2PDeviceConfig',dbus.Dictionary({dbus.String(u'PrimaryDeviceType'): dbus.Array([dbus.Byte(0), dbus.Byte(7), dbus.Byte(0), dbus.Byte(80), dbus.Byte(242), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0)])},signature='sv'))
dbus.Interface(self.wpas_object, dbus_interface=dbus.PROPERTIES_IFACE).Set('fi.w1.wpa_supplicant1', dbus.String(u'WFDIEs'), dbus.Array([dbus.Byte(0), dbus.Byte(0), dbus.Byte(6), dbus.Byte(1), dbus.Byte(81), dbus.Byte(2), dbus.Byte(42), dbus.Byte(1), dbus.Byte(44), dbus.Byte(1), dbus.Byte(0), dbus.Byte(6), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(6), dbus.Byte(0), dbus.Byte(7), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0), dbus.Byte(0)], signature=dbus.Signature('y'), variant_level=1))
props = self.wpas_object.GetAll('fi.w1.wpa_supplicant1',dbus_interface=dbus.PROPERTIES_IFACE)
print(props)
print ''
def run(self):
groupadddict = {'persistent':False}
try:
self.interfacep2pdevice.GroupAdd(groupadddict)
except:
print('Warning:\n Could not preform group add')
print 'If existing beacon does not function properly, run ./removep2p.sh first.'
print 'Now running ./project.py'
event.set()
gobject.MainLoop().get_context().iteration(True)
gobject.threads_init()
gobject.MainLoop().run()
if __name__ == "__main__":
try:
p2p_group_add_test = P2P_Group_Add('wlan0','fi.w1.wpa_supplicant1')
except:
print("Error:\n Invalid Arguements")
p2p_group_add_test.setarguments()
p2p_group_add_test.start()
event.wait()
if concurrent == 1:
os.system('./all.sh &')
execfile('project.py')
# print("Error:\n Group formation timed out")
# os._exit(0)