1 /* 2014, Copyright © Intel Coporation, license APACHE-2.0, see LICENSE file */
2 // Copyright (c) 2015 Samsung Electronics Co., Ltd All Rights Reserved
3 // Use of this source code is governed by a apache 2.0 license that can be
4 // found in the LICENSE file.
6 #include "wgt/step/configuration/step_parse.h"
8 #include <boost/filesystem/path.hpp>
10 #include <common/app_installer.h>
11 #include <common/backup_paths.h>
12 #include <common/installer_context.h>
13 #include <common/step/step.h>
14 #include <common/utils/glist_range.h>
15 #include <manifest_parser/utils/version_number.h>
16 #include <wgt_manifest_handlers/account_handler.h>
17 #include <wgt_manifest_handlers/app_control_handler.h>
18 #include <wgt_manifest_handlers/application_icons_handler.h>
19 #include <wgt_manifest_handlers/application_manifest_constants.h>
20 #include <wgt_manifest_handlers/background_category_handler.h>
21 #include <wgt_manifest_handlers/category_handler.h>
22 #include <wgt_manifest_handlers/content_handler.h>
23 #include <wgt_manifest_handlers/metadata_handler.h>
24 #include <wgt_manifest_handlers/service_handler.h>
25 #include <wgt_manifest_handlers/setting_handler.h>
26 #include <wgt_manifest_handlers/tizen_application_handler.h>
27 #include <wgt_manifest_handlers/widget_handler.h>
28 #include <wgt_manifest_handlers/ime_handler.h>
30 #include <pkgmgr/pkgmgr_parser.h>
42 #include "wgt/wgt_backend_data.h"
44 namespace bf = boost::filesystem;
48 const char kCategoryWearableClock[] =
49 "http://tizen.org/category/wearable_clock";
50 const char kCategoryWatchClock[] = "com.samsung.wmanager.WATCH_CLOCK";
52 const std::string kManifestVersion = "1.0.0";
53 const char kTizenPackageXmlNamespace[] = "http://tizen.org/ns/packages";
54 const char kImeCategoryName[] = "http://tizen.org/category/ime";
56 const char kResWgt[] = "res/wgt";
58 GList* GenerateMetadataListX(const wgt::parse::MetaDataInfo& meta_info) {
59 GList* list = nullptr;
60 for (auto& meta : meta_info.metadata()) {
61 metadata_x* new_meta =
62 static_cast<metadata_x*>(calloc(1, sizeof(metadata_x)));
63 new_meta->key = strdup(meta.first.c_str());
64 if (!meta.second.empty())
65 new_meta->value = strdup(meta.second.c_str());
66 list = g_list_append(list, new_meta);
71 void SetApplicationXDefaults(application_x* application) {
72 application->effectimage_type = strdup("image");
73 application->enabled = strdup("true");
74 application->guestmode_visibility = strdup("true");
75 application->hwacceleration = strdup("default");
76 application->indicatordisplay = strdup("true");
77 application->launchcondition = strdup("false");
78 application->permission_type = strdup("normal");
79 application->process_pool = strdup("false");
80 application->recentimage = strdup("false");
81 application->screenreader = strdup("use-system-setting");
82 application->submode = strdup("false");
83 application->support_disable = strdup("false");
84 application->ui_gadget = strdup("false");
88 void AppendLabel(T* root, const std::string& label,
89 const std::string& locale) {
90 label_x* label_item = reinterpret_cast<label_x*>(calloc(1, sizeof(label_x)));
91 label_item->name = strdup(label.c_str());
92 label_item->text = strdup(label.c_str());
93 label_item->lang = !locale.empty() ?
94 strdup(locale.c_str()) : strdup(DEFAULT_LOCALE);
95 root->label = g_list_append(root->label, label_item);
101 namespace configuration {
103 namespace app_keys = wgt::application_widget_keys;
104 namespace sc = std::chrono;
106 StepParse::StepParse(common_installer::InstallerContext* context,
107 ConfigLocation config_location,
108 bool check_start_file)
110 config_location_(config_location),
111 check_start_file_(check_start_file) {
114 std::set<std::string> StepParse::ExtractPrivileges(
115 std::shared_ptr<const wgt::parse::PermissionsInfo> perm_info) const {
116 return perm_info->GetAPIPermissions();
119 std::string StepParse::GetPackageVersion(
120 const std::string& manifest_version) {
121 if (manifest_version.empty()) {
122 return kManifestVersion;
124 std::string version = manifest_version.substr(0,
125 manifest_version.find_first_not_of("1234567890."));
127 utils::VersionNumber version_number(version);
129 if (!version_number.IsValidTizenPackageVersion()) {
130 LOG(WARNING) << "Version number: " << manifest_version
131 << " is not valid version number for tizen package. "
132 << "Default value will be used.";
133 return kManifestVersion;
136 return version_number.ToString();
139 bool StepParse::FillInstallationInfo(manifest_x* manifest) {
140 manifest->root_path = strdup(
141 (context_->root_application_path.get() / manifest->package).c_str());
142 manifest->installed_time =
143 strdup(std::to_string(sc::system_clock::to_time_t(
144 sc::system_clock::now())).c_str());
148 bool StepParse::FillIconPaths(manifest_x* manifest) {
149 std::shared_ptr<const wgt::parse::TizenApplicationInfo> app_info =
150 std::static_pointer_cast<const wgt::parse::TizenApplicationInfo>(
151 parser_->GetManifestData(app_keys::kTizenApplicationKey));
153 LOG(ERROR) << "Application info manifest data has not been found.";
156 std::shared_ptr<const wgt::parse::ApplicationIconsInfo> icons_info =
157 std::static_pointer_cast<const wgt::parse::ApplicationIconsInfo>(
158 parser_->GetManifestData(app_keys::kIconsKey));
159 if (icons_info.get()) {
160 for (auto& application_icon : icons_info->icons()) {
161 icon_x* icon = reinterpret_cast<icon_x*> (calloc(1, sizeof(icon_x)));
162 bf::path icon_path = context_->root_application_path.get()
163 / app_info->package() / "res" / "wgt" / application_icon.path();
164 icon->text = strdup(icon_path.c_str());
165 icon->lang = strdup(DEFAULT_LOCALE);
166 manifest->icon = g_list_append(manifest->icon, icon);
172 bool StepParse::FillWidgetInfo(manifest_x* manifest) {
173 std::shared_ptr<const wgt::parse::WidgetInfo> wgt_info =
174 std::static_pointer_cast<const wgt::parse::WidgetInfo>(
175 parser_->GetManifestData(app_keys::kWidgetKey));
176 if (!wgt_info.get()) {
177 LOG(ERROR) << "Widget info manifest data has not been found.";
181 const std::string& version = wgt_info->version();
183 manifest->ns = strdup(kTizenPackageXmlNamespace);
184 manifest->version = strdup(GetPackageVersion(version).c_str());
186 for (auto& item : wgt_info->description_set()) {
187 description_x* description = reinterpret_cast<description_x*>
188 (calloc(1, sizeof(description_x)));
189 description->text = strdup(item.second.c_str());
190 description->lang = !item.first.empty() ?
191 strdup(item.first.c_str()) : strdup(DEFAULT_LOCALE);
192 manifest->description = g_list_append(manifest->description, description);
195 for (auto& item : wgt_info->name_set()) {
196 AppendLabel(manifest, item.second, item.first);
199 manifest->type = strdup("wgt");
200 manifest->appsetting = strdup("false");
201 manifest->nodisplay_setting = strdup("false");
202 manifest->preload = strdup("false");
204 // For wgt package use the long name
205 for (auto& item : wgt_info->name_set()) {
207 reinterpret_cast<application_x*>(manifest->application->data);
208 AppendLabel(app, item.second, item.first);
211 author_x* author = reinterpret_cast<author_x*>(calloc(1, sizeof(author_x)));
212 if (!wgt_info->author().empty())
213 author->text = strdup(wgt_info->author().c_str());
214 if (!wgt_info->author_email().empty())
215 author->email = strdup(wgt_info->author_email().c_str());
216 if (!wgt_info->author_href().empty())
217 author->href = strdup(wgt_info->author_href().c_str());
218 author->lang = strdup(DEFAULT_LOCALE);
219 manifest->author = g_list_append(manifest->author, author);
221 std::shared_ptr<const wgt::parse::SettingInfo> settings_info =
222 std::static_pointer_cast<const wgt::parse::SettingInfo>(
223 parser_->GetManifestData(
224 wgt::application_widget_keys::kTizenSettingKey));
226 switch (settings_info->install_location()) {
227 case wgt::parse::SettingInfo::InstallLocation::AUTO: {
228 manifest->installlocation = strdup("auto");
231 case wgt::parse::SettingInfo::InstallLocation::INTERNAL: {
232 manifest->installlocation = strdup("internal-only");
235 case wgt::parse::SettingInfo::InstallLocation::EXTERNAL: {
236 manifest->installlocation = strdup("prefer-external");
241 manifest->installlocation = strdup("auto");
247 bool StepParse::FillMainApplicationInfo(manifest_x* manifest) {
248 std::shared_ptr<const wgt::parse::TizenApplicationInfo> app_info =
249 std::static_pointer_cast<const wgt::parse::TizenApplicationInfo>(
250 parser_->GetManifestData(app_keys::kTizenApplicationKey));
252 LOG(ERROR) << "Application info manifest data has not been found.";
255 bool has_watch_catergory = false;
256 bool has_ime = false;
257 std::shared_ptr<const wgt::parse::CategoryInfoList> category_info =
258 std::static_pointer_cast<const wgt::parse::CategoryInfoList>(
259 parser_->GetManifestData(app_keys::kTizenCategoryKey));
261 has_watch_catergory = std::find_if(category_info->categories.begin(),
262 category_info->categories.end(),
263 [](const std::string& category) {
264 return category == kCategoryWearableClock ||
265 category == kCategoryWatchClock;
266 }) != category_info->categories.end();
267 has_ime = std::find(category_info->categories.begin(),
268 category_info->categories.end(),
270 != category_info->categories.end();
274 application_x* application = reinterpret_cast<application_x*>(
275 calloc(1, sizeof(application_x)));
276 application->component_type =
277 has_watch_catergory ? strdup("watchapp") : strdup("uiapp");
278 application->mainapp = strdup("true");
279 application->multiple = strdup("false");
280 application->appid = strdup(app_info->id().c_str());
281 application->nodisplay = has_ime ? strdup("true") : strdup("false");
282 application->taskmanage = has_ime ? strdup("false") : strdup("true");
283 SetApplicationXDefaults(application);
284 if (has_watch_catergory)
285 application->ambient_support =
286 strdup(app_info->ambient_support() ? "true" : "false");
288 application->ambient_support = strdup("false");
289 application->package = strdup(app_info->package().c_str());
292 strdup((context_->root_application_path.get() / app_info->package()
293 / "bin" / application->appid).c_str());
294 application->type = strdup("webapp");
295 application->onboot = strdup("false");
296 application->autorestart = strdup("false");
298 application->launch_mode = strdup(app_info->launch_mode().c_str());
299 if (manifest->icon) {
300 icon_x* icon = reinterpret_cast<icon_x*>(manifest->icon->data);
301 icon_x* app_icon = reinterpret_cast<icon_x*>(calloc(1, sizeof(icon_x)));
302 app_icon->text = strdup(icon->text);
303 app_icon->lang = strdup(icon->lang);
304 application->icon = g_list_append(application->icon, app_icon);
306 manifest->application = g_list_append(manifest->application, application);
308 manifest->package = strdup(app_info->package().c_str());
309 manifest->mainapp_id = strdup(app_info->id().c_str());
313 bool StepParse::FillServiceApplicationInfo(manifest_x* manifest) {
314 std::shared_ptr<const wgt::parse::ServiceList> service_list =
315 std::static_pointer_cast<const wgt::parse::ServiceList>(
316 parser_->GetManifestData(app_keys::kTizenServiceKey));
319 for (auto& service_info : service_list->services) {
320 application_x* application = reinterpret_cast<application_x*>
321 (calloc(1, sizeof(application_x)));
322 application->component_type = strdup("svcapp");
323 application->mainapp = strdup("false");
324 application->multiple = strdup("false");
325 application->appid = strdup(service_info.id().c_str());
327 strdup((context_->root_application_path.get() / manifest->package
328 / "bin" / application->appid).c_str());
329 application->type = strdup("webapp");
330 application->onboot =
331 service_info.on_boot() ? strdup("true") : strdup("false");
332 application->autorestart =
333 service_info.auto_restart() ? strdup("true") : strdup("false");
334 application->nodisplay = strdup("false");
335 application->taskmanage = strdup("true");
336 SetApplicationXDefaults(application);
337 application->ambient_support = strdup("false");
338 application->package = strdup(manifest->package);
340 for (auto& pair : service_info.names()) {
341 AppendLabel(application, pair.second, pair.first);
344 if (!service_info.icon().empty()) {
345 icon_x* icon = reinterpret_cast<icon_x*>(calloc(1, sizeof(icon_x)));
346 icon->text = strdup(service_info.icon().c_str());
347 icon->lang = strdup(DEFAULT_LOCALE);
348 application->icon = g_list_append(application->icon, icon);
351 // TODO(t.iwanek): what about description, how is it different from name?
353 for (auto& category : service_info.categories()) {
354 application->category = g_list_append(application->category,
355 strdup(category.c_str()));
358 for (auto& pair : service_info.metadata_set()) {
359 metadata_x* item = reinterpret_cast<metadata_x*>(
360 calloc(1, sizeof(metadata_x)));
361 item->key = strdup(pair.first.c_str());
362 if (!pair.second.empty())
363 item->value = strdup(pair.second.c_str());
364 application->metadata = g_list_append(application->metadata, item);
367 manifest->application = g_list_append(manifest->application, application);
372 bool StepParse::FillWidgetApplicationInfo(manifest_x* manifest) {
373 std::shared_ptr<const wgt::parse::AppWidgetInfo> appwidget_info =
374 std::static_pointer_cast<const wgt::parse::AppWidgetInfo>(
375 parser_->GetManifestData(
376 wgt::application_widget_keys::kTizenAppWidgetFullKey));
379 for (auto& app_widget : appwidget_info->app_widgets()) {
380 application_x* application = reinterpret_cast<application_x*>
381 (calloc(1, sizeof(application_x)));
382 application->component_type = strdup("widgetapp");
383 application->mainapp = strdup("false");
384 application->multiple = strdup("false");
385 application->appid = strdup(app_widget.id.c_str());
387 strdup((context_->root_application_path.get() / manifest->package
388 / "bin" / application->appid).c_str());
389 application->type = strdup("webapp");
390 application->nodisplay = strdup("false");
391 application->taskmanage = strdup("false");
392 SetApplicationXDefaults(application);
393 application->ambient_support = strdup("false");
394 application->package = strdup(manifest->package);
396 if (!app_widget.label.default_value.empty()) {
397 AppendLabel(application, app_widget.label.default_value, std::string());
400 for (auto& pair : app_widget.label.lang_value_map) {
401 AppendLabel(application, pair.second, pair.first);
404 if (!app_widget.icon_src.empty()) {
405 icon_x* icon = reinterpret_cast<icon_x*>(calloc(1, sizeof(icon_x)));
406 icon->text = strdup(app_widget.icon_src.c_str());
407 icon->lang = strdup(DEFAULT_LOCALE);
408 application->icon = g_list_append(application->icon, icon);
411 manifest->application = g_list_append(manifest->application, application);
417 bool StepParse::FillBackgroundCategoryInfo(manifest_x* manifest) {
418 auto manifest_data = parser_->GetManifestData(
419 app_keys::kTizenBackgroundCategoryKey);
420 std::shared_ptr<const wgt::parse::BackgroundCategoryInfoList> bc_list =
421 std::static_pointer_cast<const wgt::parse::BackgroundCategoryInfoList>(
428 reinterpret_cast<application_x*>(manifest->application->data);
430 for (auto& background_category : bc_list->background_categories) {
431 app->background_category = g_list_append(
432 app->background_category, strdup(background_category.value().c_str()));
438 bool StepParse::FillAppControl(manifest_x* manifest) {
439 std::shared_ptr<const wgt::parse::AppControlInfoList> app_info_list =
440 std::static_pointer_cast<const wgt::parse::AppControlInfoList>(
441 parser_->GetManifestData(app_keys::kTizenApplicationAppControlsKey));
444 reinterpret_cast<application_x*>(manifest->application->data);
446 for (const auto& control : app_info_list->controls) {
447 appcontrol_x* app_control =
448 static_cast<appcontrol_x*>(calloc(1, sizeof(appcontrol_x)));
449 app_control->operation = strdup(control.operation().c_str());
450 app_control->mime = strdup(control.mime().c_str());
451 app_control->uri = strdup(control.uri().c_str());
452 app->appcontrol = g_list_append(app->appcontrol, app_control);
458 bool StepParse::FillPrivileges(manifest_x* manifest) {
459 std::shared_ptr<const wgt::parse::PermissionsInfo> perm_info =
460 std::static_pointer_cast<const wgt::parse::PermissionsInfo>(
461 parser_->GetManifestData(app_keys::kTizenPermissionsKey));
462 std::set<std::string> privileges;
464 privileges = ExtractPrivileges(perm_info);
466 for (auto& priv : privileges) {
467 manifest->privileges =
468 g_list_append(manifest->privileges, strdup(priv.c_str()));
473 bool StepParse::FillCategories(manifest_x* manifest) {
474 std::shared_ptr<const wgt::parse::CategoryInfoList> category_info =
475 std::static_pointer_cast<const wgt::parse::CategoryInfoList>(
476 parser_->GetManifestData(app_keys::kTizenCategoryKey));
481 reinterpret_cast<application_x*>(manifest->application->data);
482 // there is one app atm
483 for (auto& category : category_info->categories) {
484 app->category = g_list_append(app->category, strdup(category.c_str()));
489 bool StepParse::FillMetadata(manifest_x* manifest) {
490 std::shared_ptr<const wgt::parse::MetaDataInfo> meta_info =
491 std::static_pointer_cast<const wgt::parse::MetaDataInfo>(
492 parser_->GetManifestData(app_keys::kTizenMetaDataKey));
496 for (application_x* app : GListRange<application_x*>(manifest->application)) {
497 app->metadata = GenerateMetadataListX(*meta_info);
502 bool StepParse::FillAppWidget() {
503 // This is needed to store preview icons which are not saved into manifest_x
504 WgtBackendData* backend_data =
505 static_cast<WgtBackendData*>(context_->backend_data.get());
507 std::shared_ptr<const wgt::parse::AppWidgetInfo> appwidget_info =
508 std::static_pointer_cast<const wgt::parse::AppWidgetInfo>(
509 parser_->GetManifestData(
510 wgt::application_widget_keys::kTizenAppWidgetFullKey));
512 backend_data->appwidgets.set(*appwidget_info);
516 bool StepParse::FillAccounts(manifest_x* manifest) {
517 std::shared_ptr<const wgt::parse::AccountInfo> account_info =
518 std::static_pointer_cast<const wgt::parse::AccountInfo>(
519 parser_->GetManifestData(app_keys::kAccountKey));
522 common_installer::AccountInfo info;
523 for (auto& account : account_info->accounts()) {
524 common_installer::SingleAccountInfo single_info;
525 single_info.capabilities = account.capabilities;
526 single_info.icon_paths = account.icon_paths;
527 single_info.multiple_account_support = account.multiple_account_support;
528 single_info.names = account.names;
529 // wgt can contain only one app so this assumes mainapp_id is valid here
530 single_info.appid = manifest->mainapp_id;
531 info.set_account(single_info);
533 context_->manifest_plugins_data.get().account_info.set(info);
537 bool StepParse::FillImeInfo() {
538 const auto ime_info = std::static_pointer_cast<const wgt::parse::ImeInfo>(
539 parser_->GetManifestData(app_keys::kTizenImeKey));
543 common_installer::ImeInfo info;
544 info.setUuid(ime_info->uuid());
546 const auto &languages = ime_info->languages();
547 for (const auto &language : languages)
548 info.AddLanguage(language);
550 context_->manifest_plugins_data.get().ime_info.set(std::move(info));
554 bool StepParse::FillExtraManifestInfo(manifest_x* manifest) {
555 return FillAccounts(manifest) && FillImeInfo() && FillAppWidget();
558 bool StepParse::FillManifestX(manifest_x* manifest) {
559 if (!FillIconPaths(manifest))
561 if (!FillMainApplicationInfo(manifest))
563 if (!FillWidgetInfo(manifest))
565 if (!FillInstallationInfo(manifest))
567 if (!FillPrivileges(manifest))
569 if (!FillAppControl(manifest))
571 if (!FillCategories(manifest))
573 if (!FillMetadata(manifest))
575 // TODO(t.iwanek): fix adding ui application element
576 // for now adding application service is added here because rest of code
577 // assumes that there is one application at manifest->application
578 // so this must execute last. Don't move it above any item
579 if (!FillServiceApplicationInfo(manifest))
581 if (!FillWidgetApplicationInfo(manifest))
583 if (!FillBackgroundCategoryInfo(manifest))
585 if (!FillExtraManifestInfo(manifest))
590 bool StepParse::LocateConfigFile() {
591 switch (config_location_) {
592 case ConfigLocation::PACKAGE:
593 return StepParse::Check(context_->unpacked_dir_path.get());
594 case ConfigLocation::INSTALLED:
595 return StepParse::Check(context_->pkg_path.get() / kResWgt);
596 case ConfigLocation::RECOVERY:
597 if (StepParse::Check(common_installer::GetBackupPathForPackagePath(
598 context_->root_application_path.get()
599 / context_->pkgid.get()) / kResWgt))
601 if (StepParse::Check(
602 context_->root_application_path.get()
603 / context_->pkgid.get() / kResWgt))
606 case ConfigLocation::RESOURCE_WGT:
607 return StepParse::Check(context_->unpacked_dir_path.get() / kResWgt);
609 LOG(ERROR) << "Unknown config location";
614 common_installer::Step::Status StepParse::process() {
615 if (!LocateConfigFile()) {
616 LOG(ERROR) << "No config.xml";
617 return common_installer::Step::Status::MANIFEST_NOT_FOUND;
620 parser_.reset(new wgt::parse::WidgetConfigParser());
621 if (!parser_->ParseManifest(config_)) {
622 LOG(ERROR) << "[Parse] Parse failed. " << parser_->GetErrorMessage();
623 return common_installer::Step::Status::PARSE_ERROR;
625 if (check_start_file_) {
626 if (!parser_->HasValidStartFile()) {
627 LOG(ERROR) << parser_->GetErrorMessage();
628 return common_installer::Step::Status::PARSE_ERROR;
630 if (!parser_->HasValidServicesStartFiles()) {
631 LOG(ERROR) << parser_->GetErrorMessage();
632 return common_installer::Step::Status::PARSE_ERROR;
636 manifest_x* manifest =
637 static_cast<manifest_x*>(calloc(1, sizeof(manifest_x)));
638 if (!FillManifestX(manifest)) {
639 LOG(ERROR) << "[Parse] Storing manifest_x failed. "
640 << parser_->GetErrorMessage();
641 return common_installer::Step::Status::PARSE_ERROR;
644 // Copy data from ManifestData to InstallerContext
645 std::shared_ptr<const wgt::parse::TizenApplicationInfo> info =
646 std::static_pointer_cast<const wgt::parse::TizenApplicationInfo>(
647 parser_->GetManifestData(
648 wgt::application_widget_keys::kTizenApplicationKey));
649 std::shared_ptr<const wgt::parse::WidgetInfo> wgt_info =
650 std::static_pointer_cast<const wgt::parse::WidgetInfo>(
651 parser_->GetManifestData(
652 wgt::application_widget_keys::kTizenWidgetKey));
655 const auto& name_set = wgt_info->name_set();
656 if (name_set.find("") != name_set.end())
657 name = name_set.find("")->second;
658 if (name_set.begin() != name_set.end())
659 name = name_set.begin()->second;
661 std::string short_name;
662 const auto& short_name_set = wgt_info->short_name_set();
663 if (short_name_set.find("") != short_name_set.end())
664 short_name = short_name_set.find("")->second;
665 if (short_name_set.begin() != short_name_set.end())
666 short_name = short_name_set.begin()->second;
668 const std::string& package_version = wgt_info->version();
669 const std::string& required_api_version = info->required_version();
671 manifest->api_version = strdup(required_api_version.c_str());
673 context_->pkgid.set(manifest->package);
675 // write pkgid for recovery file
676 if (context_->recovery_info.get().recovery_file) {
677 context_->recovery_info.get().recovery_file->set_pkgid(manifest->package);
678 context_->recovery_info.get().recovery_file->WriteAndCommitFileContent();
681 std::shared_ptr<const wgt::parse::PermissionsInfo> perm_info =
682 std::static_pointer_cast<const wgt::parse::PermissionsInfo>(
683 parser_->GetManifestData(
684 wgt::application_widget_keys::kTizenPermissionsKey));
685 parser::PermissionSet permissions;
687 permissions = perm_info->GetAPIPermissions();
689 WgtBackendData* backend_data =
690 static_cast<WgtBackendData*>(context_->backend_data.get());
692 std::shared_ptr<const wgt::parse::SettingInfo> settings_info =
693 std::static_pointer_cast<const wgt::parse::SettingInfo>(
694 parser_->GetManifestData(
695 wgt::application_widget_keys::kTizenSettingKey));
697 backend_data->settings.set(*settings_info);
699 LOG(DEBUG) << " Read data -[ ";
700 LOG(DEBUG) << "App id: " << info->id();
701 LOG(DEBUG) << " package = " << info->package();
702 LOG(DEBUG) << " id = " << info->id();
703 LOG(DEBUG) << " name = " << name;
704 LOG(DEBUG) << " short_name = " << short_name;
705 LOG(DEBUG) << " aplication version = " << package_version;
706 LOG(DEBUG) << " api_version = " << info->required_version();
707 LOG(DEBUG) << " launch_mode = " << info->launch_mode();
708 LOG(DEBUG) << " privileges -[";
709 for (const auto& p : permissions) {
710 LOG(DEBUG) << " " << p;
715 // TODO(t.iwanek): In delta mode this step is running two times
716 if (context_->manifest_data.get())
717 pkgmgr_parser_free_manifest_xml(context_->manifest_data.get());
719 context_->manifest_data.set(manifest);
720 return common_installer::Step::Status::OK;
723 bool StepParse::Check(const boost::filesystem::path& widget_path) {
724 boost::filesystem::path config = widget_path / "config.xml";
726 LOG(DEBUG) << "config.xml path: " << config;
728 if (!boost::filesystem::exists(config))
735 } // namespace configuration