blob: 815749dc939b6269085863803883084049b611eb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_EXO_DATA_EXCHANGE_DELEGATE_H_
#define COMPONENTS_EXO_DATA_EXCHANGE_DELEGATE_H_
#include <string>
#include <vector>
#include "base/callback.h"
#include "base/memory/scoped_refptr.h"
namespace aura {
class Window;
}
namespace base {
class Pickle;
class RefCountedMemory;
} // namespace base
namespace ui {
class DataTransferEndpoint;
struct FileInfo;
enum class EndpointType;
} // namespace ui
namespace exo {
// Interface for data exchange operations that are implemented in chrome such as
// file drag and drop path translations and file sharing for VMs.
class DataExchangeDelegate {
public:
virtual ~DataExchangeDelegate() {}
// Returns the endpoint type of `window`.
virtual ui::EndpointType GetDataTransferEndpointType(
aura::Window* window) const = 0;
// Read filenames from text/uri-list |data| which was provided by |source|
// endpoint. Translates paths from source to host format.
virtual std::vector<ui::FileInfo> GetFilenames(
ui::EndpointType source,
const std::vector<uint8_t>& data) const = 0;
// Returns the mime type which is used by |target| endpoint for a list of
// file path URIs.
virtual std::string GetMimeTypeForUriList(ui::EndpointType target) const = 0;
// Sends the given list of |files| to |target| endpoint. Translates paths from
// host format to the target and performs any required file sharing for VMs.
using SendDataCallback =
base::OnceCallback<void(scoped_refptr<base::RefCountedMemory>)>;
virtual void SendFileInfo(ui::EndpointType target,
const std::vector<ui::FileInfo>& files,
SendDataCallback callback) const = 0;
// Takes in |pickle| constructed by the web contents view and returns true if
// it contains any valid filesystem URLs.
virtual bool HasUrlsInPickle(const base::Pickle& pickle) const = 0;
// Takes in |pickle| constructed by the web contents view containing
// filesystem URLs. Provides translations for the specified |target| endpoint
// and performs any required file sharing for VMs.
virtual void SendPickle(ui::EndpointType target,
const base::Pickle& pickle,
SendDataCallback callback) = 0;
// Reads pickle for FilesApp fs/sources with newline-separated filesystem
// URLs. Validates that |source| is FilesApp.
virtual std::vector<ui::FileInfo> ParseFileSystemSources(
const ui::DataTransferEndpoint* source,
const base::Pickle& pickle) const = 0;
};
} // namespace exo
#endif // COMPONENTS_EXO_DATA_EXCHANGE_DELEGATE_H_
|