1 /****************************************************************************
2 **
3 ** Copyright (C) 2016 Centria research and development
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the QtNfc module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 3 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL3 included in the
21 ** packaging of this file. Please review the following information to
22 ** ensure the GNU Lesser General Public License version 3 requirements
23 ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24 **
25 ** GNU General Public License Usage
26 ** Alternatively, this file may be used under the terms of the GNU
27 ** General Public License version 2.0 or (at your option) the GNU General
28 ** Public license version 3 or any later version approved by the KDE Free
29 ** Qt Foundation. The licenses are as published by the Free Software
30 ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31 ** included in the packaging of this file. Please review the following
32 ** information to ensure the GNU General Public License requirements will
33 ** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34 ** https://www.gnu.org/licenses/gpl-3.0.html.
35 **
36 ** $QT_END_LICENSE$
37 **
38 ****************************************************************************/
39 
40 #include "androidjninfc_p.h"
41 
42 #include <android/log.h>
43 
44 #include "androidmainnewintentlistener_p.h"
45 
46 #include "qglobal.h"
47 #include "qbytearray.h"
48 #include "qdebug.h"
49 
50 static const char *nfcClassName = "org/qtproject/qt5/android/nfc/QtNfc";
51 
52 static AndroidNfc::MainNfcNewIntentListener mainListener;
53 
54 QT_BEGIN_ANDROIDNFC_NAMESPACE
55 
startDiscovery()56 bool startDiscovery()
57 {
58     return QAndroidJniObject::callStaticMethod<jboolean>(nfcClassName,"start");
59 }
60 
isAvailable()61 bool isAvailable()
62 {
63     return QAndroidJniObject::callStaticMethod<jboolean>(nfcClassName,"isAvailable");
64 }
65 
isSupported()66 bool isSupported()
67 {
68     return QAndroidJniObject::callStaticMethod<jboolean>(nfcClassName,"isSupported");
69 }
70 
stopDiscovery()71 bool stopDiscovery()
72 {
73     return QAndroidJniObject::callStaticMethod<jboolean>(nfcClassName,"stop");
74 }
75 
getStartIntent()76 QAndroidJniObject getStartIntent()
77 {
78     QAndroidJniObject ret = QAndroidJniObject::callStaticObjectMethod(nfcClassName, "getStartIntent", "()Landroid/content/Intent;");
79     return ret;
80 }
81 
registerListener(AndroidNfcListenerInterface * listener)82 bool registerListener(AndroidNfcListenerInterface *listener)
83 {
84     return mainListener.registerListener(listener);
85 }
86 
unregisterListener(AndroidNfcListenerInterface * listener)87 bool unregisterListener(AndroidNfcListenerInterface *listener)
88 {
89     return mainListener.unregisterListener(listener);
90 }
91 
getTag(const QAndroidJniObject & intent)92 QAndroidJniObject getTag(const QAndroidJniObject &intent)
93 {
94     QAndroidJniObject extraTag = QAndroidJniObject::getStaticObjectField("android/nfc/NfcAdapter", "EXTRA_TAG", "Ljava/lang/String;");
95     QAndroidJniObject tag = intent.callObjectMethod("getParcelableExtra", "(Ljava/lang/String;)Landroid/os/Parcelable;", extraTag.object<jstring>());
96     return tag;
97 }
98 
99 QT_END_ANDROIDNFC_NAMESPACE
100 
JNI_OnLoad(JavaVM * vm,void *)101 Q_DECL_EXPORT jint JNICALL JNI_OnLoad(JavaVM *vm, void * /*reserved*/)
102 {
103     static bool initialized = false;
104     if (initialized)
105         return JNI_VERSION_1_6;
106     initialized = true;
107 
108     JNIEnv* env;
109     if (vm->GetEnv(reinterpret_cast<void**>(&env), JNI_VERSION_1_6) != JNI_OK) {
110         return -1;
111     }
112 
113     return JNI_VERSION_1_6;
114 }
115