I’m developing a web application inside Telegram’s WebApp (Mini App), and I’m trying to read or write text to the clipboard using the Clipboard API. However, when I try to execute navigator.clipboard.writeText() or navigator.clipboard.readText(), I receive the following error:
NotAllowedError: Failed to execute 'writeText' on 'Clipboard': The Clipboard API has been blocked because of a permissions policy applied to the current document.
Is here another way to read content from clipboard?
-
Checked for Clipboard API availability:
I verified that navigator.clipboard is available in the environment. The Clipboard API exists, so it should theoretically work. -
Triggered clipboard operations through user interaction:
To meet security requirements, I made sure that both clipboard read and write operations were triggered via a user action, such as clicking a button. Here’s an example of the code I used: -
Tried both reading and writing text:
I tried both navigator.clipboard.writeText() for writing to the clipboard and navigator.clipboard.readText() for reading from the clipboard. Both operations throw a NotAllowedError with a message saying the clipboard has been blocked due to a permissions policy. -
Tested in different environments:
In Chrome: The clipboard functionality works as expected in a standard Chrome browser (both desktop and mobile). I can successfully read and write to the clipboard after user interaction.
In Telegram WebApp: The same code throws the NotAllowedError when run inside Telegram’s WebApp (Mini App). This suggests the WebView in Telegram is applying stricter security policies or permissions that block access to the Clipboard API.
2
Answers
It’s the iframe policies, I guess. Here’s the iframe embed from Telegram Web A-version:
However,
allow="clipboard-read; clipboard-write”
is needed to access the clipboard from the iframe.As stated in docs for
readTextFromClipboard([callback])
:So basically clipboard is limited in Mini apps to bots who have the feature to be added to "attachment menu".