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

This method apperently doesn't work anymore #3

Open
NeverSm1le opened this issue Aug 3, 2023 · 23 comments
Open

This method apperently doesn't work anymore #3

NeverSm1le opened this issue Aug 3, 2023 · 23 comments

Comments

@NeverSm1le
Copy link

I have used both method (magisk and just the overlay zip) on 2 different devices, both run Android 13 QPR3. I contact rom developers and they doesn't change anything. It indeed worked on QPR2 so I guess Google do something that change the overlay in QPR3. Another module relies on overlay (open-webview) also doesn't work.

@lss4
Copy link

lss4 commented Oct 2, 2023

It appears with newer Android 13 the overlay needs to be installed to /system/product/overlay instead of /system/vendor/overlay. Altered the build script to package the overlay to the new path and it worked -- Mulch Webview is now selectable.

@lss4
Copy link

lss4 commented Oct 2, 2023

Here is an example change I made to the build script to create a package that'll install the overlay to the new path. The generated Magisk module also works with KernelSU.

I'm not sure about the compatibility with older Android versions when using /product/overlay instead of /vendor/overlay, so I'm tracking this change in a separate branch in my fork at the moment.

@akasaka99
Copy link

Hi, I would like to try your updated version on /e/OS based LOS 20 (A13) using the custom recovery method and I see you made the changes to your script about a week ago but v0.1 is from March 17. Where your changes included in v0.1 ? Thanks

@lss4
Copy link

lss4 commented Oct 12, 2023

I'm tracking this change on a separate branch in my own fork, as I do not know if this breaks Android 12 and earlier support. If older Android versions (preferably from 10 and onwards) can still work this way I could consider making a PR.

I only changed the build.sh script. You can just cherry-pick my commit into your existing workspace and create working packages, or fork my A13 branch.

@lss4
Copy link

lss4 commented Oct 12, 2023

Hi, I would like to try your updated version on /e/OS based LOS 20 (A13) using the custom recovery method and I see you made the changes to your script about a week ago but v0.1 is from March 17. Where your changes included in v0.1 ? Thanks

Hmmm... if you're using custom recovery method instead of Magisk/KSU then I'm afraid I need to make some changes to update-binary. As I'm not modifying /system directly (by using the Magisk/KSU module)... I neglected it.

EDIT: The addon.d script is fine. It already covered the /product/overlay scenario.

@lss4
Copy link

lss4 commented Oct 12, 2023

I've just added some more changes in my A13 branch.

Will now produce two different variants of packages, one for /vendor/overlay which will continue to work with older Android versions, and the other for /product/overlay which is needed by Android 13 and onwards.

Testing needed for non-Magisk/KSU packages as I'm not sure if changes to update-binary might have broken anything.

@akasaka99
Copy link

I really like your rootless overlay approach, as you wrote in your notes it's indeed clean and elegant. I personally try to avoid Magisk if I can, eventhough it does wonders... at some risk.

  1. I just checked and I realise I also have a LOS A10 phone which I see has been a last updated with version 108.xxxx (never paid attention to it before as I assumed it would update somehow ...) probably since bromite stopped so I downloaded your v0.1 version from March 17 release.

  2. Sorry, where is your A13 branch ?

@lss4
Copy link

lss4 commented Oct 13, 2023

2. Sorry, where is your `A13` branch ?

Here it is.

With my latest changes, there will be two sets of generated packages: vendor and product, indicating where the overlay would be installed.

I can't test the recovery packages for you, as I don't want to make changes to /system. The Magisk module can be used with KernelSU as well.

@NeverSm1le
Copy link
Author

2. Sorry, where is your `A13` branch ?

Here it is.

With my latest changes, there will be two sets of generated packages: vendor and product, indicating where the overlay would be installed.

I can't test the recovery packages for you, as I don't want to make changes to /system. The Magisk module can be used with KernelSU as well.

As far as I'm understand, running build.sh will generate the necessary modules right? I'm a newbie at linux

@akasaka99
Copy link

akasaka99 commented Oct 13, 2023

Ok needs to be installed manually. Won't go there as if there's an issue not sure will be able to revert to previous stage, so will leave it there. Thanks anyway!

@lss4
Copy link

lss4 commented Oct 14, 2023

As far as I'm understand, running build.sh will generate the necessary modules right? I'm a newbie at linux

Yes, that's all you need. If the script finishes without issues, collect the modules in the build folder.

Ok needs to be installed manually. Won't go there as if there's an issue not sure will be able to revert to previous stage, so will leave it there. Thanks anyway!

I don't think it would cause too much harm, as it involves only a single file that would be the overlay. The problem is, you'll definitely have to rely on the module (Magisk/KSU), if your system partitions cannot be made r/w.

