2 * Copyright (c) 2011 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 task_install_ospsvc.cpp
18 * @author Soyoung Kim (sy037.kim@samsung.com)
20 * @brief Implementation file for installer task install osp service
22 #include "task_install_ospsvc.h"
27 #include <dpl/log/log.h>
28 #include <dpl/errno_string.h>
29 #include <dpl/foreach.h>
30 #include <dpl/wrt-dao-ro/global_config.h>
31 #include <dpl/utils/bash_utils.h>
33 #include <widget_install/job_widget_install.h>
34 #include <widget_install/widget_install_context.h>
35 #include <widget_install/widget_install_errors.h>
37 using namespace WrtDB;
40 const int MAX_BUF_SIZE = 128;
41 const char* OSP_INSTALL_STR = "/usr/etc/package-manager/backend/tpk -iv ";
45 namespace WidgetInstall {
46 TaskInstallOspsvc::TaskInstallOspsvc(InstallerContext& context) :
47 DPL::TaskDecl<TaskInstallOspsvc>(this),
50 AddStep(&TaskInstallOspsvc::StepInstallOspService);
53 void TaskInstallOspsvc::StepInstallOspService()
55 LogInfo("Step: installation for osp service");
57 std::ostringstream commStr;
58 commStr << OSP_INSTALL_STR << BashUtils::escape_arg(m_context.locations->getPackageInstallationDir());
60 LogDebug("osp install command : " << commStr.str());
62 char readBuf[MAX_BUF_SIZE];
64 fd = popen(commStr.str().c_str(), "r");
66 LogError("Failed to installtion osp service");
67 ThrowMsg(Exceptions::InstallOspsvcFailed, "Error occurs during\
68 install osp service");
70 fgets(readBuf, MAX_BUF_SIZE, fd);
71 LogDebug("return value : " << readBuf);
73 int result = atoi(readBuf);
75 ThrowMsg(Exceptions::InstallOspsvcFailed, "Error occurs during\
76 install osp service");
81 m_context.job->UpdateProgress(
82 InstallerContext::INSTALL_INSTALL_OSPSVC,
83 "Installed Osp servcie");
85 } //namespace WidgetInstall