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

utmctl list gives error: OSStatus error -1743 #5377

Open
muzzah opened this issue Jun 8, 2023 · 10 comments
Open

utmctl list gives error: OSStatus error -1743 #5377

muzzah opened this issue Jun 8, 2023 · 10 comments

Comments

@muzzah
Copy link

muzzah commented Jun 8, 2023

Describe the issue
This has been reported in a closed issue so Im creating a new ticket for this as I think its an important fix thats needed.

When using utmctl over ssh, the list command returns an error. This seems to be a gap in capability as I cannot now remotely manage the VMs.

#5001 Is the original issue where this was reported.

[9:41:21] universe:bin $ sudo utmctl list
Error from event: The operation couldn’t be completed. (OSStatus error -600.)

Any known workaround would be appreciated since I am remote and cannot physically access my Mac Studio.

Configuration

  • UTM Version: 4.2.5
  • macOS Version: 13.4
  • Mac Chip (Intel, M1, ...): M1
@muzzah
Copy link
Author

muzzah commented Jun 8, 2023

As a side note, I looked into the config.plist under the ~Library/Containers/com.utmapp.UTM/Data/Documents/[VM NAME] and even if I use the ID or Name of the VM with utmctl it still fails.

I used the key located under UUID below, if this is not correct, can you advise which UUID I should be using? Why does it not work with the name field?

<dict>
		<key>Icon</key>
		<string>linux</string>
		<key>IconCustom</key>
		<false/>
		<key>Name</key>
		<string>Dev Server</string>
		<key>UUID</key>
		<string>8EB11628-544C-44BF-9EDE-4A65A616BEE2</string>
	</dict>

@antekone
Copy link

I have the same problem, I'm not able to manipulate VMs by using utmctl from an SSH session, even if I'm logged in to GUI in another session.

utmctl from a Terminal app from GUI works fine.

@matzuk
Copy link

matzuk commented Jul 27, 2023

@osy hey! First of all, very thank you for your product!
Could you help to answer here? This issue is very critical regarding the usage of UTM VMs in clouds and etc.

@osy
Copy link
Contributor

osy commented Jul 27, 2023

This is unfortunately a limitation of how apple scripting bridge works. You must have the GUI launched or launchable in an interactive instance. I don’t think it works with SSH.

@mitchblank
Copy link

Probably UTMCtl.eventDidFail could print a more helpful error message in the case of errAEEventNotPermitted. Not sure how easy it is to get the numeric code from the Error object (I haven't written any Swift code)

@nre-ableton
Copy link

nre-ableton commented Apr 15, 2024

This is unfortunately a limitation of how apple scripting bridge works. You must have the GUI launched or launchable in an interactive instance. I don’t think it works with SSH.

This makes sense, thanks for the explanation. Is there no way to work around this? For example, by requiring the same user to be logged-in and having the UTM app running?

I was really hoping that our company could use UTM for Mac VMs, but unfortunately as we use Ansible for VM deployments (which runs over SSH), this limitation is a dealbreaker for us. However, our Ansible playbooks use osascript in other places (for example, osascript -e 'tell application "System Events" to keystroke RETURN to dismiss some system dialogs), so it seems like there should theoretically be a way to get this working. 🤔

@osy
Copy link
Contributor

osy commented Apr 15, 2024

I am open to suggestions. Not an expect at Apple script APIs so maybe there's some hidden option I'm not aware of.

@nre-ableton
Copy link

I am open to suggestions. Not an expect at Apple script APIs so maybe there's some hidden option I'm not aware of.

Sadly nor am I, but I'm willing to do a bit of research on the topic. I assume that "rewriting the CLI in another language" is not an acceptable solution? 😅

On that note, why was AppleScript used for the CLI, just out of curiosity?

@matzuk
Copy link

matzuk commented Apr 26, 2024

The CLI should be done in the same manner as it is done in https://github.com/cirruslabs/tart.
I mean, the CLI is just a tiny wrapper over Virtualization.Framework not over GUI.

@tamsky
Copy link

tamsky commented Oct 30, 2024

I had the same error and assumed it was a permissions prompt issue as well.

This fixes it for me:

  • Open: System Settings > Privacy & Security > Full Disk Access
  • Click: + in the bottom left to add a new binary
  • In the file picker that comes up: type CMD-Shift-g to bring up a "Go To Folder/File" dialog
  • Navigate and find your utmctl binary and click "Open" to add the binary.

On my system, /opt/homebrew/bin/utmctl is a symlink to /Applications/Utm.app/Contents/MacOS/utmcl, so I added it using the /Applications/... path.

** IMPORTANT LAST STEP **
Quit and re-launch your OSX Terminal Application where you run the utmctl command.
After utmctl is added to the "Full Disk Access" list, existing terminals and/or shell processes need to be re-launched from the Finder to pick up the new permission.

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

7 participants