diff options
Diffstat (limited to 'src/components/remote_control/src/request_controller.cc')
-rw-r--r-- | src/components/remote_control/src/request_controller.cc | 96 |
1 files changed, 0 insertions, 96 deletions
diff --git a/src/components/remote_control/src/request_controller.cc b/src/components/remote_control/src/request_controller.cc deleted file mode 100644 index 9ffc639898..0000000000 --- a/src/components/remote_control/src/request_controller.cc +++ /dev/null @@ -1,96 +0,0 @@ -/* - * Copyright (c) 2017, 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 "remote_control/request_controller.h" -#include "json/json.h" -#include "utils/logger.h" - -namespace remote_control { -namespace request_controller { - -CREATE_LOGGERPTR_GLOBAL(logger_, "RCRequestController") - -RequestController::RequestController() { - timer_.AddObserver(this); - time_director_.RegisterTimer(timer_); -} - -RequestController::~RequestController() { - time_director_.UnregisterTimer(timer_); - timer_.RemoveObserver(this); -} - -void RequestController::AddRequest(const uint32_t mobile_correlation_id, - MobileRequestPtr request) { - // TODO(VS) Research and fix be problem with overlap correlation ids from two - // different apllications(on two different mobile devices) - sync_primitives::AutoLock lock(mobile_request_lock_); - LOG4CXX_DEBUG(logger_, - "Add request with correlation_id: " << mobile_correlation_id); - mobile_request_list_[mobile_correlation_id] = request; - // TODO(VS): add app id - timer_.AddTrackable(TrackableMessage(0, mobile_correlation_id)); - time_director_.ResetTimer(timer_); -} - -void RequestController::DeleteRequest(const uint32_t& mobile_correlation_id) { - sync_primitives::AutoLock lock(mobile_request_lock_); - LOG4CXX_DEBUG( - logger_, "Delete request with correlation_id: " << mobile_correlation_id); - mobile_request_list_.erase(mobile_correlation_id); - // TODO(VS): add app id - timer_.RemoveTrackable(TrackableMessage(0, mobile_correlation_id)); -} - -void RequestController::OnTimeoutTriggered(const TrackableMessage& expired) { - sync_primitives::AutoLock lock(mobile_request_lock_); - LOG4CXX_DEBUG(logger_, - "Timeout is expired for request with correlation_id: " - << expired.correlation_id()); - std::map<correlation_id, MobileRequestPtr>::iterator it = - mobile_request_list_.find(expired.correlation_id()); - if (mobile_request_list_.end() == it) { - // no corresponding request found, error. - return; - } - it->second->OnTimeout(); - mobile_request_list_.erase(it); -} - -void RequestController::SetRequestTimeout( - const functional_modules::TimeUnit timeout_seconds) { - LOG4CXX_DEBUG(logger_, "RC request timeout is set to " << timeout_seconds); - timer_.set_period(timeout_seconds); -} - -} // namespace request_controller -} // namespace remote_control |