Microsoft: Introducing Sudo for Windows!

Shipped in Windows 11 Insider Preview Build 26052. https://www.tiraniddo.dev/2024/02/sudo-on-windows-quick-rundown.html claims it has a big security problem that makes the program accept calls to elevate from anywhere once first run

Edit:

  1. The security problem has been internally fixed and will be available in the next release
  2. It's not just an alias for 'runas'. It seems to be able to configurably block user input for sudo'd commands, retain the existing environment, ditch it and open a new window, and remember that you've sudo'd in the last minute or so.
  3. It brings up UAC instead of having you input the password
nothacking,

This would be real nice if this let you easly run commands as SYSTEM or TrustedInstaller from a script, not just as Admin. Not only can Admin be reached from the “Run as Admininstrator” menu option, is actualy quite limited for messing around with system files. For the most part, Admin lets you mess with system settings/registry, and user files, but not with a lot if system/application files without TAKEOWNing everything.

venia_sil,
@venia_sil@fedia.io avatar

sudo format /q c: && apt install debian

Nice!

LallyLuckFarm,
reddthat,
@reddthat@reddthat.com avatar

I’ve been using Sudo for years.

  • install scoop
  • scoop install sudo
Nath,
@Nath@aussie.zone avatar

I was Googling like mad just this week on how to execute a cmdlet as Admin from within a script that isn’t running with elevated privileges. The results all basically came back with some variation of “just run the script as Admin”.

This is the right way to do it. I’m glad it’s coming.

jarfil,

start-process -verb runas

learn.microsoft.com/en-us/…/start-process

Not the same as sudo, but mostly equivalent for single cmdlets or scripts.

Nath,
@Nath@aussie.zone avatar

That’s where I started, of course - but you can’t combine -verb with -credential. It’s a silly limitation that seems to make sense to Microsoft. What you can do is configure a savecred which you can call with RunAs, but you then need to update that saved credential every time the password changes.

I do have a $Credential object that has been pulled out of the password safe that has elevation permissions, but can’t seem to apply it non-interactively or without being in an elevated session. This appears to be by design. Not that I intended my comment to turn into a support question. 😀

NoLifeKing,

Use Linux is the awnsers i got…

jarfil,

Haven’t tried it on Linux, but it says the -verb runas only works on Windows… might have to use actual sudo on Linux.

beefcat,
@beefcat@beehaw.org avatar

runas will do it, but the syntax is awful. i’m so glad windows is finally getting a real sudo

Aatube,
Aatube avatar

google gsudo

Nath,
@Nath@aussie.zone avatar

I like it! I think I’ll tinker with this on my workstation, potentially even my dev environment. It isn’t suitable for my present issue though, as gsudo is not in the SOE. Also, from that little demo thingy, it appears to pop up a UAC prompt the first time it executes. I need to be non-interactive.

Aatube,
Aatube avatar

MS sudo also does UAC

Nath,
@Nath@aussie.zone avatar

This is a sad revelation. This sudo implementation wasn’t going to make much difference to me immediately anyway, as I assume sudo won’t be in Windows Server until v2025. But still: I was hoping it would work like *nix with a sudoers file or something similar.

tesseract, (edited )

The OpenBSD devs published a mail about it. The irony here is how Microsoft would behave if anybody else copied their concepts, including the name. The treatment is never symmetric or reciprocal.

UNIX84,

I mean licensing comes in here. The FOSS licenses allow this. Microsoft EULA and copyright almost certainly does not. But yes, I get the sentiment.

It’s almost as if all of the FAANG/Magnificent 7 market outperformance the past 15 years was built on the backs of the free labor provided by the FOSS movement. But then they will turn around and claim that non-western companies steal IP, etc and have US intervene to ban competition, or sue in courts. Kind of funny.

Back to the tech discussion, I’ve been using doas for a few years now instead of sudo. Even on my GNU/Linux machines. It’s a lot simpler to setup for desktop workflow machines.

jarfil,

free labor provided by the FOSS movement

Check out the contributors to Linux, how many of them work for free vs. how many work on behalf of companies.

There is this pervasive myth that FOSS gets developed by lone wolves working in their spare time, when in reality most of the projects that get any traction, have a financing model behind them.

jarfil,

No irony there; BSD devs want companies to copy their code and close it down… or they wouldn’t be using the BSD license.

Pilgrim,

I would say “hey that’s just copying” but Microsoft is legally incapable of being wrong, or noticing irony so I’ll leave it be

OmnipotentEntity,
@OmnipotentEntity@beehaw.org avatar

If I’m understanding this correctly, it’s not even copying. It’s apparently just a wrapper for the built-in runas command that’s been there since Windows 2000.

Penguincoder,

Exactly. Windows already has this functionality with runas and this implantation doesn’t improve on it at all.

TxzK,

Classic Microsoft. Just change the look and be done with. No need it to actually improve the internals.

Aatube,
Aatube avatar

It's more complicated than that. It seems to be able to configurably block user input for sudo'd commands, retain the existing environment, ditch it and open a new window, and remember that you've sudo'd in the last minute or so.

zadjii,
@zadjii@mastodon.social avatar

@OmnipotentEntity @Pilgrim it's actually not just a wrapper for runas. There's a lot of other plumbing here to get the console handle you're actually using plumbed to the target application. That's the magic that lets you actually interact with the elevated process in the same terminal.

With runas, the target application is just stuck in a separate console window (gross)

OmnipotentEntity,
@OmnipotentEntity@beehaw.org avatar

So please forgive me if this is a rather naive question. I haven’t seriously used Windows in nearly 15 years.

I seem to recall runas being a lot like su, in that you enter the target user’s credentials, rather than your own as in sudo. This works because sudo is a setuid executable, and reads from configuration to find out what you’re allowed to do as the switched user.

Is the behavior of windows sudo like unix su or unix sudo with regard to the credentials you enter? Can you limit the user to only certain commands?

Aatube,
Aatube avatar

It brings up a UAC prompt, so any admin's credentials ig

OmnipotentEntity,
@OmnipotentEntity@beehaw.org avatar

So it’s su then, not sudo.

Aatube,
Aatube avatar

(this is the maintainer)

  • All
  • Subscribed
  • Moderated
  • Favorites
  • technology@beehaw.org
  • DreamBathrooms
  • magazineikmin
  • InstantRegret
  • hgfsjryuu7
  • vwfavf
  • Youngstown
  • slotface
  • thenastyranch
  • ngwrru68w68
  • rosin
  • kavyap
  • PowerRangers
  • Durango
  • khanakhh
  • anitta
  • mdbf
  • tacticalgear
  • ethstaker
  • modclub
  • osvaldo12
  • everett
  • tester
  • cubers
  • GTA5RPClips
  • normalnudes
  • Leos
  • cisconetworking
  • provamag3
  • All magazines