2 * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd All Rights Reserved
4 * Contact: Bumjin Im <bj.im@samsung.com>
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License
19 * @file client-common.h
20 * @author Bartlomiej Grzelewski (b.grzelewski@samsung.com)
22 * @brief This file constains implementation of common types
23 * used in security server.
26 #ifndef _SECURITY_SERVER_CLIENT_
27 #define _SECURITY_SERVER_CLIENT_
32 #include <message-buffer.h>
34 #define SECURITY_SERVER_API __attribute__((visibility("default")))
35 #define SECURITY_SERVER_UNUSED __attribute__((unused))
41 namespace SecurityServer {
43 typedef std::vector<unsigned char> RawBuffer;
45 int sendToServer(char const * const interface, const RawBuffer &send, MessageBuffer &recv);
48 * sendToServerAncData is special case when we want to receive file descriptor
49 * passed by Security Server on behalf of calling process. We can't get it with
52 * This function should be called _ONLY_ in this particular case.
55 int sendToServerAncData(char const * const interface, const RawBuffer &send, struct msghdr &hdr);
58 * Decorator function that performs frequently repeated exception handling in
59 * SS client API functions. Accepts lambda expression as an argument.
61 int try_catch(const std::function<int()>& func);
63 } // namespace SecuritySever
65 #endif // _SECURITY_SERVER_CLIENT_