Merge branch 'master' into 'security-basecamp'
[platform/upstream/iotivity.git] / resource / csdk / connectivity / src / bt_le_adapter / android / caleutils.h
1 /******************************************************************
2  *
3  * Copyright 2014 Samsung Electronics All Rights Reserved.
4  *
5  *
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  ******************************************************************/
20
21 /**
22  * @file caleutils.h
23  * @brief This file contains the APIs for BT LE communications.
24  */
25 #ifndef CA_LE_UTILS_H_
26 #define CA_LE_UTILS_H_
27
28 #include "cacommon.h"
29 #include "cathreadpool.h"
30 #include "cagattservice.h"
31 #include "uarraylist.h"
32 #include "jni.h"
33
34 #ifdef __cplusplus
35 extern "C"
36 {
37 #endif
38
39 /* Service UUID */
40 static const char OIC_GATT_SERVICE_UUID[] = CA_GATT_SERVICE_UUID;
41 static const char OIC_GATT_CHARACTERISTIC_REQUEST_UUID[] = CA_GATT_REQUEST_CHRC_UUID;
42 static const char OIC_GATT_CHARACTERISTIC_RESPONSE_UUID[] = CA_GATT_RESPONSE_CHRC_UUID;
43 static const char OIC_GATT_CHARACTERISTIC_CONFIG_UUID[] = "00002902-0000-1000-8000-00805f9b34fb";
44
45 static const jint GATT_SUCCESS = 0;
46
47 static const jint BOND_BONDED = 12;
48 static const jint BOND_BONDING = 11;
49 static const jint BOND_NONE = 10;
50
51 /**
52  * @brief   get uuid(jni object) from uuid(character)
53  * @param   env              [IN] JNI interface pointer
54  * @param   uuid             [IN] uuid(character)
55  * @return  uuid(jni object)
56  */
57 jobject CALEGetUuidFromString(JNIEnv *env, const char* uuid);
58
59 /**
60  * @brief   get parcel uuid object
61  * @param   env              [IN] JNI interface pointer
62  * @param   uuid             [IN] uuid (jni object)
63  * @return  parcel uuid object
64  */
65 jobject CALEGetParcelUuid(JNIEnv *env, jobject uuid);
66
67 /**
68  * @brief   get address from a local device
69  * @param   env              [IN] JNI interface pointer
70  * @return  local address
71  */
72 jstring CALEGetLocalDeviceAddress(JNIEnv *env);
73
74 /**
75  * @brief   get bonded list
76  * @param   env              [IN] JNI interface pointer
77  * @return  bonded list
78  */
79 jobjectArray CALEGetBondedDevices(JNIEnv *env);
80
81 /**
82  * @brief   get constants information of bluetooth state-on
83  * @param   env              [IN] JNI interface pointer
84  * @return  constants information of bluetooth state-on
85  */
86 jint CALEGetBTStateOnInfo(JNIEnv *env);
87
88 /**
89  * @brief   check this device can be supported as BLE client or server
90  * @param   env              [IN] JNI interface pointer
91  * @param   level            [IN] Android API Level to support
92  * @return  CA_STATUS_OK or ERROR CODES (CAResult_t error codes in cacommon.h)
93  */
94 CAResult_t CALECheckPlatformVersion(JNIEnv *env, uint16_t level);
95
96 /**
97  * @brief   get constants information of android.os.Build.VERSION.SDK_INT
98  * @param   env              [IN] JNI interface pointer
99  * @return  constants information of android.os.Build.VERSION.SDK_INT
100  */
101 jint CALEGetBuildVersion(JNIEnv *env);
102
103 /**
104  * @brief   get constants information of android.os.Build.VERSION_CODES.[VersionName]
105  * @param   env              [IN] JNI interface pointer
106  * @param   versionName      [IN] version name (.., KITKAT, LOLLIPOP, ..)
107  * @return  constants information of android.os.Build.VERSION_CODES.[VersionName]
108  */
109 jint CALEGetBuildVersionCodeForName(JNIEnv *env, const char* versionName);
110
111 /**
112  * @brief   get bluetooth adapter state information
113  * @param   env              [IN] JNI interface pointer
114  * @return  JNI_TRUE if the local adapter is turned on
115  */
116 jboolean CALEIsEnableBTAdapter(JNIEnv *env);
117
118 /**
119  * @brief   get address from remote device
120  * @param   env              [IN] JNI interface pointer
121  * @param   bluetoothDevice  [IN] bluetooth device object
122  * @return  remote address
123  */
124 jstring CALEGetAddressFromBTDevice(JNIEnv *env, jobject bluetoothDevice);
125
126 #ifdef __cplusplus
127 } /* extern "C" */
128 #endif
129
130 #endif /* CA_LE_UTILS_H_ */