1 //******************************************************************
3 // Copyright 2014 Intel Mobile Communications GmbH 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 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
22 #include "occlientcb.h"
29 #include "cainterface.h"
32 #define TAG PCF("occlientcb")
34 struct ClientCB *cbList = NULL;
35 static OCMulticastNode * mcPresenceNodes = NULL;
38 AddClientCB (ClientCB** clientCB, OCCallbackData* cbData,
39 CAToken_t * token, OCDoHandle *handle, OCMethod method,
40 char * requestUri, char * resourceTypeName)
42 if(!clientCB || !cbData || !token || !handle || !requestUri)
44 return OC_STACK_INVALID_PARAM;
47 ClientCB *cbNode = NULL;
50 if(method == OC_REST_PRESENCE)
51 { // Retrieve the presence callback structure for this specific requestUri.
52 cbNode = GetClientCB(NULL, NULL, requestUri);
54 #endif // WITH_PRESENCE
56 if(!cbNode)// If it does not already exist, create new node.
58 cbNode = (ClientCB*) OCMalloc(sizeof(ClientCB));
66 cbNode->callBack = cbData->cb;
67 cbNode->context = cbData->context;
68 cbNode->deleteCallback = cbData->cd;
69 //Note: token memory is allocated in the caller OCDoResource
70 //but freed in DeleteClientCB
71 cbNode->token = *token;
72 cbNode->handle = *handle;
73 cbNode->method = method;
74 cbNode->sequenceNumber = 0;
76 cbNode->presence = NULL;
77 cbNode->filterResourceType = NULL;
78 #endif // WITH_PRESENCE
79 cbNode->requestUri = requestUri;
80 LL_APPEND(cbList, cbNode);
86 // Ensure that the handle the SDK hands back up to the application layer for the
87 // OCDoResource call matches the found ClientCB Node.
89 cbData->cd(cbData->context);
93 OCFree(resourceTypeName);
94 *handle = cbNode->handle;
98 if(method == OC_REST_PRESENCE && resourceTypeName)
99 { // Amend the found or created node by adding a new resourceType to it.
100 return InsertResourceTypeFilter(cbNode, resourceTypeName);
107 return OC_STACK_NO_MEMORY;
110 void DeleteClientCB(ClientCB * cbNode)
113 LL_DELETE(cbList, cbNode);
114 OC_LOG(INFO, TAG, PCF("deleting tokens"));
115 CADestroyToken (cbNode->token);
116 OC_LOG_BUFFER(INFO, TAG, (const uint8_t *)cbNode->token, CA_MAX_TOKEN_LEN);
117 OCFree(cbNode->handle);
118 OCFree(cbNode->requestUri);
119 if(cbNode->deleteCallback)
121 cbNode->deleteCallback(cbNode->context);
125 if(cbNode->presence) {
126 OCFree(cbNode->presence->timeOut);
127 OCFree(cbNode->presence);
129 if(cbNode->method == OC_REST_PRESENCE)
131 OCResourceType * pointer = cbNode->filterResourceType;
132 OCResourceType * next = NULL;
135 next = pointer->next;
136 OCFree(pointer->resourcetypename);
141 #endif // WITH_PRESENCE
147 ClientCB* GetClientCB(const CAToken_t * token, OCDoHandle handle, const char * requestUri)
149 ClientCB* out = NULL;
151 LL_FOREACH(cbList, out) {
152 OC_LOG(INFO, TAG, PCF("comparing tokens"));
153 OC_LOG_BUFFER(INFO, TAG, (const uint8_t *)*token, CA_MAX_TOKEN_LEN);
154 OC_LOG_BUFFER(INFO, TAG, (const uint8_t *)out->token, CA_MAX_TOKEN_LEN);
155 if(memcmp(out->token, *token, CA_MAX_TOKEN_LEN) == 0)
162 LL_FOREACH(cbList, out) {
163 if(out->handle == handle) {
168 else if(requestUri) {
169 LL_FOREACH(cbList, out) {
170 if(out->requestUri && strcmp(out->requestUri, requestUri ) == 0)
176 OC_LOG(INFO, TAG, PCF("Callback Not found !!"));
181 OCStackResult InsertResourceTypeFilter(ClientCB * cbNode, char * resourceTypeName)
183 OCResourceType * newResourceType = NULL;
184 if(cbNode && resourceTypeName)
186 // Form a new resourceType member.
187 newResourceType = (OCResourceType *) OCMalloc(sizeof(OCResourceType));
190 return OC_STACK_NO_MEMORY;
193 newResourceType->next = NULL;
194 newResourceType->resourcetypename = resourceTypeName;
196 LL_APPEND(cbNode->filterResourceType, newResourceType);
199 return OC_STACK_ERROR;
201 #endif // WITH_PRESENCE
203 void DeleteClientCBList() {
206 LL_FOREACH_SAFE(cbList, out, tmp) {
212 void FindAndDeleteClientCB(ClientCB * cbNode) {
216 LL_FOREACH(cbList, tmp)
227 OCStackResult AddMCPresenceNode(OCMulticastNode** outnode, char* uri, uint32_t nonce)
231 return OC_STACK_INVALID_PARAM;
234 OCMulticastNode *node;
236 node = (OCMulticastNode*) OCMalloc(sizeof(OCMulticastNode));
241 LL_APPEND(mcPresenceNodes, node);
246 return OC_STACK_NO_MEMORY;
249 OCMulticastNode* GetMCPresenceNode(const char * uri) {
250 OCMulticastNode* out = NULL;
253 LL_FOREACH(mcPresenceNodes, out) {
254 if(out->uri && strcmp(out->uri, uri) == 0) {
259 OC_LOG(INFO, TAG, PCF("MulticastNode Not found !!"));