| // Copyright 2012 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef UI_BASE_CLIPBOARD_SCOPED_CLIPBOARD_WRITER_H_ |
| #define UI_BASE_CLIPBOARD_SCOPED_CLIPBOARD_WRITER_H_ |
| |
| #include <string> |
| #include <string_view> |
| |
| #include "base/component_export.h" |
| #include "base/containers/flat_map.h" |
| #include "third_party/skia/include/core/SkBitmap.h" |
| #include "ui/base/clipboard/clipboard.h" |
| #include "ui/base/data_transfer_policy/data_transfer_endpoint.h" |
| |
| namespace base { |
| class Pickle; |
| } |
| |
| namespace ui { |
| |
| // |ScopedClipboardWriter|: |
| // - is a wrapper for |Clipboard|. |
| // - simplifies writing data to the system clipboard. |
| // - handles packing data into a Clipboard::ObjectMap. |
| // |
| // Upon deletion, the class atomically writes all data to the clipboard, |
| // avoiding any potential race condition with other processes that are also |
| // writing to the system clipboard. |
| class COMPONENT_EXPORT(UI_BASE_CLIPBOARD) ScopedClipboardWriter { |
| public: |
| // Create an instance that is a simple wrapper around the clipboard of the |
| // given buffer with an optional parameter indicating the source of the data. |
| // TODO(crbug.com/40704495): change its references to use |
| // DataTransferEndpoint, if possible. |
| explicit ScopedClipboardWriter( |
| ClipboardBuffer buffer, |
| std::unique_ptr<DataTransferEndpoint> src = nullptr); |
| ScopedClipboardWriter(const ScopedClipboardWriter&) = delete; |
| ScopedClipboardWriter& operator=(const ScopedClipboardWriter&) = delete; |
| ~ScopedClipboardWriter(); |
| |
| // Sets the clipboard's source metadata. |
| void SetDataSource(std::unique_ptr<DataTransferEndpoint> data_src); |
| |
| // Set the clipboards source URL. |
| // Typically used for attributing content originally copied from a web page. |
| void SetDataSourceURL(const GURL& main_frame, const GURL& frame); |
| |
| // Converts |text| to UTF-8 and adds it to the clipboard. |
| void WriteText(std::u16string_view text); |
| |
| // Adds HTML to the clipboard. The url parameter is optional, but especially |
| // useful if the HTML fragment contains relative links. |
| // The `content_type` refers to the sanitization of the markup. |
| void WriteHTML(std::u16string_view markup, std::string source_url); |
| |
| // Adds SVG to the clipboard. |
| void WriteSvg(std::u16string_view text); |
| |
| // Adds RTF to the clipboard. |
| void WriteRTF(std::string rtf_data); |
| |
| // Adds text/uri-list filenames to the clipboard. |
| // Security Note: This function is expected to be called only by exo in |
| // Chrome OS. It should not be called by renderers or any other untrusted |
| // party since any paths written to the clipboard can be read by renderers. |
| void WriteFilenames(std::string uri_list); |
| |
| // Adds a bookmark to the clipboard. |
| void WriteBookmark(std::u16string_view bookmark_title, std::string url); |
| |
| // Adds an html hyperlink (<a href>) to the clipboard. |anchor_text| and |
| // |url| will be escaped as needed. |
| void WriteHyperlink(std::u16string_view anchor_text, std::string_view url); |
| |
| // Used by WebKit to determine whether WebKit wrote the clipboard last |
| void WriteWebSmartPaste(); |
| |
| // Adds arbitrary pickled data to clipboard. |
| void WritePickledData(const base::Pickle& pickle, |
| const ClipboardFormatType& format); |
| |
| // Data is written to the system clipboard in the same order as WriteData |
| // calls are received. |
| // This is only used to write custom format data. |
| void WriteData(std::u16string_view format, mojo_base::BigBuffer data); |
| |
| void WriteImage(const SkBitmap& bitmap); |
| |
| // Mark the data to be written as confidential. |
| void MarkAsConfidential(); |
| |
| // Data is copied from an incognito window. |
| void MarkAsOffTheRecord(); |
| |
| // Removes all objects that would be written to the clipboard. |
| void Reset(); |
| |
| private: |
| // We accumulate the data passed to the various targets in the |objects_| |
| // vector, and pass it to Clipboard::WritePortableRepresentations() during |
| // object destruction. |
| Clipboard::ObjectMap objects_; |
| |
| // Same as `objects_`, but holds every type passed to `WritePickledData` to |
| // allow writing more than one to the clipboard at once. |
| // This uses a map instead of a vector to avoid attempts to write the same |
| // format type multiple times to the clipboard. |
| std::map<ClipboardFormatType, Clipboard::RawData> raw_objects_; |
| |
| std::vector<Clipboard::PlatformRepresentation> platform_representations_; |
| // Keeps track of the unique custom formats registered in the clipboard. |
| base::flat_map<std::string, std::string> registered_formats_; |
| int counter_ = 0; |
| |
| // The type is set at construction, and can be changed before committing. |
| const ClipboardBuffer buffer_; |
| |
| // Contains the `Clipboard::PrivacyTypes` based on whether the content was |
| // marked as confidential or off the record. e.g. password is considered as |
| // confidential that should be concealed. |
| uint32_t privacy_types_ = 0; |
| |
| // The source of the data written in ScopedClipboardWriter, nullptr means it's |
| // not set, or the source of the data can't be represented by |
| // DataTransferEndpoint. |
| std::unique_ptr<DataTransferEndpoint> data_src_; |
| |
| // The URL of the mainframe the contents are from. |
| GURL main_frame_url_; |
| |
| // The URL of the frame the contents are from. |
| GURL frame_url_; |
| }; |
| |
| } // namespace ui |
| |
| #endif // UI_BASE_CLIPBOARD_SCOPED_CLIPBOARD_WRITER_H_ |