mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-12-05 03:36:08 +03:00
146 lines
6.2 KiB
C++
146 lines
6.2 KiB
C++
// Copyright 2014 The Chromium Authors
|
|
// 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 "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 |url| is
|
|
// invalid or the file path cannot be extracted from |url|.
|
|
// On failure, *file_path will be empty.
|
|
//
|
|
// Do not call this with a |url| that doesn't have a file:// scheme.
|
|
// The implementation is specific to the platform filesystem, and not
|
|
// applicable to other schemes.
|
|
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.The file extension for
|
|
// filenames extracted from the URL are considered unreliable if the URL
|
|
// contains a query string. If a MIME type is available (i.e. |mime_type| is
|
|
// not empty) and that MIME type has a preferred extension, then the
|
|
// resulting filename will have that preferred extension.
|
|
// 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 std::u16string 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);
|
|
|
|
// Similar to GetSuggestedFilename(). If |should_replace_extension| is true, the
|
|
// file extension extracted from a URL will always be considered unreliable and
|
|
// the file extension will be determined by |mime_type|.
|
|
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,
|
|
bool should_replace_extension);
|
|
|
|
// 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_
|