2 * //******************************************************************
4 * // Copyright 2015 Intel Corporation.
6 * //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
8 * // Licensed under the Apache License, Version 2.0 (the "License");
9 * // you may not use this file except in compliance with the License.
10 * // You may obtain a copy of the License at
12 * // http://www.apache.org/licenses/LICENSE-2.0
14 * // Unless required by applicable law or agreed to in writing, software
15 * // distributed under the License is distributed on an "AS IS" BASIS,
16 * // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * // See the License for the specific language governing permissions and
18 * // limitations under the License.
20 * //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
22 #include "JniOnObserveListener.h"
23 #include "JniOcResource.h"
24 #include "JniOcRepresentation.h"
27 #include "JniOcAccountManager.h"
30 #define CA_OBSERVE_MAX_SEQUENCE_NUMBER 0xFFFFFF
32 JniOnObserveListener::JniOnObserveListener(JNIEnv *env, jobject jListener, JniOcResource* owner)
33 : m_ownerResource(owner)
35 m_jwListener = env->NewWeakGlobalRef(jListener);
37 m_ownerAccountManager = nullptr;
42 JniOnObserveListener::JniOnObserveListener(JNIEnv *env, jobject jListener, JniOcAccountManager* owner)
43 : m_ownerAccountManager(owner)
45 m_jwListener = env->NewWeakGlobalRef(jListener);
46 m_ownerResource = nullptr;
50 JniOnObserveListener::~JniOnObserveListener()
55 JNIEnv *env = GetJNIEnv(ret);
61 env->DeleteWeakGlobalRef(m_jwListener);
62 m_jwListener = nullptr;
64 if (JNI_EDETACHED == ret)
66 g_jvm->DetachCurrentThread();
71 void JniOnObserveListener::onObserveCallback(const HeaderOptions headerOptions,
72 const OCRepresentation& ocRepresentation, const int& eCode, const int& sequenceNumber)
74 jint envRet = JNI_ERR;
75 JNIEnv *env = GetJNIEnv(envRet);
81 if (nullptr == m_jwListener)
83 LOGE("listener is not available");
84 if (JNI_EDETACHED == envRet)
86 g_jvm->DetachCurrentThread();
91 jobject jListener = env->NewLocalRef(m_jwListener);
94 checkExAndRemoveListener(env);
95 if (JNI_EDETACHED == envRet)
97 g_jvm->DetachCurrentThread();
102 jclass clsL = env->GetObjectClass(jListener);
105 env->DeleteLocalRef(jListener);
106 checkExAndRemoveListener(env);
107 if (JNI_EDETACHED == envRet)
109 g_jvm->DetachCurrentThread();
114 if (OC_STACK_OK != eCode && OC_STACK_RESOURCE_CREATED != eCode &&
115 OC_STACK_RESOURCE_DELETED != eCode && OC_STACK_RESOURCE_CHANGED != eCode)
117 jobject ex = GetOcException(eCode, "stack error in onObserveCallback");
123 jmethodID midL = env->GetMethodID(clsL, "onObserveFailed", "(Ljava/lang/Throwable;)V");
126 env->DeleteLocalRef(ex);
129 env->CallVoidMethod(jListener, midL, ex);
133 jobject jHeaderOptionList = JniUtils::convertHeaderOptionsVectorToJavaList(env, headerOptions);
134 if (!jHeaderOptionList)
139 OCRepresentation * rep = new OCRepresentation(ocRepresentation);
140 jlong handle = reinterpret_cast<jlong>(rep);
141 jobject jRepresentation = env->NewObject(g_cls_OcRepresentation,
142 g_mid_OcRepresentation_N_ctor_bool, handle, true);
143 if (!jRepresentation)
146 env->DeleteLocalRef(jHeaderOptionList);
150 jmethodID midL = env->GetMethodID(clsL, "onObserveCompleted",
151 "(Ljava/util/List;Lorg/iotivity/base/OcRepresentation;I)V");
154 env->DeleteLocalRef(jRepresentation);
155 env->DeleteLocalRef(jHeaderOptionList);
159 env->CallVoidMethod(jListener, midL, jHeaderOptionList, jRepresentation,
160 static_cast<jint>(sequenceNumber));
161 if (env->ExceptionCheck())
163 LOGE("Java exception is thrown");
165 env->DeleteLocalRef(jRepresentation);
166 env->DeleteLocalRef(jHeaderOptionList);
167 jthrowable ex = env->ExceptionOccurred();
168 env->ExceptionClear();
170 m_ownerResource->removeOnObserveListener(env, m_jwListener);
172 if (nullptr != m_ownerResource)
174 m_ownerResource->removeOnObserveListener(env, m_jwListener);
176 if (nullptr != m_ownerAccountManager)
178 m_ownerAccountManager->removeOnObserveListener(env, m_jwListener);
181 env->Throw((jthrowable)ex);
184 if (CA_OBSERVE_MAX_SEQUENCE_NUMBER + 1 == sequenceNumber)
186 LOGI("Observe De-registration action is successful");
191 env->DeleteLocalRef(clsL);
192 env->DeleteLocalRef(jListener);
193 if (JNI_EDETACHED == envRet)
195 g_jvm->DetachCurrentThread();
200 env->DeleteLocalRef(clsL);
201 env->DeleteLocalRef(jListener);
202 checkExAndRemoveListener(env);
203 if (JNI_EDETACHED == envRet)
205 g_jvm->DetachCurrentThread();
209 void JniOnObserveListener::checkExAndRemoveListener(JNIEnv* env)
211 LOGI("checkExAndRemoveListener");
212 if (env->ExceptionCheck())
214 jthrowable ex = env->ExceptionOccurred();
215 env->ExceptionClear();
217 m_ownerResource->removeOnObserveListener(env, m_jwListener);
219 if (nullptr != m_ownerResource)
221 m_ownerResource->removeOnObserveListener(env, m_jwListener);
223 if (nullptr != m_ownerAccountManager)
225 m_ownerAccountManager->removeOnObserveListener(env, m_jwListener);
228 env->Throw((jthrowable)ex);
233 m_ownerResource->removeOnObserveListener(env, m_jwListener);
235 if (nullptr != m_ownerResource)
237 m_ownerResource->removeOnObserveListener(env, m_jwListener);
239 if (nullptr != m_ownerAccountManager)
241 m_ownerAccountManager->removeOnObserveListener(env, m_jwListener);
247 jweak JniOnObserveListener::getJWListener()
249 return this->m_jwListener;