|  | // Copyright 2020 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_ASH_FILE_MANAGER_APP_SERVICE_FILE_TASKS_H_ | 
|  | #define CHROME_BROWSER_ASH_FILE_MANAGER_APP_SERVICE_FILE_TASKS_H_ | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  | #include <vector> | 
|  |  | 
|  | #include "chrome/browser/ash/file_manager/file_tasks.h" | 
|  |  | 
|  | class Profile; | 
|  |  | 
|  | namespace extensions { | 
|  | struct EntryInfo; | 
|  | } | 
|  |  | 
|  | namespace storage { | 
|  | class FileSystemURL; | 
|  | } | 
|  |  | 
|  | namespace file_manager::file_tasks { | 
|  |  | 
|  | // Returns true if a file handler is enabled. Some handlers such as | 
|  | // import-crostini-image can be disabled at runtime by enterprise policy. | 
|  | bool FileHandlerIsEnabled(Profile* profile, | 
|  | const std::string& app_id, | 
|  | const std::string& file_handler_id); | 
|  |  | 
|  | // Returns a profile that has App Service available. App Service doesn't exist | 
|  | // in Incognito mode, so when the user opens a file from the downloads page | 
|  | // within an Incognito browser, we will use the base profile instead. If neither | 
|  | // the given profile nor the base profile have access to an available App | 
|  | // Service, we return a nullptr. | 
|  | Profile* GetProfileWithAppService(Profile* profile); | 
|  |  | 
|  | // Finds the app services tasks that can handle |entries|, appends them to | 
|  | // |result_list|, and calls back to |callback|. If passed, |dlp_source_urls| | 
|  | // should have the same length as |entries| and each element should represent | 
|  | // the URL from which the corresponding entry was downloaded from, and are used | 
|  | // to check DLP restrictions on the |entries|. | 
|  | void FindAppServiceTasks(Profile* profile, | 
|  | const std::vector<extensions::EntryInfo>& entries, | 
|  | const std::vector<GURL>& file_urls, | 
|  | const std::vector<std::string>& dlp_source_urls, | 
|  | std::vector<FullTaskDescriptor>* result_list); | 
|  |  | 
|  | // Executes the specified task by app service. | 
|  | void ExecuteAppServiceTask( | 
|  | Profile* profile, | 
|  | const TaskDescriptor& task, | 
|  | const std::vector<storage::FileSystemURL>& file_system_urls, | 
|  | const std::vector<std::string>& mime_types, | 
|  | FileTaskFinishedCallback done); | 
|  |  | 
|  | // Checks `DefaultHandlersForFileExtensions` policy and maybe sets the default | 
|  | // task. Returns false to indicate that the caller may set the default task and | 
|  | // true if default has been set by this function or default should not be set | 
|  | // due to some assignment conflict. | 
|  | // The exact rules are | 
|  | //    * If there are no default handlers for the given |entries|, returns false | 
|  | //      to allow the caller to specify the default task on its own. | 
|  | //    * If there's exactly one unique default handler for the given |entries| | 
|  | //      and the corresponding task is listed in |resulting_tasks|, marks it as | 
|  | //      default, sets the policy default handler status to | 
|  | //      `kDefaultHandlerAssignedByPolicy` and returns true. | 
|  | //    * In all other cases sets the policy default handler status to | 
|  | //      `kIncorrectAssignment` and returns true. | 
|  | bool ChooseAndSetDefaultTaskFromPolicyPrefs( | 
|  | Profile* profile, | 
|  | const std::vector<extensions::EntryInfo>& entries, | 
|  | ResultingTasks* resulting_tasks); | 
|  |  | 
|  | }  // namespace file_manager::file_tasks | 
|  |  | 
|  | #endif  // CHROME_BROWSER_ASH_FILE_MANAGER_APP_SERVICE_FILE_TASKS_H_ |