mirror of
https://github.com/QubesOS/qubes-doc.git
synced 2024-12-31 18:26:19 -05:00
d82e47c449
- remove `1` from RPC names - change `mgmt.vm.Create` wrt class - misc notes and TODOs QubesOS/qubes-issues#853
11 KiB
11 KiB
layout | title | permalink |
---|---|---|
doc-full | Management API | /doc/mgmt1/ |
Management API
(This page is the current draft of the proposal. It is not implemented yet.)
The API should be implemented as a set of qrexec calls. This is to make it easy to set the policy using current mechanism.
The calls
call | dest | argument | inside | return | note |
---|---|---|---|---|---|
mgmt.vm.List |
dom0 |
- | - | <name> class=<class> state=<state>\n |
|
mgmt.vm.Create.<class> |
dom0 |
template | name=<name> label=<label> |
- | |
mgmt.vm.CreateInPool.<class> |
dom0 |
template | name=<name> label=<label> pool=<pool> |
- | |
mgmt.vm.CreateTemplate |
dom0 |
name | root.img |
- | |
mgmt.vm.property.List |
vm | - | - | <property>\n |
|
mgmt.vm.property.Get |
vm | property | - | `default={yes | no} ` |
mgmt.vm.property.Help |
vm | property | - | help.rst |
|
mgmt.vm.property.Reset |
vm | property | - | - | |
mgmt.vm.property.Set |
vm | property | value | - | |
mgmt.vm.feature.List |
vm | - | - | <feature>\n |
|
mgmt.vm.feature.Get |
vm | feature | - | value | |
mgmt.vm.feature.CheckWithTemplate |
vm | feature | - | value | |
mgmt.vm.feature.Remove |
vm | feature | - | - | |
mgmt.vm.feature.Set |
vm | feature | value | - | |
mgmt.vm.tag.List |
vm | tag | - | <tag>\n |
|
mgmt.vm.tag.Get |
vm | tag | - | 0 or 1 |
retcode? |
mgmt.vm.tag.Remove |
vm | tag | - | - | |
mgmt.vm.tag.Set |
vm | tag | - | - | |
mgmt.vm.firewall.Get |
vm | position | - | <rule id> <rule>\n |
|
mgmt.vm.firewall.InsertRule |
vm | position | rule | rule id | |
mgmt.vm.firewall.RemoveRule |
vm | rule id | - | - | |
mgmt.vm.firewall.Flush |
vm | - | - | - | |
mgmt.vm.device.<class>.Attach |
vm | device | - | - | |
mgmt.vm.device.<class>.Detach |
vm | device | - | - | |
mgmt.vm.device.<class>.List |
vm | - | - | <device>\n |
|
mgmt.vm.device.<class>.Available |
vm | - | - | <device>\n |
|
mgmt.vm.microphone.Attach |
vm | - | - | - | |
mgmt.vm.microphone.Detach |
vm | - | - | - | |
mgmt.pool.List |
dom0 |
- | - | <pool>\n |
|
mgmt.pool.Info |
dom0 |
pool | - | <property>=<value>\n |
|
mgmt.pool.Add |
dom0 |
pool | <property>=<value>\n |
- | |
mgmt.pool.Remove |
dom0 |
pool | - | - | |
mgmt.pool.volume.List |
dom0 |
pool | - | volume id | |
mgmt.pool.volume.Info |
dom0 |
pool:vid | - | <property>=<value>\n |
|
mgmt.pool.volume.ListSnapshots |
dom0 |
pool:vid | - | <snapshot>\n |
|
mgmt.pool.volume.Snapshot |
dom0 |
pool:vid | - | snapshot | |
mgmt.pool.volume.Revert |
dom0 |
pool:vid | snapshot | - | |
mgmt.pool.volume.Extend |
dom0 |
pool:vid | - | <size_in_bytes> |
|
mgmt.vm.volume.List |
vm | -/pool? | - | ? | |
mgmt.vm.volume.Info |
vm | volume | - | ? | |
mgmt.vm.volume.ListSnapshots |
vm | volume | - | snapshot | duplicate of mgmt.pool.volume. , but with other call params |
mgmt.vm.volume.Snapshot |
vm | volume | - | snapshot | id. |
mgmt.vm.volume.Revert |
vm | volume | snapshot | - | id. |
mgmt.vm.volume.Extend |
vm | volume | - | <size_in_bytes> |
id. |
mgmt.vm.volume.Attach |
vm | volume | - | - | |
mgmt.vm.volume.Detach |
vm | volume | - | - | |
mgmt.vm.Start |
vm | - | - | - | |
mgmt.vm.Shutdown |
vm | - | - | - | |
mgmt.vm.Pause |
vm | - | - | - | |
mgmt.vm.Unpause |
vm | - | - | - | |
mgmt.vm.Kill |
vm | - | - | - | |
mgmt.backup.Execute |
dom0 |
config id | - | - | config in /etc/qubes/backup/<id>.conf |
mgmt.backup.Info |
dom0 |
? | content? | ? | |
mgmt.backup.Restore |
dom0 |
? | content | ? |
Tags
created-by-<vm>
managed-by-<vm>
backup-<id>
General notes
- there is no provision for
qvm-run
, but there already existsqubes.VMShell
call
TODO
- something to configure/update policy
- notifications
- how to constrain the events?
- how to pass the parameters? maybe XML, since this is trusted anyway and parser may be complicated
- how to constrain the possible values for
mgmt.vm.property.Set
etc, like "you can changenetvm
, but you have to pick from this set"; this currently can be done by writing an extension - a call for executing
*.desktop
file from/usr/share/applications
, for use with appmenus without giving access toqubes.VMShell
; currently this can be done by writing custom qrexec calls - maybe some generator for
.desktop
for appmenus, which would wrap calls inqrexec-client-vm