diff options
Diffstat (limited to 'src/components/application_manager/src/commands/mobile/set_media_clock_timer_request.cc')
-rw-r--r-- | src/components/application_manager/src/commands/mobile/set_media_clock_timer_request.cc | 157 |
1 files changed, 0 insertions, 157 deletions
diff --git a/src/components/application_manager/src/commands/mobile/set_media_clock_timer_request.cc b/src/components/application_manager/src/commands/mobile/set_media_clock_timer_request.cc deleted file mode 100644 index 54727abe01..0000000000 --- a/src/components/application_manager/src/commands/mobile/set_media_clock_timer_request.cc +++ /dev/null @@ -1,157 +0,0 @@ -/* - - Copyright (c) 2013, 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 "application_manager/commands/mobile/set_media_clock_timer_request.h" - -#include "application_manager/message_helper.h" -#include "application_manager/application_impl.h" -#include "interfaces/MOBILE_API.h" -#include "interfaces/HMI_API.h" - -namespace application_manager { - -namespace commands { - -SetMediaClockRequest::SetMediaClockRequest( - const MessageSharedPtr& message, ApplicationManager& application_manager) - : CommandRequestImpl(message, application_manager) {} - -SetMediaClockRequest::~SetMediaClockRequest() {} - -void SetMediaClockRequest::Run() { - LOG4CXX_AUTO_TRACE(logger_); - - ApplicationSharedPtr app = application_manager_.application(connection_key()); - - if (!app) { - SendResponse(false, mobile_apis::Result::APPLICATION_NOT_REGISTERED); - LOG4CXX_ERROR(logger_, "Application is not registered"); - return; - } - - if (!app->is_media_application()) { - LOG4CXX_ERROR(logger_, "Application is not media application"); - SendResponse(false, mobile_apis::Result::REJECTED); - return; - } - - if (isDataValid()) { - smart_objects::SmartObject msg_params = - smart_objects::SmartObject(smart_objects::SmartType_Map); - // copy entirely msg - msg_params = (*message_)[strings::msg_params]; - msg_params[strings::app_id] = app->app_id(); - StartAwaitForInterface(HmiInterfaces::HMI_INTERFACE_UI); - - SendHMIRequest( - hmi_apis::FunctionID::UI_SetMediaClockTimer, &msg_params, true); - } else { - SendResponse(false, mobile_apis::Result::INVALID_DATA); - } -} - -void SetMediaClockRequest::on_event(const event_engine::Event& event) { - LOG4CXX_AUTO_TRACE(logger_); - const smart_objects::SmartObject& message = event.smart_object(); - - switch (event.id()) { - case hmi_apis::FunctionID::UI_SetMediaClockTimer: { - EndAwaitForInterface(HmiInterfaces::HMI_INTERFACE_UI); - hmi_apis::Common_Result::eType result_code = - static_cast<hmi_apis::Common_Result::eType>( - message[strings::params][hmi_response::code].asInt()); - const bool result = PrepareResultForMobileResponse( - result_code, HmiInterfaces::HMI_INTERFACE_UI); - std::string response_info; - GetInfo(message, response_info); - - SendResponse(result, - MessageHelper::HMIToMobileResult(result_code), - response_info.empty() ? NULL : response_info.c_str(), - &(message[strings::msg_params])); - break; - } - default: { - LOG4CXX_ERROR(logger_, "Received unknown event" << event.id()); - return; - } - } -} - -bool SetMediaClockRequest::isDataValid() { - smart_objects::SmartObject msg_params = (*message_)[strings::msg_params]; - mobile_apis::UpdateMode::eType update_mode = - static_cast<mobile_apis::UpdateMode::eType>( - msg_params[strings::update_mode].asUInt()); - - if (update_mode == mobile_apis::UpdateMode::COUNTUP || - update_mode == mobile_apis::UpdateMode::COUNTDOWN) { - if (!msg_params.keyExists(strings::start_time)) { - LOG4CXX_INFO(logger_, "Invalid data"); - return false; - } - - if (msg_params.keyExists(strings::end_time)) { - unsigned int start_time_in_seconds = 0; - start_time_in_seconds = - (msg_params[strings::start_time][strings::hours].asUInt()) * 3600; - start_time_in_seconds += - (msg_params[strings::start_time][strings::minutes].asUInt()) * 60; - start_time_in_seconds += - (msg_params[strings::start_time][strings::seconds].asUInt()); - - unsigned int end_time_in_seconds = 0; - end_time_in_seconds = - (msg_params[strings::end_time][strings::hours].asUInt()) * 3600; - end_time_in_seconds += - (msg_params[strings::end_time][strings::minutes].asUInt()) * 60; - end_time_in_seconds += - (msg_params[strings::end_time][strings::seconds].asUInt()); - - if (((end_time_in_seconds > start_time_in_seconds) && - (update_mode == mobile_apis::UpdateMode::COUNTDOWN)) || - ((end_time_in_seconds < start_time_in_seconds) && - (update_mode == mobile_apis::UpdateMode::COUNTUP))) { - LOG4CXX_INFO(logger_, "Invalid data"); - return false; - } - } - } - - LOG4CXX_INFO(logger_, "Data is valid"); - return true; -} - -} // namespace commands - -} // namespace application_manager |