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 DEFAULT_CONTEXT_VALUE 0x99
31 //-----------------------------------------------------------------------------
33 //-----------------------------------------------------------------------------
36 * List of methods that can be inititated from the client
39 TEST_DISCOVER_REQ = 1,
46 * List of connectivity types that can be initiated from the client
47 * Required for user input validation
50 CT_ADAPTER_DEFAULT = 0,
53 } CLIENT_CONNECTIVITY_TYPE;
55 //-----------------------------------------------------------------------------
57 //-----------------------------------------------------------------------------
59 /* Get the IP address of the server */
60 std::string getIPAddrTBServer(OCClientResponse * clientResponse);
62 /* Get the port number the server is listening on */
63 std::string getPortTBServer(OCClientResponse * clientResponse);
65 /* Returns the query string for GET and PUT operations */
66 std::string getQueryStrForGetPut(OCClientResponse * clientResponse);
68 /* Following are initialization functions for GET, PUT
69 * POST & Discovery operations
71 int InitPutRequest(OCQualityOfService qos);
72 int InitGetRequest(OCQualityOfService qos);
73 int InitPostRequest(OCQualityOfService qos);
76 /* Function to retrieve ip address, port no. of the server
77 * and query for the operations to be performed.
79 int parseClientResponse(OCClientResponse * clientResponse);
81 /* This method calls OCDoResource() which in turn makes calls
84 OCStackResult InvokeOCDoResource(std::ostringstream &query,
85 OCMethod method, OCQualityOfService qos,
86 OCClientResponseHandler cb, OCHeaderOption * options, uint8_t numOptions);
88 //-----------------------------------------------------------------------------
90 //-----------------------------------------------------------------------------
92 /* Following are callback functions for the GET, PUT
93 * POST & Discovery operations
96 OCStackApplicationResult putReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
98 OCStackApplicationResult postReqCB(void *ctx, OCDoHandle handle, OCClientResponse *clientResponse);
100 OCStackApplicationResult getReqCB(void* ctx, OCDoHandle handle, OCClientResponse * clientResponse);
102 OCStackApplicationResult discoveryReqCB(void* ctx, OCDoHandle handle,
103 OCClientResponse * clientResponse);