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 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
27 //-----------------------------------------------------------------------------
29 //-----------------------------------------------------------------------------
30 #define TAG "occlient"
31 #define DEFAULT_CONTEXT_VALUE 0x99
32 #ifndef MAX_LENGTH_IPv4_ADDR
33 #define MAX_LENGTH_IPv4_ADDR 16
36 //-----------------------------------------------------------------------------
38 //-----------------------------------------------------------------------------
41 * List of methods that can be inititated from the client
44 TEST_DISCOVER_REQ = 1,
50 TEST_GET_UNAVAILABLE_RES_REQ_NON,
57 TEST_OBS_PRESENCE_WITH_FILTER,
59 TEST_OBS_REQ_NON_CANCEL_IMM,
60 TEST_GET_REQ_NON_WITH_VENDOR_HEADER_OPTIONS,
68 //----------------------------------------------------------------------------
70 //----------------------------------------------------------------------------
72 /* call getResult in common.cpp to get the result in string format. */
73 const char *getResult(OCStackResult result);
75 /* Get the IP address of the server */
76 std::string getIPAddrTBServer(OCClientResponse * clientResponse);
78 /* Get the port number the server is listening on */
79 std::string getPortTBServer(OCClientResponse * clientResponse);
81 /* Returns the query string for GET and PUT operations */
82 std::string getQueryStrForGetPut(OCClientResponse * clientResponse);
84 /* Following are initialization functions for GET, Observe, PUT
85 * POST, Delete & Discovery operations
87 int InitGetRequestToUnavailableResource();
88 int InitObserveRequest(OCQualityOfService qos);
90 int InitGetRequest(OCQualityOfService qos, uint8_t withVendorSpecificHeaderOptions);
91 int InitPostRequest(OCQualityOfService qos);
92 int InitDeleteRequest(OCQualityOfService qos);
93 int InitGetRequest(OCQualityOfService qos);
96 /* Function to retrieve ip address, port no. of the server
97 * and query for the operations to be performed.
99 void parseClientResponse(OCClientResponse * clientResponse);
101 /* Call delete operation on already deleted resource */
102 void* RequestDeleteDeathResourceTask(void* myqos);
104 /* This method calls OCDoResource() which in turn makes calls
105 * to the lower layers
107 OCStackResult InvokeOCDoResource(std::ostringstream &query,
108 OCMethod method, OCQualityOfService qos,
109 OCClientResponseHandler cb, OCHeaderOption * options, uint8_t numOptions);
111 //-----------------------------------------------------------------------------
112 // Callback functions
113 //-----------------------------------------------------------------------------
115 /* Following are callback functions for the GET, Observe, PUT
116 * POST, Delete, Presence & Discovery operations
118 OCStackApplicationResult putReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
120 OCStackApplicationResult postReqCB(void *ctx, OCDoHandle handle, OCClientResponse *clientResponse);
122 OCStackApplicationResult getReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
124 OCStackApplicationResult obsReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
126 OCStackApplicationResult presenceCB(void* ctx,
127 OCDoHandle handle, OCClientResponse * clientResponse);
129 OCStackApplicationResult deleteReqCB(void *ctx,
130 OCDoHandle handle, OCClientResponse *clientResponse);
132 OCStackApplicationResult discoveryReqCB(void* ctx, OCDoHandle handle,
133 OCClientResponse * clientResponse);