[ENROLLEE] Tizen enrollee sample application build using scons command
[platform/upstream/iotivity.git] / service / easy-setup / sdk / mediator / android / EasySetupCore / src / main / java / org / iotivity / service / easysetup / mediator / EnrolleeDeviceWiFiOnboarding.java
1 /**\r
2  * ***************************************************************\r
3  * <p/>\r
4  * Copyright 2015 Samsung Electronics All Rights Reserved.\r
5  * <p/>\r
6  * <p/>\r
7  * <p/>\r
8  * Licensed under the Apache License, Version 2.0 (the "License");\r
9  * you may not use this file except in compliance with the License.\r
10  * You may obtain a copy of the License at\r
11  * <p/>\r
12  * http://www.apache.org/licenses/LICENSE-2.0\r
13  * <p/>\r
14  * Unless required by applicable law or agreed to in writing, software\r
15  * distributed under the License is distributed on an "AS IS" BASIS,\r
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
17  * See the License for the specific language governing permissions and\r
18  * limitations under the License.\r
19  * <p/>\r
20  * ****************************************************************\r
21  */\r
22 \r
23 package org.iotivity.service.easysetup.mediator;\r
24 \r
25 import java.util.Timer;\r
26 import java.util.TimerTask;\r
27 \r
28 import org.iotivity.service.easysetup.core.EasySetupManager;\r
29 import org.iotivity.service.easysetup.core.EnrolleeInfo;\r
30 import org.iotivity.service.easysetup.core.IOnBoardingStatus;\r
31 import org.iotivity.service.easysetup.core.IProvisioningListener;\r
32 import org.iotivity.service.easysetup.core.ProvisionEnrollee;\r
33 import org.iotivity.service.easysetup.core.ip.WiFiSoftAPManager;\r
34 \r
35 import android.content.Context;\r
36 import android.net.wifi.WifiConfiguration;\r
37 import android.util.Log;\r
38 \r
39 /**\r
40  * This is a ready to use class for Enrollee device having Soft AP as on-boarding connectivity.\r
41  */\r
42 public class EnrolleeDeviceWiFiOnboarding extends EnrolleeDevice {\r
43 \r
44     public static final String TAG = EnrolleeDeviceWiFiOnboarding.class.getName();\r
45 \r
46     final Context mContext;\r
47     final WiFiSoftAPManager mWifiSoftAPManager;\r
48     EnrolleeInfo connectedDevice;\r
49     private EasySetupManager easySetupManagerNativeInstance;\r
50     ProvisionEnrollee provisionEnrolleInstance;\r
51     Timer myTimer = null;\r
52 \r
53     IOnBoardingStatus deviceScanListener = new IOnBoardingStatus() {\r
54 \r
55         @Override\r
56         public void deviceOnBoardingStatus(EnrolleeInfo enrolleStatus) {\r
57             myTimer.cancel();\r
58             Log.d("ESSoftAPOnBoarding", "Entered");\r
59             if (mState == EnrolleeState.DEVICE_ON_BOARDING_STATE) {\r
60                 Log.d("ESSoftAPOnBoarding", "Device in OnBoarding State");\r
61                 if (enrolleStatus != null && enrolleStatus.getIpAddr() != null) {\r
62                     String finalResult = "Easy Connect : ";\r
63 \r
64                     if (enrolleStatus.isReachable()) {\r
65                         finalResult = "Device OnBoarded" + "["\r
66                                 + enrolleStatus.getIpAddr() + "]";\r
67 \r
68                         connectedDevice = enrolleStatus;\r
69                         IpOnBoardingConnection conn = new IpOnBoardingConnection();\r
70 \r
71                         conn.setConnectivity(true);\r
72                         conn.setIp(connectedDevice.getIpAddr());\r
73                         conn.setHardwareAddress(enrolleStatus.getHWAddr());\r
74                         conn.setDeviceName(enrolleStatus.getDevice());\r
75 \r
76                         Log.d("ESSoftAPOnBoarding", "Entered" + finalResult);\r
77                         mOnBoardingCallback.onFinished(conn);\r
78                         return;\r
79 \r
80                     }\r
81                 }\r
82 \r
83                 IpOnBoardingConnection conn = new IpOnBoardingConnection();\r
84                 conn.setConnectivity(false);\r
85                 mOnBoardingCallback.onFinished(conn);\r
86             } else {\r
87                 Log.e("ESSoftAPOnBoarding", "Device NOT in OnBoarding State. Ignoring the event");\r
88             }\r
89         }\r
90     };\r
91 \r
92 \r
93     protected EnrolleeDeviceWiFiOnboarding(Context context, OnBoardingConfig onBoardingConfig,\r
94                                            ProvisioningConfig provConfig) {\r
95         super(onBoardingConfig, provConfig);\r
96         mContext = context;\r
97         mWifiSoftAPManager = new WiFiSoftAPManager(mContext);\r
98     }\r
99 \r
100     protected EnrolleeDeviceWiFiOnboarding(Context context, IpOnBoardingConnection conn,\r
101                                            ProvisioningConfig provConfig) {\r
102         super(new WiFiOnBoardingConfig(), provConfig);\r
103         mContext = context;\r
104         mConnection = conn;\r
105         mState = EnrolleeState.DEVICE_ON_BOARDED_STATE;\r
106         mWifiSoftAPManager = new WiFiSoftAPManager(mContext);\r
107     }\r
108 \r
109     @Override\r
110     protected void startOnBoardingProcess() {\r
111         Log.i(TAG, "Starting on boarding process");\r
112 \r
113         //1. Create Soft AP\r
114         boolean status = mWifiSoftAPManager.setWifiApEnabled((WifiConfiguration)\r
115                 mOnBoardingConfig.getConfig(), true);\r
116 \r
117         mState = EnrolleeState.DEVICE_ON_BOARDING_STATE;\r
118 \r
119         Log.i(TAG, "Soft AP is created with status " + status);\r
120 \r
121         myTimer = new Timer();\r
122         myTimer.schedule(new TimerTask() {\r
123             @Override\r
124             public void run() {\r
125                 // Below function to be called after 5 seconds\r
126                 mWifiSoftAPManager.getClientList(deviceScanListener, 300);\r
127             }\r
128 \r
129         }, 0, 5000);\r
130     }\r
131 \r
132     protected void stopOnBoardingProcess() {\r
133         Log.i(TAG, "Stopping on boarding process");\r
134         if(myTimer != null)\r
135         {\r
136             myTimer.cancel();\r
137         }\r
138         boolean status = mWifiSoftAPManager.setWifiApEnabled(null, false);\r
139         Log.i(TAG, "Soft AP is disabled with status " + status);\r
140     }\r
141 \r
142     @Override\r
143     protected void startProvisioningProcess(OnBoardingConnection conn) {\r
144 \r
145         mState = EnrolleeState.DEVICE_PROVISIONING_STATE;\r
146         mProvisioningCallback.onProgress(this);\r
147         final EnrolleeDevice device = this;\r
148         if (mProvConfig.getConnType() == ProvisioningConfig.ConnType.WiFi) {\r
149 \r
150             provisionEnrolleInstance = new ProvisionEnrollee(mContext);\r
151 \r
152             provisionEnrolleInstance.registerProvisioningHandler(new IProvisioningListener() {\r
153                 @Override\r
154                 public void onFinishProvisioning(int statuscode) {\r
155 \r
156                     Log.i(TAG, "Provisioning is finished with status code " + statuscode);\r
157                     mState = (statuscode == 0) ? EnrolleeState.DEVICE_PROVISIONED_STATE\r
158                             : EnrolleeState.DEVICE_INIT_STATE;\r
159                     stopOnBoardingProcess();\r
160                     mProvisioningCallback.onProgress(device);\r
161                     mProvisioningCallback.onFinished(EnrolleeDeviceWiFiOnboarding.this);\r
162                 }\r
163             });\r
164 \r
165             IpOnBoardingConnection connection = (IpOnBoardingConnection) conn;\r
166             WiFiProvConfig wifiProvConfig = (WiFiProvConfig) mProvConfig;\r
167 \r
168             easySetupManagerNativeInstance = EasySetupManager.getInstance();\r
169             easySetupManagerNativeInstance.setApplicationContext(mContext);\r
170             easySetupManagerNativeInstance.initEasySetup();\r
171 \r
172             // Native Api call to start provisioning of the enrolling device\r
173             easySetupManagerNativeInstance.provisionEnrollee(connection.getIp(), wifiProvConfig\r
174                     .getSsId(), wifiProvConfig.getPassword(), 1);\r
175         }\r
176     }\r
177 \r
178 \r
179 }\r