2 * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 using System.Threading.Tasks;
19 using System.Threading;
20 using Tizen.Applications;
22 namespace Tizen.Network.WiFi
24 internal static class EventHandlerExtension
26 internal static void SafeInvoke(this EventHandler evt, object sender, EventArgs e)
35 internal static void SafeInvoke<T>(this EventHandler<T> evt, object sender, T e) where T : EventArgs
45 internal partial class WiFiManagerImpl
47 private event EventHandler<DeviceStateChangedEventArgs> _deviceStateChanged;
48 private event EventHandler<ConnectionStateChangedEventArgs> _connectionStateChanged;
49 private event EventHandler<RssiLevelChangedEventArgs> _rssiLevelChanged;
50 private event EventHandler _backgroundScanFinished;
52 private Interop.WiFi.DeviceStateChangedCallback _deviceChangedCallback;
53 private Interop.WiFi.ConnectionStateChangedCallback _connectionChangedCallback;
54 private Interop.WiFi.RssiLevelChangedCallback _rssiChangedCallback;
55 private Interop.WiFi.VoidCallback _backgroundScanFinishedCallback;
57 internal event EventHandler<DeviceStateChangedEventArgs> DeviceStateChanged
63 if (_deviceStateChanged == null)
67 RegisterDeviceStateChangedEvent();
70 Log.Error(Globals.LogTag, "Exception on adding DeviceStateChanged\n" + e.ToString());
74 _deviceStateChanged += value;
81 _deviceStateChanged -= value;
82 if (_deviceStateChanged == null)
86 UnregisterDeviceStateChangedEvent();
90 Log.Error(Globals.LogTag, "Exception on removing DeviceStateChanged\n" + e.ToString());
97 internal event EventHandler<ConnectionStateChangedEventArgs> ConnectionStateChanged
103 if (_connectionStateChanged == null)
107 RegisterConnectionStateChangedEvent();
111 Log.Error(Globals.LogTag, "Exception on adding ConnectionStateChanged\n" + e.ToString());
115 _connectionStateChanged += value;
122 _connectionStateChanged -= value;
123 if (_connectionStateChanged == null)
127 UnregisterConnectionStateChangedEvent();
131 Log.Error(Globals.LogTag, "Exception on removing ConnectionStateChanged\n" + e.ToString());
138 internal event EventHandler<RssiLevelChangedEventArgs> RssiLevelChanged
144 if (_rssiLevelChanged == null)
148 RegisterRssiLevelChangedEvent();
152 Log.Error(Globals.LogTag, "Exception on adding RssiLevelChanged\n" + e.ToString());
156 _rssiLevelChanged += value;
163 _rssiLevelChanged -= value;
164 if (_rssiLevelChanged == null)
168 UnregisterRssiLevelChangedEvent();
172 Log.Error(Globals.LogTag, "Exception on removing RssiLevelChanged\n" + e.ToString());
179 internal event EventHandler BackgroundScanFinished
185 if (_backgroundScanFinished == null)
189 RegisterBackgroundScanFinishedEvent();
193 Log.Error(Globals.LogTag, "Exception on adding BackgroundScanFinished\n" + e.ToString());
197 _backgroundScanFinished += value;
204 _backgroundScanFinished -= value;
205 if (_backgroundScanFinished == null)
209 UnregisterBackgroundScanFinishedEvent();
213 Log.Error(Globals.LogTag, "Exception on removing BackgroundScanFinished\n" + e.ToString());
220 private void RegisterDeviceStateChangedEvent()
222 Log.Info(Globals.LogTag, "RegisterDeviceStateChangedEvent in Thread " + Thread.CurrentThread.ManagedThreadId);
223 _deviceChangedCallback = (int deviceState, IntPtr userDate) =>
225 WiFiDeviceState state = (WiFiDeviceState)deviceState;
226 DeviceStateChangedEventArgs e = new DeviceStateChangedEventArgs(state);
227 _deviceStateChanged.SafeInvoke(null, e);
229 int ret = Interop.WiFi.SetDeviceStateChangedCallback(GetSafeHandle(), _deviceChangedCallback, IntPtr.Zero);
230 if (ret != (int)WiFiError.None)
232 Log.Error(Globals.LogTag, "Failed to set device state changed callback, Error - " + (WiFiError)ret);
236 private void UnregisterDeviceStateChangedEvent()
238 Log.Info(Globals.LogTag, "UnregisterDeviceStateChangedEvent in Thread " + Thread.CurrentThread.ManagedThreadId);
239 int ret = Interop.WiFi.UnsetDeviceStateChangedCallback(GetSafeHandle());
240 if (ret != (int)WiFiError.None)
242 Log.Error(Globals.LogTag, "Failed to unset device state changed callback, Error - " + (WiFiError)ret);
246 private void RegisterConnectionStateChangedEvent()
248 _connectionChangedCallback = (int connectionState, IntPtr ap, IntPtr userData) =>
250 if (ap != IntPtr.Zero)
252 WiFiConnectionState state = (WiFiConnectionState)connectionState;
253 ConnectionStateChangedEventArgs e = new ConnectionStateChangedEventArgs(state, ap);
254 _connectionStateChanged.SafeInvoke(null, e);
257 int ret = Interop.WiFi.SetConnectionStateChangedCallback(GetSafeHandle(), _connectionChangedCallback, IntPtr.Zero);
258 if (ret != (int)WiFiError.None)
260 Log.Error(Globals.LogTag, "Failed to set copnnection state changed callback, Error - " + (WiFiError)ret);
264 private void UnregisterConnectionStateChangedEvent()
266 int ret = Interop.WiFi.UnsetConnectionStateChangedCallback(GetSafeHandle());
267 if (ret != (int)WiFiError.None)
269 Log.Error(Globals.LogTag, "Failed to unset device state changed callback, Error - " + (WiFiError)ret);
273 private void RegisterRssiLevelChangedEvent()
276 _rssiChangedCallback = (int rssiLevel, IntPtr userDate) =>
278 WiFiRssiLevel level = (WiFiRssiLevel)rssiLevel;
279 RssiLevelChangedEventArgs e = new RssiLevelChangedEventArgs(level);
280 _rssiLevelChanged.SafeInvoke(null, e);
282 int ret = Interop.WiFi.SetRssiLevelchangedCallback(GetSafeHandle(), _rssiChangedCallback, IntPtr.Zero);
283 if (ret != (int)WiFiError.None)
285 Log.Error(Globals.LogTag, "Failed to set rssi level changed callback, Error - " + (WiFiError)ret);
289 private void UnregisterRssiLevelChangedEvent()
291 int ret = Interop.WiFi.UnsetRssiLevelchangedCallback(GetSafeHandle());
292 if (ret != (int)WiFiError.None)
294 Log.Error(Globals.LogTag, "Failed to unset rssi level changed callback, Error - " + (WiFiError)ret);
298 private void RegisterBackgroundScanFinishedEvent()
300 _backgroundScanFinishedCallback = (int result, IntPtr userDate) =>
302 EventArgs e = new EventArgs();
303 _backgroundScanFinished.SafeInvoke(null, e);
305 int ret = Interop.WiFi.SetBackgroundScanCallback(GetSafeHandle(), _backgroundScanFinishedCallback, IntPtr.Zero);
306 if (ret != (int)WiFiError.None)
308 Log.Error(Globals.LogTag, "Failed to set background scan callback, Error - " + (WiFiError)ret);
312 private void UnregisterBackgroundScanFinishedEvent()
314 int ret = Interop.WiFi.UnsetBackgroundScanCallback(GetSafeHandle());
315 if (ret != (int)WiFiError.None)
317 Log.Error(Globals.LogTag, "Failed to unset background scan callback, Error - " + (WiFiError)ret);