1 //******************************************************************
3 // Copyright 2016 Samsung Electronics All Rights Reserved.
5 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
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
11 // http://www.apache.org/licenses/LICENSE-2.0
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.
19 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
24 #include "NSConstants.h"
25 #include "NSConsumerCommon.h"
26 #include "cautilinterface.h"
27 #include "oic_malloc.h"
29 #include "NSConsumerDiscovery.h"
30 #include "NSConsumerNetworkEventListener.h"
32 #define NS_PRESENCE_SUBSCRIBE_QUERY "coap://224.0.1.187:5683/oic/ad?rt=oic.r.notification"
34 void NSConnectionStateListener(const CAEndpoint_t * info, bool isConnected);
36 void NSAdapterStateListener(CATransportAdapter_t adapter, bool enabled);
38 OCDoHandle * getPresenceHandle()
40 static OCDoHandle g_PresenceHandle = NULL;
42 return & g_PresenceHandle;
46 NSResult NSConsumerListenerInit()
48 // TODO replace with comment lines when enable network monitor of IP Adapter
49 CARegisterNetworkMonitorHandler(NSAdapterStateListener, NSConnectionStateListener);
50 // if (CARegisterNetworkMonitorHandler(NSAdapterStateListener, NSConnectionStateListener)
56 NS_LOG(DEBUG, "Request to subscribe presence");
57 OCStackResult stackResult = NSInvokeRequest(getPresenceHandle(), OC_REST_PRESENCE, NULL,
58 NS_PRESENCE_SUBSCRIBE_QUERY, NULL, NSConsumerPresenceListener,
60 NS_VERIFY_STACK_SUCCESS(NSOCResultToSuccess(stackResult), NS_ERROR);
62 NS_LOG(DEBUG, "Request to discover provider");
63 stackResult = NSInvokeRequest(NULL, OC_REST_DISCOVER, NULL,
64 NS_DISCOVER_QUERY, NULL, NSProviderDiscoverListener,
66 NS_VERIFY_STACK_SUCCESS(NSOCResultToSuccess(stackResult), NS_ERROR);
71 void NSConsumerListenerTermiate()
73 CARegisterNetworkMonitorHandler(NULL, NULL);
74 OCCancel(*getPresenceHandle(), NS_QOS, NULL, 0);
77 void NSConnectionStateListener(const CAEndpoint_t * info, bool connected)
79 NS_VERIFY_NOT_NULL_V(info);
81 NS_LOG_V(DEBUG, "adapter : %d", info->adapter);
82 NS_LOG_V(DEBUG, "remote_address : %s:%d", info->addr, info->port);
83 NS_LOG_V(DEBUG, "isConnect : %d", connected);
85 NSTaskType type = TASK_EVENT_CONNECTED;
86 OCDevAddr * addr = NULL;
89 if (info->adapter == CA_ADAPTER_TCP)
91 type = TASK_EVENT_CONNECTED_TCP;
92 NS_LOG(DEBUG, "try to discover notification provider : TCP.");
93 // TODO convet to OCDevAddr;
96 else if (info->adapter == CA_ADAPTER_IP)
98 NS_LOG(DEBUG, "try to discover notification provider.");
99 // TODO convet to OCDevAddr;
103 NSTask * task = NSMakeTask(type, addr);
104 NS_VERIFY_NOT_NULL_WITH_POST_CLEANING_V(task, NSOICFree(addr));
106 NSConsumerPushEvent(task);
110 void NSAdapterStateListener(CATransportAdapter_t adapter, bool enabled)
112 NS_LOG_V(DEBUG, "adapter : %d", adapter);
113 NS_LOG_V(DEBUG, "isEnabled : %d", enabled);
119 NS_LOG(DEBUG, "try to discover notification provider.");
121 NSTask * task = NSMakeTask(TASK_EVENT_CONNECTED, NULL);
122 NS_VERIFY_NOT_NULL_V(task);
124 NSConsumerPushEvent(task);