|  | // Copyright 2014 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 NET_BASE_FILENAME_UTIL_H_ | 
|  | #define NET_BASE_FILENAME_UTIL_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "base/files/file_path.h" | 
|  | #include "base/strings/string16.h" | 
|  | #include "net/base/net_export.h" | 
|  |  | 
|  | class GURL; | 
|  |  | 
|  | namespace base { | 
|  | class FilePath; | 
|  | } | 
|  |  | 
|  | namespace  net { | 
|  |  | 
|  | // Given the full path to a file name, creates a file: URL. The returned URL | 
|  | // may not be valid if the input is malformed. | 
|  | NET_EXPORT GURL FilePathToFileURL(const base::FilePath& path); | 
|  |  | 
|  | // Converts a file: URL back to a filename that can be passed to the OS. The | 
|  | // file URL must be well-formed (GURL::is_valid() must return true); we don't | 
|  | // handle degenerate cases here. Returns true on success, false if it isn't a | 
|  | // valid file URL. On failure, *file_path will be empty. | 
|  | NET_EXPORT bool FileURLToFilePath(const GURL& url, base::FilePath* file_path); | 
|  |  | 
|  | // Generates a filename using the first successful method from the following (in | 
|  | // order): | 
|  | // | 
|  | // 1) The raw Content-Disposition header in |content_disposition| as read from | 
|  | //    the network.  |referrer_charset| is used to decode non-ASCII strings. | 
|  | // 2) |suggested_name| if specified.  |suggested_name| is assumed to be in | 
|  | //    UTF-8. | 
|  | // 3) The filename extracted from the |url|.  |referrer_charset| will be used to | 
|  | //    interpret the URL if there are non-ascii characters. | 
|  | // 4) |default_name|.  If non-empty, |default_name| is assumed to be a filename | 
|  | //    and shouldn't contain a path.  |default_name| is not subject to validation | 
|  | //    or sanitization, and therefore shouldn't be a user supplied string. | 
|  | // 5) The hostname portion from the |url| | 
|  | // | 
|  | // Then, leading and trailing '.'s will be removed.  On Windows, trailing spaces | 
|  | // are also removed.  The string "download" is the final fallback if no filename | 
|  | // is found or the filename is empty. | 
|  | // | 
|  | // Any illegal characters in the filename will be replaced by '-'.  If the | 
|  | // filename doesn't contain an extension, and a |mime_type| is specified, the | 
|  | // preferred extension for the |mime_type| will be appended to the filename. | 
|  | // The resulting filename is then checked against a list of reserved names on | 
|  | // Windows.  If the name is reserved, an underscore will be prepended to the | 
|  | // filename. | 
|  | // | 
|  | // Note: |mime_type| should only be specified if this function is called from a | 
|  | // thread that allows IO. | 
|  | NET_EXPORT base::string16 GetSuggestedFilename( | 
|  | const GURL& url, | 
|  | const std::string& content_disposition, | 
|  | const std::string& referrer_charset, | 
|  | const std::string& suggested_name, | 
|  | const std::string& mime_type, | 
|  | const std::string& default_name); | 
|  |  | 
|  | // Similar to GetSuggestedFilename(), but returns a FilePath. | 
|  | NET_EXPORT base::FilePath GenerateFileName( | 
|  | const GURL& url, | 
|  | const std::string& content_disposition, | 
|  | const std::string& referrer_charset, | 
|  | const std::string& suggested_name, | 
|  | const std::string& mime_type, | 
|  | const std::string& default_name); | 
|  |  | 
|  | // Valid components: | 
|  | // * are not empty | 
|  | // * are not Windows reserved names (CON, NUL.zip, etc.) | 
|  | // * do not have trailing separators | 
|  | // * do not equal kCurrentDirectory | 
|  | // * do not reference the parent directory | 
|  | // * do not contain illegal characters | 
|  | // * do not end with Windows shell-integrated extensions (even on posix) | 
|  | // * do not begin with '.' (which would hide them in most file managers) | 
|  | // * do not end with ' ' or '.' | 
|  | NET_EXPORT bool IsSafePortablePathComponent(const base::FilePath& component); | 
|  |  | 
|  | // Basenames of valid relative paths are IsSafePortableBasename(), and internal | 
|  | // path components of valid relative paths are valid path components as | 
|  | // described above IsSafePortableBasename(). Valid relative paths are not | 
|  | // absolute paths. | 
|  | NET_EXPORT bool IsSafePortableRelativePath(const base::FilePath& path); | 
|  |  | 
|  | // Ensures that the filename and extension is safe to use in the filesystem. | 
|  | // | 
|  | // Assumes that |file_path| already contains a valid path or file name.  On | 
|  | // Windows if the extension causes the file to have an unsafe interaction with | 
|  | // the shell (see net_util::IsShellIntegratedExtension()), then it will be | 
|  | // replaced by the string 'download'.  If |file_path| doesn't contain an | 
|  | // extension or |ignore_extension| is true then the preferred extension, if one | 
|  | // exists, for |mime_type| will be used as the extension. | 
|  | // | 
|  | // On Windows, the filename will be checked against a set of reserved names, and | 
|  | // if so, an underscore will be prepended to the name. | 
|  | // | 
|  | // |file_name| can either be just the file name or it can be a full path to a | 
|  | // file. | 
|  | // | 
|  | // Note: |mime_type| should only be non-empty if this function is called from a | 
|  | // thread that allows IO. | 
|  | NET_EXPORT void GenerateSafeFileName(const std::string& mime_type, | 
|  | bool ignore_extension, | 
|  | base::FilePath* file_path); | 
|  |  | 
|  | // Returns whether the specified file name is a reserved name on Windows. | 
|  | // This includes names like "com2.zip" (which correspond to devices) and | 
|  | // desktop.ini and thumbs.db which have special meaning to the Windows shell. | 
|  | // Even on other platforms, this will return whether or not a file name is | 
|  | // reserved on Windows. | 
|  | NET_EXPORT bool IsReservedNameOnWindows( | 
|  | const base::FilePath::StringType& filename); | 
|  |  | 
|  | }  // namespace net | 
|  |  | 
|  | #endif  // NET_BASE_FILENAME_UTIL_H_ |