Return scheduled-backup configuration, retention settings, recent schedule history, limits, and action gates. Get {id} from GET /api/v2/vps. Use schedules[].id as {scheduleId} for deletion. Only one schedule can be active per VPS; POST updates an existing schedule with the same frequency. Scheduled backups create offsite, longer-term recovery images and can take longer to create or restore than snapshots. Use snapshot schedules only for short-lived local block-on-write rollback points.
read:vm
Use Authorization: Bearer <token> for API keys. Dashboard sessions may also use hostup_session.
id string required
Example: vps_01hxa3b4c5d6e7f8g9h0j1k2m3 Public VPS ID 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 schedules array<object> required schedules[].id string required
· Example: bks_01hxa3b4c5d6e7f8g9h0j1k2m3 schedules[].name string required
· Example: Nightly backup schedules[].frequency string · enum required
· Example: daily daily weekly monthly schedules[].time stringnull required
· Example: 02:00 schedules[].daySpecifier stringnull required
· Example: 1 schedules[].retentionCount integer required
· Example: 3 schedules[].enabled boolean required
· Example: true schedules[].lastRun stringnull required
· Example: 2026-04-27T02:00:00.000Z schedules[].nextRun stringnull required
· Example: 2026-04-28T02:00:00.000Z schedules[].status stringnull · enum required
· Example: null completed running queued failed cancelled unknown settings object required
· Example: null settings.totalBackupLimit integer required
· Example: 5 settings.manualBackupsActive integer required
· Example: 1 settings.scheduledBackupsActive integer required
· Example: 2 settings.availableScheduledSlots integer required
· Example: 2 settings.autoDeleteOldest boolean required
· Example: true history array<object> required history[].backupType stringnull required
· Example: scheduled history[].status string · enum required
· Example: running completed running queued failed cancelled unknown history[].createdAt stringnull required
· Example: 2026-04-27T02:00:00.000Z history[].updatedAt stringnull required
· Example: null history[].note stringnull required
· Example: Nightly backup limits object required limits.maxSchedules integer required
· Example: 1 limits.totalBackups integer required
· Example: 5 limits.maxRetention integer required
· Example: 5 limits.currentSchedules integer required
· Example: 1 limits.manualBackupsActive integer required
· Example: 1 limits.scheduledBackupsActive integer required
· Example: 2 limits.availableScheduledSlots integer required
· Example: 2 actions object required actions.canCreate object required actions.canCreate.allowed boolean required
· Example: true actions.canCreate.reason stringnull required
· Example: null actions.canCreate.code stringnull
· Example: pending_order Machine-readable reason code when an action is blocked.
actions.canUpdateSettings object required actions.canUpdateSettings.allowed boolean required
· Example: true actions.canUpdateSettings.reason stringnull required
· Example: null actions.canUpdateSettings.code stringnull
· Example: pending_order Machine-readable reason code when an action is blocked.
actions.canDelete object required actions.canDelete.allowed boolean required
· Example: true actions.canDelete.reason stringnull required
· Example: null actions.canDelete.code stringnull
· Example: pending_order Machine-readable reason code when an action is blocked.
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}/backup-schedules curl -X GET "https://cloud.hostup.se/api/v2/vps/vps_01hxa3b4c5d6e7f8g9h0j1k2m3/backup-schedules" \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Accept: application/json" {
"schedules": [
{
"id": "bks_01hxa3b4c5d6e7f8g9h0j1k2m3",
"name": "Nightly backup",
"frequency": "weekly",
"time": "02:00",
"daySpecifier": "1",
"retentionCount": 7,
"enabled": true,
"lastRun": "2026-04-27T02:00:00.000Z",
"nextRun": "2026-05-04T02:00:00.000Z",
"status": null
}
],
"settings": {
"totalBackupLimit": 5,
"manualBackupsActive": 1,
"scheduledBackupsActive": 2,
"availableScheduledSlots": 2,
"autoDeleteOldest": true
},
"history": [
{
"backupType": "scheduled",
"status": "running",
"createdAt": "2026-04-27T02:00:00.000Z",
"updatedAt": null,
"note": "Nightly backup"
}
],
"limits": {
"maxSchedules": 1,
"totalBackups": 5,
"maxRetention": 5,
"currentSchedules": 1,
"manualBackupsActive": 1,
"scheduledBackupsActive": 2,
"availableScheduledSlots": 2
},
"actions": {
"canCreate": {
"allowed": false,
"reason": "A backup schedule already exists. Update or delete it before creating another."
},
"canUpdateSettings": {
"allowed": true,
"reason": null
},
"canDelete": {
"allowed": true,
"reason": null
}
}
}