/** * Copyright (c) 2018, Ford Motor Company * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following * disclaimer in the documentation and/or other materials provided with the * distribution. * * Neither the name of the Ford Motor Company nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #include "sdl_rpc_plugin/commands/hmi/on_app_permission_consent_notification.h" #include #include #include #include "application_manager/application_manager.h" #include "application_manager/message_helper.h" #include "application_manager/policies/policy_handler.h" #include "policy/policy_types.h" #include "smart_objects/smart_object.h" namespace { /** * @brief Converts SmartObject data to group permission status and appends to * collection */ struct PermissionsAppender : public std::unary_function { PermissionsAppender(policy::PermissionConsent& consents) : allowed_key_(application_manager::hmi_response::allowed) , consents_(consents) {} void operator()(const smart_objects::SmartArray::value_type& item) const { using namespace policy; using namespace application_manager; FunctionalGroupPermission permissions; permissions.group_id = static_cast(item[strings::id].asInt()); permissions.group_alias = item[strings::name].asString(); if (item.keyExists(allowed_key_)) { permissions.state = item[allowed_key_].asBool() ? kGroupAllowed : kGroupDisallowed; } consents_.group_permissions.push_back(permissions); } private: const std::string allowed_key_; policy::PermissionConsent& consents_; }; #ifdef EXTERNAL_PROPRIETARY_MODE /** * @brief Converts SmartObject data to customer connectivity status item and * appends to collection */ struct ExternalConsentStatusAppender : std::unary_function { ExternalConsentStatusAppender( policy::ExternalConsentStatus& external_consent_status) : external_consent_status_(external_consent_status) {} void operator()(const smart_objects::SmartArray::value_type& item) const { using namespace policy; using namespace hmi_apis; using namespace application_manager; ExternalConsentStatusItem status_item( static_cast(item[strings::entity_type].asUInt()), static_cast(item[strings::entity_id].asUInt()), static_cast( item[strings::status].asUInt()) == Common_EntityStatus::ON ? policy::kStatusOn : policy::kStatusOff); external_consent_status_.insert(status_item); } private: policy::ExternalConsentStatus& external_consent_status_; }; #endif } // namespace namespace sdl_rpc_plugin { using namespace application_manager; namespace commands { OnAppPermissionConsentNotification::OnAppPermissionConsentNotification( const application_manager::commands::MessageSharedPtr& message, ApplicationManager& application_manager, rpc_service::RPCService& rpc_service, HMICapabilities& hmi_capabilities, policy::PolicyHandlerInterface& policy_handle) : NotificationFromHMI(message, application_manager, rpc_service, hmi_capabilities, policy_handle) {} OnAppPermissionConsentNotification::~OnAppPermissionConsentNotification() {} void OnAppPermissionConsentNotification::Run() { LOG4CXX_AUTO_TRACE(logger_); smart_objects::SmartObject& msg_params = (*message_)[strings::msg_params]; uint32_t connection_key = 0; policy::PermissionConsent permission_consent; // If user defined group permissions for specific app if (msg_params.keyExists(strings::app_id)) { connection_key = msg_params[strings::app_id].asUInt(); } if (msg_params.keyExists(strings::consented_functions)) { const smart_objects::SmartArray* user_consent = msg_params[strings::consented_functions].asArray(); smart_objects::SmartArray::const_iterator it = user_consent->begin(); smart_objects::SmartArray::const_iterator it_end = user_consent->end(); for (; it != it_end; ++it) { policy::FunctionalGroupPermission permissions; permissions.group_id = (*it)["id"].asInt(); permissions.group_alias = (*it)["name"].asString(); if ((*it).keyExists("allowed")) { permissions.state = (*it)["allowed"].asBool() ? policy::kGroupAllowed : policy::kGroupDisallowed; } else { permissions.state = policy::kGroupUndefined; } permission_consent.group_permissions.push_back(permissions); } permission_consent.consent_source = msg_params[strings::source].asString(); } #ifdef EXTERNAL_PROPRIETARY_MODE policy::ExternalConsentStatus external_consent_status; if (msg_params.keyExists(strings::external_consent_status)) { const smart_objects::SmartArray* system_external_consent_status = msg_params[strings::external_consent_status].asArray(); ExternalConsentStatusAppender status_appender(external_consent_status); std::for_each(system_external_consent_status->begin(), system_external_consent_status->end(), status_appender); } policy_handler_.OnAppPermissionConsent( connection_key, permission_consent, external_consent_status); #else policy_handler_.OnAppPermissionConsent(connection_key, permission_consent); #endif } } // namespace commands } // namespace sdl_rpc_plugin