Are we giving too much power to the web browsers?

Let's start with the basics. I recently found out that locking my screen in my desktop (Debian Linux) wouldn't suspend the two screens I have attached to it. It should, since the configuration states it should be the case. I checked it and it was correct. I even did the usual waltz of changing the settings to return to the original ones in case something got overwritten.

Then, the next step was to start looking over the Web to try to find a solution. Maybe is a known bug? Maybe something else? I found someone having a problem with their HDMI cable, and since one of the screens uses a DisplayPort to HDMI cable (the screen is a bit old, doesn't have DP) maybe that was the problem. Results, zero, but at least the screen now wakes up better from suspension (when it does go in)

Noticed that closing the session and starting it up again, and locking the screen had the desired suspension happen. So it was, certainly some software that I leave open that was preventing the suspension. So it was all a discarding game... why it took a bit? Because the program preventing the suspension would not do it all the time. No.

It was a certain website preventing my screens suspending (and the computer going into a lower power setting!). Yes, Youtube. Even with a video just loaded, makes my browser not allow the system to suspend.

The problem began when I loaded certain videos for "later watching" and have them visible so they just get ignored. Turns out this is a bad idea if you want your computer to go into suspension.

So now, I close Firefox, with the sessions saved, so I can recover my tabs later when I come back to my computer. I didn't know this was possible and really leaves me stunned. A Javascript in a website can prevent a function from outside from happening. Remote. Code.

#rant #WorldWideWeb

=> ๐Ÿฆ‰ ResetReboot

2024-11-06 ยท 2 months ago ยท ๐Ÿ‘ norayr

11 Comments โ†“

=> ๐Ÿฆ wasolili [...] ยท Nov 06 at 20:03:

for this specific case, it may not be due to javascript (though javascript can be used to do this). browsers will prevent locking if a video is considered to be playing (which seems reasonable since it would be annoying for your screensaver to turn on due to inactivity when you're watching something)

if you go to about:config and search for "wake" you'll see options for disabling it.

=> ๐Ÿฆ‚ zzo38 ยท Nov 06 at 20:14:

Are we giving too much power to the web browsers? Yes. The feature you mentioned is a useful one, but one that the user ought to be allowed to configure.

With many features that web browsers will have, more user commands (keyboard commands, menus, configuration files, etc) to control them should be needed too. Unfortunately, many things require the document to contain them (or JavaScript codes in the document) to work, rather than being specified by user commands which would be better, and the design isn't made very well for such things (instead they tend to remove menus and user options, which doesn't help). Many JavaScript functions and CSS commands will then become unnecessary, if designed better.

=> ๐Ÿš€ stack ยท Nov 06 at 20:39:

I find it disturbing that Firefox (and derivatives) launch dozens of worker processes just in case. The assumption is that the browser is the most important process in the world and any unused memory is wasted unless the browser uses it. For me it's pretty much the opposite.

It's so bad that when I do PS I can't see anything but browser processes generally.

=> ๐Ÿฆ‰ ResetReboot [OP] ยท Nov 08 at 08:31:

Hey @wasolili I went and checked the config and turns out it is another pesky Web API that works both in Firefox and Chrome. So yeah, any JS can go and request that your computer never sleeps for whatever reason, but it is not something your browser does itself.

=> ๐Ÿ™ norayr ยท Nov 09 at 00:27:

one solution could be to suspend the tabs (there are extensions, that is useful to save ram and not run js when you don't need the tab).

what is very cool about firefox and its forks is that it remembers which window was in which workspace. i needed that feature a lot.

=> ๐Ÿš€ stack ยท Nov 09 at 00:40:

On Android the firefox UX is a complete mess -- there are tabs, bookmarks, recently-accessed pages, recently-closed tabs and god knows what else all mixed up. I never know when I'll see what. There are 42 tabs open for some reason on my phone, and I am afraid to touch them because I'd hate to have to actually type in URLs or search again.

=> ๐Ÿ™ norayr ยท Nov 09 at 23:23:

i just had a thought - how does browser prevent locking?

i use gentoo and i remember mplayer has xscreensaver flag. if it is enabled, mplayer is able to stop xscreensaver when it is running.

what that 'flag' means is that mplayer has this compiltation option. its configure script is able to detect presence of xscreensaver, or it is possible to explicitly tell mplayer to not use xscreensaver, and not have that functionality.

i wonder if firefox has such a flag. or, which screensaver/lock screen do you use? i guess from your desktop environment. is it gnome? it has its own screensavers.

=> ๐Ÿ™ norayr ยท Nov 09 at 23:29: | โ€” gentoo firefox flags

i can only see gnome shell integration.

i guess if you use xscreensaver as your locking mechanism this won't happen.

=> ๐Ÿฆ wasolili [...] ยท Nov 10 at 04:11:

@ResetReboot yeah there's a javascript api to let pages prevent locking which can be disabled with the dom.screenwakelock.enabled setting. there's a separate feature where videos prevent locking that can be disabled with the media.video-wakelock setting.

=> ๐Ÿ™ norayr ยท Nov 11 at 11:45:

basically they can tell the program which locks to not lock. And the program may listen instead to you.

=> ๐Ÿฆ‰ ResetReboot [OP] ยท Nov 20 at 12:03:

@norayr I'm using Cinnamon, ditched Gnome 3 after a couple upgrades made it unusable thanks to funky deps on my Debian and now I feel quite comfortable in it. Anyway, yeah, as @wasolilli commented I can disable the web API, but if I watch some long video, I do actually want that.

I guess the solution is to close the damn browser while I'm away from the computer, no need to have that window to remote code execution open while I'm not looking xD

Proxy Information
Original URL
gemini://bbs.geminispace.org/u/ResetReboot/21578
Status Code
Success (20)
Meta
text/gemini; charset=utf-8
Capsule Response Time
148.148696 milliseconds
Gemini-to-HTML Time
1.972805 milliseconds

This content has been proxied by September (ba2dc).