-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MV3 user's mic and cam permissions using iframe #821
Comments
Hi @esphoenixc! I am tagging this as a potential sample the team could put together |
Yes, it is possible to use the Offscreen API to achieve what you are trying to do in Manifest version 3. To start, you can use the Offscreen API to create a hidden canvas element in your content script. You can then use navigator.mediaDevices.getUserMedia() to get the user's cam and mic streams inside your iframe and pass them to your background script. From your background script, you can then use the chrome.runtime.sendMessage() method to send the streams to your content script, where you can display them on the hidden canvas element using CanvasRenderingContext2D.drawImage() |
What's the status of the sample? We are unable to get this working. Offscreen APIs cannot obtain media permissions from our testing. |
I'm a little rusty on the issue, but I think you might be looking for this: https://developer.chrome.com/docs/extensions/mv3/screen_capture/ If so, I apologize for forgetting that we had an open ticket on this. |
@jpmedley The above solution will be wrt some specific tab. (Getting stream from tab)
How do we get access to Media from the user's microphone using the offscreen API? (Inside offscreen.js)
Currently, this throws a NotAllowedError: Failed due to shutdown |
Found this alternative for your requirement. (Without offscreen API)
In your Content Script (say,
|
I figured that you're able to get microphone stream on offscreen if user had previously consented to microphone permission for your extension, however, an offscreen document can't ask permission itself, so you must get it from some other context on my demo using an action popup, I setup a popup.html with a script tag sourcing from popup.js, and in popup.js I had a getUserMedia({ audio: true }) call, which triggered the permission prompt " wants to use your microphone" on first time after I consented, I was able to call getUserMedia({ audio: true }) from my offscreen document and successfully get a microphone stream; before consenting, I would get a DOMException: Failed due to shutdown |
True. Post consent, we can use Only thing was, your way of asking for consent (via popup.js) triggers "www.google.com/*** wants to use your microphone" instead of "[myExtension] wants to Use". Correct me if I am wrong. Thanks |
Hi @aakash232, Do you happen to have a full example of your solution ? (Because with MV3 I always have a not allowed error) Thank you ! |
@athioune OBJECTIVEGOAL : Get mic permissions wrt extension's context and record audio via offscreen API ISSUE : Getting not allowed error if we request mic permissions inside offscreen doc SOLUTION : Get permissions via external STEPSStep 1 : To get permissions, follow my previous reply steps Step 2 : Handle recording. (All the below steps can be achieved via offscreen doc) Create offscreen doc initially
Inside offscreen.jsCheck status of mic permissions
In
Once we have the input devices, then we can capture audio from the device ID you wish to
|
Thank you very much @aakash232 it worked ! |
Sorry to revive this, but when I try to trigger permissions flow from the popup, I see an error: "Permissions Dismissed". The pop up is not even coming up. Anyone seen this? |
Received this error along with Few follow-up(s),
|
This works everywhere except the web WhatsApp. I get the error. Permissions policy violation: microphone is not allowed in this document. |
can someone share code how to implement basic permission access to mic? i am new to chrome extensions |
Hi, just wanted to share how I solved the problem: (answering two previous questions)
You can see example at StraightenUp.ai (I'm the author, but I believe it's demonstrated well here) |
This was the workaround I used as well. I created an extension page to prompt the user for permissions, which ensures the permission prompt displays your extension's name. Once granted, you can utilize the permissions across different tabs seamlessly. |
I am building a chrome extension that records user's cam, mic, and screen.
For the screen, I think I took care of it by using desktopCapture API in background.js.
The problem comes in for user's cam and mic.
I have an iframe injected into the shadow dom. From that iframe, I request for the permissions of the use of the user's cam and mic by using
"navigator.mediaDevices.getUserMedia({audio: true, video:true})"
. The reason for requesting mic and cam permissions inside the iframe is because I want to ask for the permissions on behalf of my extension app(eg -> "[myExtension] wants to Use" instead of "www.google.com wants to use your camera and microphone")
and hold onto the permissions across all tabs, only asking once for the permissions.I want to display user's cam and mic streams in content script, not inside the iframe. In order for me to stream the user's cam and mic in content script, somehow I need to find a way to get the streams of the cam and mic from the iframe and send it over to content script and display the streams. I believe this is where chrome.tabCapture API comes in.
However, in manifest version 3, I cannot use chrome.tabCapture in backgrund.js (now also known as service workser). I think that's causing a major issue in this case.
As I researched more into this specific case, I've found that there's a new feature called, offscreen API.
Can I use offscreen API to achieve what I'm trying to achieve?
requesting permission from the permission.html inside the iframe, which will be created using offscreen API
use that permission in content script to use navigator.mediaDevices.getUserMedia() to get the streams of the user's cam and mic.
Is this even possible in manifest version 3 currently?
if what I wrote or am trying to accomplish is unclear, please let me know.
Here are the references I've gone over to solve this issue :
https://bugs.chromium.org/p/chromium/issues/detail?id=1214847
https://bugs.chromium.org/p/chromium/issues/detail?id=1339382
https://stackoverflow.com/questions/74773408/chrome-tabcapture-unavailable-in-mv3s-new-offscreen-api
https://stackoverflow.com/questions/66217882/properly-using-chrome-tabcapture-in-a-manifest-v3-extension
#627
w3c/webextensions#170
https://groups.google.com/a/chromium.org/g/chromium-extensions/c/ffI0iNd79oo/m/Dnoj6ZIoBQAJ?utm_medium=email&utm_source=footer
The text was updated successfully, but these errors were encountered: