blob: 92a52e3097e5c37166e393d299288283544a772f [file] [log] [blame]
// Copyright 2019 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 STORAGE_BROWSER_BLOB_WRITE_BLOB_TO_FILE_H_
#define STORAGE_BROWSER_BLOB_WRITE_BLOB_TO_FILE_H_
#include "base/files/file_path.h"
#include "base/time/time.h"
#include "components/services/storage/public/mojom/blob_storage_context.mojom.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "storage/browser/blob/blob_data_handle.h"
#include "storage/browser/blob/blob_entry.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
namespace storage {
// Writes the blob at |blob_handle| to the file at |file_path|. If a file
// already exists, then it is overwritten. If |flush_on_write| is true, then the
// Flush will be called on the file before it is closed. If |last_modified| is
// populated, then the file's last modified & last accessed time will be set to
// |last_modified|.
// If successful, |callback| is called with the resulting file size. If not,
// then a net error code is used ( < 0).
void WriteBlobToFile(
std::unique_ptr<BlobDataHandle> blob_handle,
const base::FilePath& file_path,
bool flush_on_write,
absl::optional<base::Time> last_modified,
mojom::BlobStorageContext::WriteBlobToFileCallback callback);
} // namespace storage
#endif // STORAGE_BROWSER_BLOB_WRITE_BLOB_TO_FILE_H_