2 * Copyright (c) 2000 - 2014 Samsung Electronics Co., Ltd All Rights Reserved
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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
17 * @file ckm-common.cpp
18 * @author Krzysztof Jackiewicz (k.jackiewicz@samsung.com)
23 #include <sys/smack.h>
24 #include <ckmc/ckmc-type.h>
25 #include <ckm-common.h>
26 #include <tests_common.h>
27 #include <access_provider2.h>
28 #include <ckm/ckm-manager.h>
29 #include <dbus_access.h>
31 const char* SERVICE[] = {
32 "/org/freedesktop/systemd1/unit/central_2dkey_2dmanager_2dlistener_2eservice",
33 "/org/freedesktop/systemd1/unit/central_2dkey_2dmanager_2eservice" };
35 void start_service(ServiceIdx idx)
37 DBusAccess dbus(SERVICE[idx]);
41 void stop_service(ServiceIdx idx)
43 DBusAccess dbus(SERVICE[idx]);
48 void switch_to_storage_user(const char* label)
50 AccessProvider ap(label);
51 ap.allowAPI("key-manager::api-storage", "rw");
52 ap.applyAndSwithToUser(APP_UID, APP_GID);
55 void switch_to_storage_ocsp_user(const char* label)
57 AccessProvider ap(label);
58 ap.allowAPI("key-manager::api-storage", "rw");
59 ap.allowAPI("key-manager::api-ocsp", "rw");
60 ap.applyAndSwithToUser(APP_UID, APP_GID);
63 DBCleanup::~DBCleanup()
65 // Let it throw. If db can't be cleared further tests are unreliable
66 CKM::ManagerShPtr mgr = CKM::Manager::create();
67 for(const auto& it:m_aliases)
72 // returns process label
76 char* my_label = NULL;
77 RUNNER_ASSERT_MSG(0 <= (ret = smack_new_label_from_self(&my_label)),
78 "Failed to get smack label for self. Error: " << ret);
80 return CharPtr(my_label, free);
83 std::string aliasWithLabel(const char *label, const char *alias)
88 ss << label << std::string(ckmc_label_name_separator) << alias;
91 return std::string(alias);
94 // changes process label
95 void change_label(const char* label)
97 int ret = smack_set_label_for_self(label);
98 RUNNER_ASSERT_MSG(0 == ret, "Error in smack_set_label_for_self. Error: " << ret);
101 ScopedLabel::ScopedLabel(const char* label) : m_original_label(get_label())
106 ScopedLabel::~ScopedLabel()
109 * Let it throw. If we can't restore label then remaining tests results will be
112 change_label(m_original_label.get());
115 const char * CKMCErrorToString(int error) {
116 #define ERRORDESCRIBE(name) case name: return #name
118 ERRORDESCRIBE(CKMC_ERROR_NONE);
119 ERRORDESCRIBE(CKMC_ERROR_INVALID_PARAMETER);
120 ERRORDESCRIBE(CKMC_ERROR_OUT_OF_MEMORY);
121 ERRORDESCRIBE(CKMC_ERROR_PERMISSION_DENIED);
122 ERRORDESCRIBE(CKMC_ERROR_SOCKET);
123 ERRORDESCRIBE(CKMC_ERROR_BAD_REQUEST);
124 ERRORDESCRIBE(CKMC_ERROR_BAD_RESPONSE);
125 ERRORDESCRIBE(CKMC_ERROR_SEND_FAILED);
126 ERRORDESCRIBE(CKMC_ERROR_RECV_FAILED);
127 ERRORDESCRIBE(CKMC_ERROR_AUTHENTICATION_FAILED);
128 ERRORDESCRIBE(CKMC_ERROR_BUFFER_TOO_SMALL);
129 ERRORDESCRIBE(CKMC_ERROR_SERVER_ERROR);
130 ERRORDESCRIBE(CKMC_ERROR_DB_LOCKED);
131 ERRORDESCRIBE(CKMC_ERROR_DB_ERROR);
132 ERRORDESCRIBE(CKMC_ERROR_DB_ALIAS_EXISTS);
133 ERRORDESCRIBE(CKMC_ERROR_DB_ALIAS_UNKNOWN);
134 ERRORDESCRIBE(CKMC_ERROR_VERIFICATION_FAILED);
135 ERRORDESCRIBE(CKMC_ERROR_INVALID_FORMAT);
136 ERRORDESCRIBE(CKMC_ERROR_FILE_ACCESS_DENIED);
137 ERRORDESCRIBE(CKMC_ERROR_NOT_EXPORTABLE);
138 ERRORDESCRIBE(CKMC_ERROR_UNKNOWN);
139 default: return "Error not defined";
144 std::string CKMCReadableError(int error) {
145 std::string output("Error: ");
146 output += std::to_string(error);
147 output += " Description: ";
148 output += CKMCErrorToString(error);