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 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
21 #ifndef OCCLIENT_BASICOPS_H_
22 #define OCCLIENT_BASICOPS_H_
26 //-----------------------------------------------------------------------------
28 //-----------------------------------------------------------------------------
29 #define TAG "occlientbasicops"
30 #define DEFAULT_CONTEXT_VALUE 0x99
31 #ifndef MAX_LENGTH_IPv4_ADDR
32 #define MAX_LENGTH_IPv4_ADDR 16
35 //-----------------------------------------------------------------------------
37 //-----------------------------------------------------------------------------
40 * List of methods that can be inititated from the client
43 TEST_DISCOVER_REQ = 1,
49 //-----------------------------------------------------------------------------
51 //-----------------------------------------------------------------------------
53 /* call getResult in common.cpp to get the result in string format. */
54 const char *getResult(OCStackResult result);
56 /* Get the IP address of the server */
57 std::string getIPAddrTBServer(OCClientResponse * clientResponse);
59 /* Get the port number the server is listening on */
60 std::string getPortTBServer(OCClientResponse * clientResponse);
62 /* Returns the query string for GET and PUT operations */
63 std::string getQueryStrForGetPut(OCClientResponse * clientResponse);
65 /* Following are initialization functions for GET, PUT
66 * POST & Discovery operations
69 int InitGetRequest(OCQualityOfService qos);
70 int InitPostRequest(OCQualityOfService qos);
73 /* Function to retrieve ip address, port no. of the server
74 * and query for the operations to be performed.
76 void parseClientResponse(OCClientResponse * clientResponse);
78 /* This method calls OCDoResource() which in turn makes calls
81 OCStackResult InvokeOCDoResource(std::ostringstream &query,
82 OCMethod method, OCQualityOfService qos,
83 OCClientResponseHandler cb, OCHeaderOption * options, uint8_t numOptions);
85 //-----------------------------------------------------------------------------
87 //-----------------------------------------------------------------------------
89 /* Following are callback functions for the GET, PUT
90 * POST & Discovery operations
93 OCStackApplicationResult putReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
95 OCStackApplicationResult postReqCB(void *ctx, OCDoHandle handle, OCClientResponse *clientResponse);
97 OCStackApplicationResult getReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
99 OCStackApplicationResult discoveryReqCB(void* ctx, OCDoHandle handle,
100 OCClientResponse * clientResponse);