// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#include "QuitCommandHandler.h"
#include "errorcodes.h"
#include "../Browser.h"
#include "../IECommandExecutor.h"

namespace webdriver {

QuitCommandHandler::QuitCommandHandler(void) {
}

QuitCommandHandler::~QuitCommandHandler(void) {
}

void QuitCommandHandler::ExecuteInternal(
    const IECommandExecutor& executor,
    const ParametersMap& command_parameters,
    Response* response) {
  IECommandExecutor& mutable_executor = const_cast<IECommandExecutor&>(executor);
  mutable_executor.set_is_quitting(true);

  std::vector<std::string> managed_browser_handles;
  executor.GetManagedBrowserHandles(&managed_browser_handles);

  std::vector<std::string>::iterator end = managed_browser_handles.end();
  for (std::vector<std::string>::iterator it = managed_browser_handles.begin();
        it != end;
        ++it) {
    BrowserHandle browser_wrapper;
    int status_code = executor.GetManagedBrowser(*it, &browser_wrapper);
    if (status_code == WD_SUCCESS && !browser_wrapper->is_closing()) {
      browser_wrapper->Close();
    }
  }

  // Calling quit will always result in an invalid session.
  mutable_executor.set_is_valid(false);
  response->SetSuccessResponse(Json::Value::null);
}

} // namespace webdriver
