1 /* ****************************************************************
3 * Copyright 2014 Samsung Electronics All Rights Reserved.
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 * This file contains common utility function for remote endpoints.
27 #ifndef CA_REMOTE_HANDLER_H_
28 #define CA_REMOTE_HANDLER_H_
38 * Creates a new remote endpoint from the input endpoint.
39 * @param[in] endpoint endpoint information where the data has to be sent.
40 * @return remote endpoint created.
42 CAEndpoint_t *CACloneEndpoint(const CAEndpoint_t *endpoint);
45 * Allocate CAEndpoint_t instance.
46 * @param[in] flags Transport flag.
47 * @param[in] adapter Adapter type.
48 * @param[in] address Address.
49 * @param[in] port Port.
50 * @return ::CA_STATUS_OK or Appropriate error code.
52 CAEndpoint_t *CACreateEndpointObject(CATransportFlags_t flags, CATransportAdapter_t adapter,
53 const char *address, uint16_t port);
55 * Destroy remote endpoint.
56 * @param[in] endpoint endpoint information where the data has to be sent.
58 void CAFreeEndpoint(CAEndpoint_t *rep);
61 * duplicates the given info.
62 * @param[in] info info object to be duplicated.
63 * @param[out] clone info object to be modified.
64 * @return ::CA_STATUS_OK or Appropriate error code if fail to clone.
66 CAResult_t CACloneInfo(const CAInfo_t *info, CAInfo_t *clone);
69 * Creates a new request information.
70 * @param[in] request request information that needs to be duplicated.
71 * @return duplicated request info object.
73 CARequestInfo_t *CACloneRequestInfo(const CARequestInfo_t *request);
76 * Destroy the request information.
77 * @param[in] request request information that needs to be destroyed.
79 void CADestroyRequestInfoInternal(CARequestInfo_t *request);
82 * Creates a new response information.
83 * @param[in] response response information that needs to be duplicated.
84 * @return duplicated response info object.
86 CAResponseInfo_t *CACloneResponseInfo(const CAResponseInfo_t *response);
89 * Destroy the response information.
90 * @param[in] response response information that needs to be destroyed.
92 void CADestroyResponseInfoInternal(CAResponseInfo_t *response);
95 * Free the error information.
96 * @param[in] errorInfo error information to be freed.
98 void CADestroyErrorInfoInternal(CAErrorInfo_t *errorInfo);
104 #endif /* CA_REMOTE_HANDLER_H_ */