diff options
author | sangwan.kwon <sangwan.kwon@samsung.com> | 2016-04-04 13:24:17 +0900 |
---|---|---|
committer | sangwan.kwon <sangwan.kwon@samsung.com> | 2016-05-11 10:46:37 +0900 |
commit | 0e0c941196c0dc23eee6247a5182f6851e45ff48 (patch) | |
tree | 26b1c19e09d8b3f3239ac94bfdcacd7f8f49405e /src/service/app.cpp | |
parent | e05626bc306e8cf9d57604fd1e8b9d540b68e6cd (diff) | |
download | cert-checker-0e0c941196c0dc23eee6247a5182f6851e45ff48.tar.gz cert-checker-0e0c941196c0dc23eee6247a5182f6851e45ff48.tar.bz2 cert-checker-0e0c941196c0dc23eee6247a5182f6851e45ff48.zip |
Implement on-demand style about server-sideref/for/tizen
[AS-IS]
* cert-checker was daemon.
[TO-BE]
* Change to on-demand style.
* cert-svc call cert-checker.
* Add common library.
Change-Id: Idab160e6103cf62299b97a5485a767de9831d614
Signed-off-by: sangwan.kwon <sangwan.kwon@samsung.com>
Diffstat (limited to 'src/service/app.cpp')
-rw-r--r-- | src/service/app.cpp | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/src/service/app.cpp b/src/service/app.cpp new file mode 100644 index 0000000..a61f4a3 --- /dev/null +++ b/src/service/app.cpp @@ -0,0 +1,77 @@ +/* + * Copyright (c) 2015 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +/* + * @file app.cpp + * @author Janusz Kozerski (j.kozerski@samsung.com) + * @version 1.0 + * @brief This file is the implementation of app struct + */ +#include "service/app.h" + +#include <sstream> +#include <string> +#include <sys/types.h> + +#include <cchecker/log.h> + +namespace CCHECKER { + +app_t::app_t(void): + uid((uid_t)-1), // (uid_t)-1 (0xFF) is defined to be invalid uid. According + // to chown manual page, you cannot change file group of owner + // to (uid_t)-1, so we'll use it as initial, invalid value. + verified(verified_t::UNKNOWN) +{} + +app_t::app_t(const std::string &app_id, + const std::string &pkg_id, + uid_t uid, + const signatures_t &signatures): + app_id(app_id), + pkg_id(pkg_id), + uid(uid), + signatures(signatures), + verified(verified_t::UNKNOWN) +{} + +std::ostream & operator<< (std::ostream &out, const app_t &app) +{ + out << "app: " << app.app_id << ", pkg: " << app.pkg_id << ", uid: " << app.uid; + return out; +} + +std::string app_t::str() const +{ + std::stringstream ss; + ss << *this; + return ss.str(); +} + +std::string app_t::str_certs(void) const +{ + std::stringstream ss; + + for (const auto &iter : signatures) { + ss << " { "; + for (const auto iter_cert : iter) { + ss << "\"" << iter_cert << "\", "; + } + ss << " } ,"; + } + return ss.str(); +} + +} //CCHECKER |