If you install it from recovery (such as Lineage's) you need to do so via adb sideload similar to how you'd install Magisk, GApps and such.

If your device happens to have a usable TWRP you may flash the zip directly from there after putting it into your phone storage.

I haven't changed the README file yet. The only difference from the original instructions would be to choose the one with product or with vendor depending on your Android version.

@lss4
Copy link

lss4 commented Nov 20, 2023

@lss4 Can you release this again for A13 ?

Done.

Note that I cannot test MulchSystemWebViewOverlay as I'm using Magisk/KernelSU and I don't intend to modify /system on my device directly.

As usual, be sure to make backups in case something goes wrong.

@lss4
Copy link

lss4 commented Nov 20, 2023

Installed successfully

~ $ su -c cmd overlay list | grep mulch
[x] com.alpha.mulch.webview.overlay

But I don't see webview in dev options

Why do you think so ?

Which variant are you using?

On the other hand... I tried your command on my own device but I don't see the entry... hmmm...

Maybe it's because I'm on KernelSU?

EDIT: You should refer to the output of this command.

adb shell dumpsys webviewupdate

See if it has a line mentioning about us.spotco.mulch_wv.

@lss4
Copy link

lss4 commented Nov 21, 2023

org.bromite.webview is NOT installed.

I think you've installed a Bromite WebView overlay before, which took priority over Mulch overlay so it cannot work.

Disable any other WebView overlay module you've installed, and see if it makes any difference.

@lss4
Copy link

lss4 commented Nov 21, 2023

Bromite I used 6 months before. It didn't exist now. I don't even know how it is showing there. It's obsolete.

~ $ su -c cmd overlay list | grep bromite
~ $ su -c cmd package list packages | grep bromite

The commands you're using are not reliable.
On my device Mulch overlay is installed and usable, but it's not shown in # cmd overlay list.
You need to check all your modules and see if you have any overlay that alters the webview package list.

@lss4
Copy link

lss4 commented Nov 21, 2023

An update on this.

If you're using phh-based GSI this built-in overlay which included Bromite support back then may have conflicted with this, and probably explained why you have a Bromite entry in the list of WebViews.

I'll be downloading and inspecting the GSI build you mentioned to see if this applies. It's been a while since I used new GSIs and I kinda forgot about it.

EDIT: Confirmed. I've filed an issue there.

A possible workaround would be to override (replace) the existing overlay (/system/product/overlay/treble-overlay-highpriomisc.apk) with this one by using the same filename.

@lss4
Copy link

lss4 commented Nov 22, 2023

I've made a second experimental release, which raised the overlay's priority to 9999 from 1.

Should be enough to make it take effect in GSIs.

@soulspark666
Copy link

I've made a second experimental release, which raised the overlay's priority to 9999 from 1.

Should be enough to make it take effect in GSIs.

This works for me on a Custom ROM without any issues.

@meequrox
Copy link

meequrox commented Mar 6, 2024

Can confirm @lss4's test-release2 works even on A14 (with Magisk).

@cairobraga
Copy link

Can confirm @lss4's test-release2 works even on A14 (with Magisk).

Can also confirm it works on /e/OS 2.1 (A13), as a Magisk module.

@gitzila
Copy link

gitzila commented Jan 3, 2025

Hi, I tried this with all variants of the @lss4's test-release2: Magisk (vendor and product) and Sideload (vendor and product) on LOS 22.1 (Android 15) with my OP7t. Does not work. The Zips can be installed without error (I checked if the overlay file was placed correctly: it was). But after installing Mulch web view and reboot I cannot change the web view impl. neither in the developer settings nor directly with adb cmd. Has anyone info about what might have been changed from A14 to A15?

@lss4
Copy link

lss4 commented Jan 3, 2025

Hi, I tried this with all variants of the @lss4's test-release2: Magisk (vendor and product) and Sideload (vendor and product) on LOS 22.1 (Android 15) with my OP7t. Does not work. The Zips can be installed without error (I checked if the overlay file was placed correctly: it was). But after installing Mulch web view and reboot I cannot change the web view impl. neither in the developer settings nor directly with adb cmd. Has anyone info about what might have been changed from A14 to A15?

Can confirm... it's not working anymore, after upgrading my phone from crDroid 10 (A14) to 11 (A15).

I've updated the note on my latest test release to reflect this discovery.

EDIT: Guess the problem lies elsewhere. Even on Android 15 the installed overlay is indeed present per cmd overlay list.

EDIT 2: Apparently as of crDroid 11 (Android 15) all overlays regarding config_webview_packages.xml don't work, despite being present. In my system the stock file in framework-res.apk contained only the AOSP webview entry, and there is a android.auto_generated_rro_product__ overlay supposedly provided additional entries for Google WebViews and that also doesn't work. Just tried installing Google WebView Dev from Play Store (com.google.android.webview.dev) and that doesn't show up as a WebView option, either. Actually, dumpsys webviewupdate showed only the stock WebView which corresponds to the unmodified config_webview_packages.xml from my crDroid 11 install.

PS: Is anyone using phhusson's latest A15 GSI? As of 20241218 Mulch was added into the treble-overlay-highpriomisc.apk overlay so Mulch WebView should be usable there out-of-box without the need of the module here. If Mulch (and others) work then there might be some other reasons preventing config_webview_packages.xml from being overridden...

@lss4
Copy link

lss4 commented Jan 11, 2025

Some additions. Just checked Android 15 release notes and found this.

Vendor overlay
Android 15 deprecates vendor overlay.

I wonder if it's related, but AFAIK this as a vendor overlay stopped working since A13 (the OP of this issue) and until now can only work when installed as a product overlay.

EDIT: Adding some further diggings on my device (crDroid 11.0, A15)...

cmd overlay lookup --verbose --user 0 android android:xml/config_webview_packages shows config_webview_packages.xml was indeed overlaid by this module.

Disabling this module and let my system's built-in RRO to take effect, the same command shows config_webview_packages.xml was indeed overlaid as well (by the built-in RRO).

However, in neither case dumpsys webviewupdate is reporting information about any "not installed" WebView package as they should (if the xml file contained such entries and they were valid), be it Mulch (from this module), or Google's (from the built-in RRO). This corresponds to the ROM's default config_webview_packages.xml file which is the same as AOSP upstream and contained only the default entry, and in this state, even Google's WebView variants on Play Store will not be usable.

PS: I think I should put it here, which I only just know that DivestOS is coming to an end so Mulch (and its WebView) will not be updated anymore. The current issue with overlaying config_webview_packages.xml on A15 remains relevant, however.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants
@akasaka99 @lss4 @soulspark666 @cairobraga @NeverSm1le @gitzila @meequrox and others