Change firmware mode to incus or legacy. Use incus for UEFI with Secure Boot and TPM 2.0; use legacy for BIOS without TPM. Optional storage is an advanced placement hint matching [A-Za-z0-9_-]{1,64}.
write:vmwrite:storage
Use Authorization: Bearer <token> for API keys. Dashboard sessions may also use hostup_session.
id string required
Example: vps_01hxa3b4c5d6e7f8g9h0j1k2m3 Public VPS ID. Get it from GET /api/v2/vps `data[].id`. Do not invent this value; use the exact ID returned by the referenced API response.
Accept Example Content-Type Example mode string · enum required
· Example: incus incus legacy storage string
· Example: local-lvm mode string · enum required
· Example: incus incus legacy summary string required
· Example: Firmware mode was changed to UEFI with Secure Boot and TPM 2.0. firmware object | null required
· Example: null firmware.status stringnull required
· Example: stopped firmware.bios stringnull required
· Example: ovmf firmware.machine stringnull required
· Example: q35 firmware.mode stringnull required
· Example: incus firmware.efi object | null required
· Example: null firmware.efi.volume stringnull required
· Example: local-lvm:vm-100-disk-0 firmware.efi.type stringnull required
· Example: 4m firmware.efi.size stringnull required
· Example: 4M firmware.efi.preEnrolledKeys boolean required
· Example: true firmware.tpm object | null required
· Example: null firmware.tpm.volume stringnull required
· Example: local-lvm:vm-100-disk-1 firmware.tpm.size stringnull required
· Example: 4M firmware.tpm.version stringnull required
· Example: 2.0 firmware.secureBootReady boolean required
· Example: true firmware.tpmReady boolean required
· Example: true firmware.actions object required firmware.actions.canChangeMode object required firmware.actions.canChangeMode.allowed boolean required
· Example: true firmware.actions.canChangeMode.reason stringnull required
· Example: null type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object type string
· Example: https://developer.hostup.se/errors/invalid_request title string
· Example: Validation failed status integer
· Example: 400 detail string
· Example: The request body failed validation. code string
· Example: invalid_request Stable machine-readable code. Branch on this field, not on `detail`.
instance string
· Example: /api/v2/orders requestId string
· Example: req_01hxa3b4c5d6e7f8g9h0j1k2m3 timestamp string
· Example: 2026-04-27T12:34:56.000Z errors array<object> Field-level validation errors when `code` is `invalid_request`.
errors[].pointer string required
· Example: /items/0/eppCode errors[].detail string required
· Example: `eppCode` is required for this transfer. errors[].code string required
· Example: missing_required extensions object https://cloud.hostup.se/api/v2/vps/{id}/firmware curl -X PUT "https://cloud.hostup.se/api/v2/vps/vps_01hxa3b4c5d6e7f8g9h0j1k2m3/firmware" \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '{
"mode": "incus"
}' {
"mode": "incus",
"summary": "Firmware mode was changed to UEFI with Secure Boot and TPM 2.0.",
"firmware": {
"status": "stopped",
"bios": "ovmf",
"machine": "q35",
"mode": "incus",
"efi": {
"volume": "local-lvm:vm-100-disk-0",
"type": "4m",
"size": "4M",
"preEnrolledKeys": true
},
"tpm": {
"volume": "local-lvm:vm-100-disk-1",
"size": "4M",
"version": "2.0"
},
"secureBootReady": true,
"tpmReady": true,
"actions": {
"canChangeMode": {
"allowed": true,
"reason": null
}
}
}
} {
"mode": "incus"
}