| // Copyright 2018 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef COMPONENTS_DOWNLOAD_QUARANTINE_TEST_SUPPORT_H_ |
| #define COMPONENTS_DOWNLOAD_QUARANTINE_TEST_SUPPORT_H_ |
| |
| #include <string> |
| |
| class GURL; |
| |
| namespace base { |
| class FilePath; |
| } |
| |
| namespace download { |
| |
| // Determine if a file has quarantine metadata attached to it. |
| // |
| // If |source_url| is non-empty, then the download source URL in |
| // quarantine metadata should match |source_url| exactly. The function returns |
| // |false| if there is a mismatch. If |source_url| is empty, then this function |
| // only checks for the existence of a download source URL in quarantine |
| // metadata. |
| // |
| // If |referrer_url| is valid, then the download referrer URL in quarantine |
| // metadata must match |referrer_url| exactly. The function returns |false| if |
| // there is a mismatch in the |referrer_url| even if the |source_url| matches. |
| // No referrer URL checks are performed if |referrer_url| is empty. |
| // |
| // If both |source_url| and |referrer_url| are empty, then the function returns |
| // true if any quarantine metadata is present for the file. |
| // |
| // **Note**: On Windows 8 or lower, this function only checks if the |
| // |ZoneIdentifier| metadata is present. |source_url| and |referrer_url| are |
| // ignored. Individual URLs are only stored as part of the mark-of-the-web since |
| // Windows 10. |
| bool IsFileQuarantined(const base::FilePath& file, |
| const GURL& source_url, |
| const GURL& referrer_url); |
| |
| } // namespace download |
| |
| #endif // COMPONENTS_DOWNLOAD_QUARANTINE_TEST_SUPPORT_H_ |