Merge branch 'tizen' into security-manager
[platform/core/test/security-tests.git] / src / ckm / ckm-common.h
1 /*
2  *  Copyright (c) 2000 - 2014 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  *  Licensed under the Apache License, Version 2.0 (the "License");
5  *  you may not use this file except in compliance with the License.
6  *  You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  *  Unless required by applicable law or agreed to in writing, software
11  *  distributed under the License is distributed on an "AS IS" BASIS,
12  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  *  See the License for the specific language governing permissions and
14  *  limitations under the License
15  */
16 /*
17  * @file       ckm-common.h
18  * @author     Krzysztof Jackiewicz (k.jackiewicz@samsung.com)
19  * @version    1.0
20  */
21
22 #pragma once
23
24 #include <string>
25 #include <memory>
26 #include <stdexcept>
27 #include <ckm/ckm-type.h>
28 #include <ckm/ckm-manager-async.h>
29 #include <ckmc/ckmc-type.h>
30 #include <ckmc/ckmc-error.h>
31 #include <tests_common.h>
32 #include <sys/types.h>
33
34 extern const std::string SMACK_USER_APP_PREFIX;
35
36 // support for error printing
37 const char * CKMCErrorToString(int error);
38 const char * CKMErrorToString(int error);
39 std::string CKMCReadableError(int error);
40
41 // RUNNER_ASSERT wrappers
42 template <typename F, typename... Args>
43 void assert_result(int expected, F&& func, Args... args)
44 {
45     int ret = func(args...);
46     RUNNER_ASSERT_MSG(ret == expected,
47                       "Expected: " << CKMCErrorToString(expected) << "(" << expected << ")"
48                       " got: " << CKMCErrorToString(ret) << "(" << ret << ")");
49 }
50
51 template <typename F, typename... Args>
52 void assert_positive(F&& func, Args... args)
53 {
54     assert_result(CKMC_ERROR_NONE, std::move(func), args...);
55 }
56
57 template <typename F, typename... Args>
58 void assert_invalid_param(F&& func, Args... args)
59 {
60     assert_result(CKMC_ERROR_INVALID_PARAMETER, std::move(func), args...);
61 }
62
63
64 // list operations
65 template <typename T>
66 size_t list_size(const T* list)
67 {
68     size_t size = 0;
69     while(list) {
70         list = list->next;
71         size++;
72     }
73     return size;
74 }
75
76
77 // service lifecycle management
78 enum ServiceIdx {
79     LISTENER,
80     MANAGER
81 };
82 void start_service(ServiceIdx idx);
83 void stop_service(ServiceIdx idx);
84
85 // scoped free
86 typedef std::unique_ptr<char, void (*)(void *)> CharPtr;
87
88 // returns process owner id
89 std::string getOwnerIdFromSelf();
90
91 std::string aliasWithLabel(const char *label, const char *alias);
92
93 // changes process label upon construction and restores it upon destruction
94 class ScopedLabel
95 {
96 public:
97     ScopedLabel(const char* label);
98     ~ScopedLabel();
99
100 private:
101     std::string m_original_label;
102 };
103
104 void save_data(const char* alias, const char *data, int expected_err = CKMC_ERROR_NONE);
105 void save_data(const char* alias, const char *data, size_t len, int expected_err);
106 class ScopedSaveData
107 {
108 public:
109     ScopedSaveData(const char* alias, const char *data, int expected_err = CKMC_ERROR_NONE);
110     virtual ~ScopedSaveData();
111
112 private:
113     std::string m_alias;
114 };
115
116 class ScopedDBUnlock
117 {
118 public:
119     ScopedDBUnlock(uid_t user_id, const char* passwd);
120     virtual ~ScopedDBUnlock();
121
122 private:
123     uid_t m_uid;
124 };
125
126 void check_remove_allowed(const char* alias);
127 void check_remove_denied(const char* alias);
128 void check_remove_not_visible(const char* alias);
129 void check_read(const char* alias,
130                 const char *label,
131                 const char *test_data,
132                 size_t len,
133                 int expected_code = CKMC_ERROR_NONE);
134 void check_read(const char* alias,
135                 const char *label,
136                 const char *test_data,
137                 int expected_code = CKMC_ERROR_NONE);
138 void check_read_allowed(const char* alias, const char *data);
139 void check_read_not_visible(const char* alias);
140 void check_key(const char *alias,
141                int expected_error = CKMC_ERROR_NONE,
142                ckmc_key_type_e expected_type = CKMC_KEY_NONE);
143 void check_key_allowed(const char *alias, ckmc_key_type_e expected_type = CKMC_KEY_NONE);
144 void check_key_not_visible(const char *alias);
145 void check_cert_allowed(const char *alias);
146 void check_cert_not_visible(const char *alias);
147 void allow_access(const char* alias, const char* accessor, int permissionMask);
148 void allow_access_negative(const char* alias, const char* accessor, int permissionMask, int expectedCode);
149 void deny_access(const char* alias, const char* accessor);
150 void deny_access_negative(const char* alias, const char* accessor, int expectedCode);
151
152 void unlock_user_data(uid_t user_id, const char *passwd);
153 void remove_user_data(uid_t user_id);
154 void reset_user_data(uid_t user_id, const char *passwd);
155
156 ckmc_raw_buffer_s prepare_message_buffer(const char * input);
157 void check_alias_list(const CKM::AliasVector& expected);
158
159 typedef enum {
160     ALIAS_KEY,
161     ALIAS_CERT,
162     ALIAS_DATA
163 } alias_type_;
164 size_t count_aliases(alias_type_ type, size_t minimum_initial_element_count = 0);
165 std::string sharedDatabase(const CKM::Alias & alias);
166 CKM::RawBuffer createRandomBuffer(size_t random_bytes);
167 ckmc_raw_buffer_s* createRandomBufferCAPI(size_t random_bytes);
168
169 ckmc_key_s *generate_AES_key(size_t lengthBits, const char *passwd);
170 void validate_AES_key(ckmc_key_s *analyzed);
171 void compare_AES_keys(ckmc_key_s *first, ckmc_key_s *second); // true if equal
172
173 // Test env class for database cleanup. Pass database uids to cleanup before and after test
174 template <uid_t ...Args>
175 class RemoveDataEnv;
176
177 template <>
178 class RemoveDataEnv<>
179 {
180 public:
181     void init(const std::string&)
182     {}
183     void finish()
184     {}
185 };
186
187 template <uid_t UID, uid_t ...Args>
188 class RemoveDataEnv<UID, Args...> : public RemoveDataEnv<Args...>
189 {
190 public:
191     void init(const std::string & str) {
192         remove_user_data(UID);
193         RemoveDataEnv<Args...>::init(str);
194     }
195     void finish() {
196         RemoveDataEnv<Args...>::finish();
197         remove_user_data(UID);
198     }
199 };
200
201 typedef std::shared_ptr<ckmc_raw_buffer_s> RawBufferPtr;
202 typedef std::shared_ptr<struct __ckmc_param_list> ParamListPtr;
203
204 ParamListPtr createParamListPtr();
205
206 void assert_buffers_equal(const ckmc_raw_buffer_s b1, const ckmc_raw_buffer_s b2, bool equal=true);
207
208 RawBufferPtr create_raw_buffer(ckmc_raw_buffer_s* buffer);
209
210
211 template <typename F, typename... Args>
212 void test_no_observer(F&& func, Args... args)
213 {
214     CKM::ManagerAsync::ObserverPtr obs;
215     CKM::ManagerAsync mgr;
216
217     try {
218         (mgr.*func)(obs, args...);
219         RUNNER_ASSERT_MSG(false, "function() should have thrown an exception");
220     } catch (const std::invalid_argument& e) {
221         RUNNER_ASSERT(true);
222     } catch (...) {
223         RUNNER_ASSERT_MSG(false, "Unexpected exception");
224     }
225 }