Skip to content
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

FrameCreated is not called for iframe inside another iframe #2440

Open
q71114 opened this issue May 10, 2022 · 26 comments
Open

FrameCreated is not called for iframe inside another iframe #2440

q71114 opened this issue May 10, 2022 · 26 comments
Assignees
Labels
feature request feature request tracked We are tracking this work internally.

Comments

@q71114
Copy link

q71114 commented May 10, 2022

Description
FrameCreated is not called for iframe inside another iframe.

Version
SDK: 1.0.1222-prerelease
Runtime: Evergreen, 101.0.1210.39
Framework: WPF
OS: Win11

Repro Steps

  1. Added event handler to CoreWebView2.FrameCreated.
  2. Open a website with nested iframes, for example this one.

Expectation: CoreWebView2.FrameCreated is raised for both iframes.
Actual: Only one CoreWebView2.FrameCreated is raised (which is for the top level iframe).

AB#40114362

@q71114 q71114 added the bug Something isn't working label May 10, 2022
@champnic
Copy link
Member

Thanks for the bug report @q71114, and sorry you are running into this. I've added this to our backlog to take a look. @vbryh-msft FYI.

@champnic champnic added the tracked We are tracking this work internally. label May 10, 2022
@vbryh-msft
Copy link
Contributor

Hi @q71114 FrameCreated event is raised currently only for top level iframes - this is known limitation. Could you please describe your scenario - why do you need nested iframes also and how are you going to use them. Thanks!

@q71114
Copy link
Author

q71114 commented May 11, 2022

Hi @vbryh-msft, we need to be able to send / receive message from all iframes in order to monitor / pause / resume camera and microphone usage as currently this is the only way to do it.
If this limitation with iframes could not be removed having this feature request implemented would be the next best thing if it can be extended with pausing / resuming the permission in use as well.

@vbryh-msft
Copy link
Contributor

@q71114 are your nested iframes in the same origin as top level iframes/parent page - or they all can be different?

@q71114
Copy link
Author

q71114 commented May 11, 2022

@vbryh-msft We need this to work with any setup so they can all be different.

@q71114 q71114 closed this as completed May 12, 2022
@q71114
Copy link
Author

q71114 commented May 23, 2022

Closed by mistake.

@perelmanari
Copy link

I would also like to a request for this feature.

We have an application using WebView2. Our users put enter a URL that they are in control of and we need to be able to read the contents of the webpage. One of our users has a webpage containing an iframe inside an iframe and we are unable to see it.

We would like to be able to work with nested frames the same way we work with top level frames. A nested frame could either trigger the CoreWebView2.FrameCreated or it could trigger a new CoreWebView2Frame.FrameCreated created.

Thank you

@Kay-Burchardt
Copy link

Kay-Burchardt commented Apr 6, 2023

Please fix this issue ASAP.

@champnic champnic assigned vbryh-msft and unassigned champnic Apr 6, 2023
@perelmanari
Copy link

Can we get an update on this? Is this something that you are planning on addressing? Is there any timeline?

Thank you

@vbryh-msft
Copy link
Contributor

@perelmanari - sorry, there is no work currently in progress for this feature. Do you think we can come up with some workaround on JS side? I was thinking if you can use AddScriptToExecuteOnDocumentCreated which should work for nested and then use JS postMessage ?

@perelmanari
Copy link

Unfortunately, I don't think there is a workaround using Javascript. If a nested frame is cross-domain, then javascript wouldn't have access to it at all and interacting with cross-domain nested frames is exactly what I need to do.

@vbryh-msft
Copy link
Contributor

Second linked doc says: The window.postMessage() method safely enables cross-origin communication - have you given it a try?

@perelmanari
Copy link

It would take a lot of javascript code and experimenting, but it seems like I could use a combination of those two to get a lot of functionality.
I could detect document created and use that to know there is a new frame (FrameCreated) or an existing frame has navigated. Javascript could give me ReadyStateChanged events. I could use postMessage both directions to get similar functionality to ExecuteScriptAsync.
Do you have any thoughts on how this could work to get NavigationStarting and WebResourceRequested events?

@perelmanari
Copy link

I have been experimenting using the devtools protocol to get events (Page.frameAttached, Page.frameDetached, Page.lifecycleEvent, Network.requestWillBeSent, Network.responseReceived, etc). Overall, this has been working well to achieve what I need. However, I am unable to get any events to fire on cross site frames.

This chromium bug report has information:
https://bugs.chromium.org/p/chromium/issues/detail?id=924937#c13

I am able to use Target.setAutoAttached and get the Target.attachedToTarget event with the sessionId for the iframe. However, CoreWebView2.CallDevToolsProtocolMethodAsync does not have any way to pass a sessionId. It only allows for methodName and parametersAsJson.

Is there any way to do this currently with WebView2? Should I add a separate feature request to add an overload for CallDevToolsProtocolMethodAsync that accepts a sessionId?

@vbryh-msft
Copy link
Contributor

Thank you for trying. We have method with sessionId input parameter - CallDevToolsProtocolMethodForSessionAsync

@perelmanari
Copy link

I can't believe I completely missed that method. Thank you.

@perelmanari
Copy link

Using that method, I am now able to see events from the cross site frames. I miss a few events due to async timing, but I can work around that. I think I will be able to get all the functionality I need this way.

Thank you for your help.

@nishitha-burman
Copy link
Collaborator

Hello, we are looking into this feature request and I have a follow up question: @q71114 do you know the hierarchy of the nested iframes? Thanks!

@q71114
Copy link
Author

q71114 commented Oct 18, 2023

Hi @nishitha-burman,

Not sure I understood the question, but I used this example for testing so you can check out the hierarchy as needed.

@ynborokh
Copy link

Hi! Are there any news about this issue?

@MarkIngramUK
Copy link

Hello, we are looking into this feature request and I have a follow up question: @q71114 do you know the hierarchy of the nested iframes? Thanks!

We're building a browser, so need to support whatever hierarchy website creators implement (i.e. we have no idea what hierarchy to expect).

@wnayes
Copy link

wnayes commented Jun 22, 2024

Even if FrameNavigationStarting / FrameNavigationCompleted fire for all frames, it would be useful to fix this for the following reason:

FrameCreated is the only way to attach e.Frame.NavigationStarted / e.Frame.NavigationEnded, which are unique in that they receive CoreWebView2Frame as the sender. This lets you know the FrameId associated with with the navigation, which is helpful to keep track of which frames are doing which navigations.

(Of course, that use case could also be helped by providing FrameId on CoreWebView2NavigationStartingEventArgs / CoreWebView2NavigationCompletedEventArgs.)

@qkevin
Copy link

qkevin commented Aug 9, 2024

we need this as well

@victorhuangwq
Copy link
Collaborator

A new API that allows developers to subscribe to the nested iframe creation event, giving them access to all properties, methods, and events of CoreWebView2Frame for the nested iframe is currently in the works.

The API is currently in review here: #4982

@victorhuangwq victorhuangwq added feature request feature request and removed bug Something isn't working labels Dec 13, 2024
@victorhuangwq
Copy link
Collaborator

Hi all!

The FrameCreated API is now available as an experimental API in 1.0.3079-prerelease.
Using this API, your app can subscribe to the nested iframe creation event, giving the app access to all properties, methods, and events of CoreWebView2Frame for the nested iframe.

Please give it a try and let us know if you have any feedback!

@victorhuangwq
Copy link
Collaborator

cc// @MarkIngramUK @q71114 @pushkin-

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature request feature request tracked We are tracking this work internally.
Projects
None yet
Development

No branches or pull requests