blob: e96c300c4f1b12e8a49659849e03a54a764c8c7d [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef REMOTING_HOST_LINUX_FD_STRING_READER_H_
#define REMOTING_HOST_LINUX_FD_STRING_READER_H_
#include <memory>
#include <string>
#include "base/files/file_descriptor_watcher_posix.h"
#include "base/files/scoped_file.h"
#include "base/functional/callback_forward.h"
#include "base/memory/weak_ptr.h"
#include "base/types/expected.h"
#include "remoting/host/base/loggable.h"
namespace remoting {
// Class to read asynchronously from a file-descriptor to a std::string, until
// end-of-stream is reached or an error occurs. The object returned by Read()
// will own the file-descriptor, closing it on destruction.
class FdStringReader {
public:
using Result = base::expected<std::string, Loggable>;
using Callback = base::OnceCallback<void(Result)>;
FdStringReader() = delete;
FdStringReader(const FdStringReader&) = delete;
FdStringReader& operator=(const FdStringReader&) = delete;
~FdStringReader();
// For non-blocking file descriptors (e.g. pipes).
static std::unique_ptr<FdStringReader> ReadFromPipe(base::ScopedFD fd,
Callback callback);
// For regular files.
static std::unique_ptr<FdStringReader> ReadFromFile(base::ScopedFD fd,
Callback callback);
private:
// For Read().
FdStringReader(base::ScopedFD fd, Callback callback);
// For ReadFromFile().
explicit FdStringReader(Callback callback);
void OnFdReadable();
void OnReadComplete(Result result);
// The file-descriptor must outlast the watcher, so it is declared first.
base::ScopedFD fd_;
Callback callback_;
std::unique_ptr<base::FileDescriptorWatcher::Controller> fd_watcher_;
std::string read_data_;
base::WeakPtrFactory<FdStringReader> weak_factory_{this};
};
} // namespace remoting
#endif // REMOTING_HOST_LINUX_FD_STRING_READER_H_