blob: b9794ae5b37041df6f11ae84af7a4854e72b8554 [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_WEB_APPLICATIONS_WEB_APP_LAUNCH_PARAMS_H_
#define CHROME_BROWSER_WEB_APPLICATIONS_WEB_APP_LAUNCH_PARAMS_H_
#include <vector>
#include "base/files/file_path.h"
#include "chrome/browser/web_applications/web_app_id.h"
#include "url/gurl.h"
namespace web_app {
// Represents the LaunchParams values to be sent to a web app on app launch and
// whether the launch triggered a navigation or not.
struct WebAppLaunchParams {
WebAppLaunchParams();
WebAppLaunchParams(const WebAppLaunchParams&);
WebAppLaunchParams(WebAppLaunchParams&&) noexcept;
~WebAppLaunchParams();
WebAppLaunchParams& operator=(const WebAppLaunchParams&);
WebAppLaunchParams& operator=(WebAppLaunchParams&&) noexcept;
// Whether this launch triggered a navigation that needs to be awaited before
// sending the launch params to the document.
bool started_new_navigation = true;
// The app being launched, used for scope validation.
AppId app_id;
// The URL the web app was launched with. Note that redirects may cause us to
// enqueue in a different URL, we still report the original launch target URL
// in the launch params.
GURL target_url;
// The directory to launch with (may be empty).
base::FilePath dir;
// The files to launch with (may be empty).
std::vector<base::FilePath> paths;
};
} // namespace web_app
#endif // CHROME_BROWSER_WEB_APPLICATIONS_WEB_APP_LAUNCH_PARAMS_H_