Skip to main content

mountos_admin_sdk/
types_gen.rs

1// Code generated by gen; DO NOT EDIT.
2
3use serde::{Deserialize, Serialize};
4
5/// Client configuration.
6#[derive(Debug, Clone, Default)]
7pub struct Config {
8    /// Base URL of the appserv provider API, e.g. `https://appserv.example.com`.
9    pub base_url: String,
10    /// Base64-encoded ED25519 private key (32-byte seed or 64-byte seed+public key).
11    pub private_key: String,
12    /// Optional dashboard operator context, signed into each request.
13    pub dashboard_user: Option<DashboardUser>,
14    /// Dedicated HMAC secret for the `X-MountOS-Dashboard-User` header (appserv
15    /// `DASHBOARD_USER_HMAC_KEY`); required when `dashboard_user` is set.
16    pub dashboard_hmac_key: Option<String>,
17}
18
19/// Page-based pagination options.
20#[derive(Debug, Clone, Default)]
21pub struct ListOptions {
22    pub page: Option<i64>,
23    pub limit: Option<i64>,
24}
25
26/// Pagination metadata returned by page-based list endpoints.
27#[derive(Debug, Clone, Deserialize)]
28pub struct PaginationMeta {
29    pub page: i64,
30    pub limit: i64,
31    pub total: i64,
32    #[serde(rename = "totalPages")]
33    pub total_pages: i64,
34}
35
36/// Page-based list response.
37#[derive(Debug, Clone, Deserialize)]
38pub struct PaginatedResponse<T> {
39    pub items: Vec<T>,
40    pub pagination: PaginationMeta,
41}
42
43/// Cursor-based list response.
44#[derive(Debug, Clone, Deserialize)]
45pub struct CursorPaginatedResponse<T> {
46    pub items: Vec<T>,
47    #[serde(rename = "nextCursor")]
48    pub next_cursor: Option<i64>,
49}
50
51/// Identifier returned by create/edit/toggle endpoints.
52#[derive(Debug, Clone, Deserialize)]
53pub struct IdResponse {
54    pub id: i64,
55}
56
57/// `ClientSessionStatus` values accepted/returned on the wire.
58pub type ClientSessionStatus = String;
59pub const CLIENT_SESSION_STATUS_CONNECTED: &str = "connected";
60pub const CLIENT_SESSION_STATUS_ACTIVE: &str = "active";
61pub const CLIENT_SESSION_STATUS_UNHEALTHY: &str = "unhealthy";
62pub const CLIENT_SESSION_STATUS_DISCONNECTED: &str = "disconnected";
63pub const CLIENT_SESSION_STATUS_EXPIRED: &str = "expired";
64pub const CLIENT_SESSION_STATUS_UNKNOWN: &str = "unknown";
65
66/// `LicenseQuotaState` values accepted/returned on the wire.
67pub type LicenseQuotaState = String;
68pub const LICENSE_QUOTA_STATE_OK: &str = "ok";
69pub const LICENSE_QUOTA_STATE_EXCEEDED: &str = "exceeded";
70
71/// `LicenseStatus` values accepted/returned on the wire.
72pub type LicenseStatus = String;
73pub const LICENSE_STATUS_VALID: &str = "valid";
74pub const LICENSE_STATUS_EXPIRING: &str = "expiring";
75pub const LICENSE_STATUS_GRACE: &str = "grace";
76pub const LICENSE_STATUS_EXPIRED_ACCESS: &str = "expired_access";
77pub const LICENSE_STATUS_EXPIRED: &str = "expired";
78
79#[derive(Debug, Clone, Serialize, Deserialize)]
80pub struct Account {
81    pub id: i64,
82    pub name: String,
83    pub description: String,
84    #[serde(rename = "iconUrl", skip_serializing_if = "Option::is_none")]
85    pub icon_url: Option<String>,
86    #[serde(rename = "providerInfo", skip_serializing_if = "Option::is_none")]
87    pub provider_info: Option<serde_json::Value>,
88    #[serde(rename = "liveVolume")]
89    pub live_volume: i64,
90    #[serde(rename = "totalVolume")]
91    pub total_volume: i64,
92    #[serde(rename = "quotaLimit")]
93    pub quota_limit: i64,
94    #[serde(rename = "quotaExcessPct")]
95    pub quota_excess_pct: i32,
96    #[serde(rename = "isActive")]
97    pub is_active: bool,
98    pub locked: bool,
99    #[serde(rename = "createdAt")]
100    pub created_at: String,
101    #[serde(rename = "updatedAt")]
102    pub updated_at: String,
103}
104
105#[derive(Debug, Clone, Serialize, Deserialize)]
106pub struct User {
107    pub id: i64,
108    #[serde(rename = "accountId")]
109    pub account_id: i64,
110    pub username: String,
111    pub email: String,
112    pub name: String,
113    #[serde(rename = "isActive")]
114    pub is_active: bool,
115}
116
117#[derive(Debug, Clone, Serialize, Deserialize)]
118pub struct Region {
119    pub id: i64,
120    #[serde(rename = "exportId")]
121    pub export_id: String,
122    #[serde(rename = "accountId")]
123    pub account_id: i64,
124    pub name: String,
125    pub dns: String,
126    #[serde(rename = "liveVolume")]
127    pub live_volume: i64,
128    #[serde(rename = "totalVolume")]
129    pub total_volume: i64,
130    #[serde(rename = "isActive")]
131    pub is_active: bool,
132    #[serde(rename = "createdAt")]
133    pub created_at: String,
134    #[serde(rename = "updatedAt")]
135    pub updated_at: String,
136}
137
138#[derive(Debug, Clone, Serialize, Deserialize)]
139pub struct RegionCluster {
140    pub id: i64,
141    #[serde(rename = "exportId")]
142    pub export_id: String,
143    #[serde(rename = "regionId")]
144    pub region_id: i64,
145    pub name: String,
146    #[serde(rename = "defaultCluster")]
147    pub default_cluster: bool,
148    #[serde(rename = "isReady")]
149    pub is_ready: bool,
150    #[serde(rename = "isActive")]
151    pub is_active: bool,
152    #[serde(rename = "createdAt")]
153    pub created_at: String,
154    #[serde(rename = "updatedAt")]
155    pub updated_at: String,
156}
157
158#[derive(Debug, Clone, Serialize, Deserialize)]
159pub struct Storage {
160    pub id: i64,
161    pub uuid: String,
162    pub account: Ref,
163    #[serde(rename = "regionInfo")]
164    pub region_info: Ref,
165    pub name: String,
166    #[serde(skip_serializing_if = "Option::is_none")]
167    pub description: Option<String>,
168    #[serde(rename = "storageType")]
169    pub storage_type: String,
170    #[serde(rename = "providerType")]
171    pub provider_type: String,
172    pub endpoint: String,
173    #[serde(skip_serializing_if = "Option::is_none")]
174    pub region: Option<String>,
175    #[serde(skip_serializing_if = "Option::is_none")]
176    pub bucket: Option<String>,
177    #[serde(skip_serializing_if = "Option::is_none")]
178    pub base: Option<String>,
179    #[serde(rename = "blockRegion", skip_serializing_if = "Option::is_none")]
180    pub block_region: Option<String>,
181    #[serde(rename = "blockSize", skip_serializing_if = "Option::is_none")]
182    pub block_size: Option<i32>,
183    #[serde(rename = "isActive")]
184    pub is_active: bool,
185    #[serde(rename = "createdAt")]
186    pub created_at: String,
187    #[serde(rename = "updatedAt")]
188    pub updated_at: String,
189}
190
191#[derive(Debug, Clone, Serialize, Deserialize)]
192pub struct BlockVolume {
193    pub id: String,
194    #[serde(skip_serializing_if = "Option::is_none")]
195    pub name: Option<String>,
196    #[serde(rename = "clusterName", skip_serializing_if = "Option::is_none")]
197    pub cluster_name: Option<String>,
198    #[serde(rename = "clusterUuid", skip_serializing_if = "Option::is_none")]
199    pub cluster_uuid: Option<String>,
200    #[serde(rename = "shardId")]
201    pub shard_id: i64,
202    #[serde(rename = "regionClusterId")]
203    pub region_cluster_id: i64,
204    #[serde(rename = "clusterReady")]
205    pub cluster_ready: bool,
206    #[serde(rename = "isActive")]
207    pub is_active: bool,
208    #[serde(rename = "createdAt")]
209    pub created_at: String,
210    #[serde(rename = "updatedAt")]
211    pub updated_at: String,
212}
213
214#[derive(Debug, Clone, Serialize, Deserialize)]
215pub struct Volume {
216    pub id: i64,
217    pub account: Ref,
218    pub storage: Ref,
219    pub region: Ref,
220    #[serde(rename = "regionCluster", skip_serializing_if = "Option::is_none")]
221    pub region_cluster: Option<Ref>,
222    pub name: String,
223    #[serde(skip_serializing_if = "Option::is_none")]
224    pub description: Option<String>,
225    #[serde(rename = "volumeType")]
226    pub volume_type: String,
227    #[serde(rename = "storageType", skip_serializing_if = "Option::is_none")]
228    pub storage_type: Option<String>,
229    pub encryption: bool,
230    #[serde(rename = "quotaLimit")]
231    pub quota_limit: i64,
232    #[serde(rename = "liveVolume")]
233    pub live_volume: i64,
234    #[serde(rename = "totalVolume")]
235    pub total_volume: i64,
236    #[serde(rename = "pendingVolume")]
237    pub pending_volume: i64,
238    #[serde(rename = "liveInactiveVolume")]
239    pub live_inactive_volume: i64,
240    pub locked: bool,
241    #[serde(rename = "retentionPeriod")]
242    pub retention_period: i32,
243    #[serde(rename = "gracePeriod")]
244    pub grace_period: i32,
245    #[serde(rename = "forkGracePeriod")]
246    pub fork_grace_period: i32,
247    #[serde(rename = "eventLogRetentionPeriod")]
248    pub event_log_retention_period: i32,
249    #[serde(rename = "isActive")]
250    pub is_active: bool,
251    #[serde(rename = "isCleanupMetaEnabled")]
252    pub is_cleanup_meta_enabled: bool,
253    #[serde(rename = "isCleanupStorageEnabled")]
254    pub is_cleanup_storage_enabled: bool,
255    #[serde(rename = "isCleanupVaultEnabled")]
256    pub is_cleanup_vault_enabled: bool,
257    #[serde(rename = "createdAt")]
258    pub created_at: String,
259    #[serde(rename = "updatedAt")]
260    pub updated_at: String,
261}
262
263#[derive(Debug, Clone, Serialize, Deserialize)]
264pub struct Fork {
265    pub fid: i32,
266    pub name: String,
267    #[serde(rename = "parentFid")]
268    pub parent_fid: i32,
269    #[serde(rename = "parentName")]
270    pub parent_name: String,
271    #[serde(rename = "snapshotTs")]
272    pub snapshot_ts: i64,
273    #[serde(rename = "createdBy", skip_serializing_if = "Option::is_none")]
274    pub created_by: Option<i64>,
275    #[serde(rename = "createdAt")]
276    pub created_at: i64,
277    #[serde(rename = "childrenCount")]
278    pub children_count: i32,
279    #[serde(skip_serializing_if = "Option::is_none")]
280    pub inactive: Option<bool>,
281    #[serde(rename = "inactiveAt", skip_serializing_if = "Option::is_none")]
282    pub inactive_at: Option<i64>,
283    pub status: String,
284    pub size: i64,
285}
286
287#[derive(Debug, Clone, Serialize, Deserialize)]
288pub struct ForkTreeEntry {
289    pub inode: i64,
290    pub name: String,
291    pub kind: String,
292    pub size: i64,
293    pub mtime: i64,
294    pub ctime: i64,
295    #[serde(rename = "creatorId", skip_serializing_if = "Option::is_none")]
296    pub creator_id: Option<i64>,
297    #[serde(rename = "updaterId", skip_serializing_if = "Option::is_none")]
298    pub updater_id: Option<i64>,
299}
300
301#[derive(Debug, Clone, Serialize, Deserialize)]
302pub struct ForkEntryDetail {
303    pub inode: i64,
304    pub path: String,
305    pub name: String,
306    pub kind: String,
307    pub size: i64,
308    pub mtime: i64,
309    pub ctime: i64,
310    pub generation: i64,
311    #[serde(skip_serializing_if = "Option::is_none")]
312    pub owner: Option<String>,
313    #[serde(skip_serializing_if = "Option::is_none")]
314    pub mode: Option<i32>,
315    #[serde(skip_serializing_if = "Option::is_none")]
316    pub xattrs: Option<serde_json::Value>,
317    #[serde(rename = "creatorId", skip_serializing_if = "Option::is_none")]
318    pub creator_id: Option<i64>,
319    #[serde(rename = "updaterId", skip_serializing_if = "Option::is_none")]
320    pub updater_id: Option<i64>,
321}
322
323#[derive(Debug, Clone, Serialize, Deserialize)]
324pub struct ForkEntryVersion {
325    pub generation: i64,
326    pub size: i64,
327    pub mtime: i64,
328    #[serde(rename = "updaterId", skip_serializing_if = "Option::is_none")]
329    pub updater_id: Option<i64>,
330    #[serde(rename = "contentHash", skip_serializing_if = "Option::is_none")]
331    pub content_hash: Option<String>,
332}
333
334#[derive(Debug, Clone, Serialize, Deserialize)]
335pub struct ForkTreeMatch {
336    pub path: String,
337    pub inode: i64,
338    pub kind: String,
339    pub size: i64,
340    pub mtime: i64,
341}
342
343#[derive(Debug, Clone, Serialize, Deserialize)]
344pub struct AuditLog {
345    pub id: i64,
346    pub title: String,
347    #[serde(skip_serializing_if = "Option::is_none")]
348    pub description: Option<String>,
349    #[serde(skip_serializing_if = "Option::is_none")]
350    pub subject: Option<String>,
351    pub success: bool,
352    #[serde(skip_serializing_if = "Option::is_none")]
353    pub data: Option<serde_json::Value>,
354    #[serde(rename = "createdBy", skip_serializing_if = "Option::is_none")]
355    pub created_by: Option<String>,
356    #[serde(skip_serializing_if = "Option::is_none")]
357    pub node: Option<String>,
358    #[serde(rename = "accountId", skip_serializing_if = "Option::is_none")]
359    pub account_id: Option<i64>,
360    #[serde(rename = "regionId", skip_serializing_if = "Option::is_none")]
361    pub region_id: Option<i64>,
362    #[serde(rename = "regionClusterId", skip_serializing_if = "Option::is_none")]
363    pub region_cluster_id: Option<i64>,
364    #[serde(rename = "createdAt", skip_serializing_if = "Option::is_none")]
365    pub created_at: Option<String>,
366    #[serde(rename = "updatedAt", skip_serializing_if = "Option::is_none")]
367    pub updated_at: Option<String>,
368}
369
370#[derive(Debug, Clone, Serialize, Deserialize)]
371pub struct ServiceNode {
372    pub id: i64,
373    #[serde(rename = "regionId")]
374    pub region_id: i64,
375    #[serde(rename = "regionClusterId", skip_serializing_if = "Option::is_none")]
376    pub region_cluster_id: Option<i64>,
377    #[serde(rename = "serviceType")]
378    pub service_type: String,
379    #[serde(rename = "nodeId")]
380    pub node_id: String,
381    #[serde(rename = "advertiseAddr")]
382    pub advertise_addr: String,
383    #[serde(rename = "rpcAddr", skip_serializing_if = "Option::is_none")]
384    pub rpc_addr: Option<String>,
385    #[serde(skip_serializing_if = "Option::is_none")]
386    pub metadata: Option<serde_json::Value>,
387    pub status: String,
388    #[serde(rename = "lastHeartbeat", skip_serializing_if = "Option::is_none")]
389    pub last_heartbeat: Option<i64>,
390    #[serde(rename = "isActive")]
391    pub is_active: bool,
392    #[serde(rename = "memUsage", skip_serializing_if = "Option::is_none")]
393    pub mem_usage: Option<f64>,
394    #[serde(rename = "sysLoad", skip_serializing_if = "Option::is_none")]
395    pub sys_load: Option<i64>,
396}
397
398#[derive(Debug, Clone, Serialize, Deserialize)]
399pub struct ClientSession {
400    pub id: i64,
401    pub account: Ref,
402    pub region: Ref,
403    #[serde(rename = "regionCluster", skip_serializing_if = "Option::is_none")]
404    pub region_cluster: Option<Ref>,
405    pub volume: VolumeRef,
406    #[serde(skip_serializing_if = "Option::is_none")]
407    pub user: Option<Ref>,
408    #[serde(rename = "clientType")]
409    pub client_type: String,
410    #[serde(rename = "osName")]
411    pub os_name: String,
412    #[serde(rename = "osVersion", skip_serializing_if = "Option::is_none")]
413    pub os_version: Option<String>,
414    #[serde(rename = "appVersion", skip_serializing_if = "Option::is_none")]
415    pub app_version: Option<String>,
416    #[serde(skip_serializing_if = "Option::is_none")]
417    pub hostname: Option<String>,
418    #[serde(rename = "ipAddr")]
419    pub ip_addr: String,
420    #[serde(rename = "mountMode", skip_serializing_if = "Option::is_none")]
421    pub mount_mode: Option<String>,
422    #[serde(rename = "mountPath", skip_serializing_if = "Option::is_none")]
423    pub mount_path: Option<String>,
424    #[serde(rename = "forkName", skip_serializing_if = "Option::is_none")]
425    pub fork_name: Option<String>,
426    #[serde(rename = "isTemporaryFork")]
427    pub is_temporary_fork: bool,
428    #[serde(skip_serializing_if = "Option::is_none")]
429    pub metadata: Option<serde_json::Value>,
430    #[serde(skip_serializing_if = "Option::is_none")]
431    pub metrics: Option<serde_json::Value>,
432    pub status: ClientSessionStatus,
433    #[serde(rename = "lastHeartbeat", skip_serializing_if = "Option::is_none")]
434    pub last_heartbeat: Option<i64>,
435    #[serde(rename = "connectedAt", skip_serializing_if = "Option::is_none")]
436    pub connected_at: Option<i64>,
437    #[serde(rename = "disconnectedAt", skip_serializing_if = "Option::is_none")]
438    pub disconnected_at: Option<i64>,
439    #[serde(rename = "isActive")]
440    pub is_active: bool,
441}
442
443#[derive(Debug, Clone, Serialize, Deserialize)]
444pub struct SessionSummary {
445    #[serde(rename = "byStatus")]
446    pub by_status: Vec<SessionSummaryStatusEntry>,
447    #[serde(rename = "byPlatform")]
448    pub by_platform: Vec<SessionSummaryFacet>,
449    #[serde(rename = "byOsName")]
450    pub by_os_name: Vec<SessionSummaryFacet>,
451    #[serde(rename = "regionCount")]
452    pub region_count: i64,
453    #[serde(rename = "volumeCount")]
454    pub volume_count: i64,
455    #[serde(rename = "hostCount")]
456    pub host_count: i64,
457    #[serde(rename = "unhealthyCount")]
458    pub unhealthy_count: i64,
459}
460
461#[derive(Debug, Clone, Serialize, Deserialize)]
462pub struct DiscoverMetaResponse {
463    #[serde(rename = "regionId")]
464    pub region_id: i64,
465    pub region: String,
466    pub endpoints: Vec<DiscoverEndpoint>,
467}
468
469#[derive(Debug, Clone, Serialize, Deserialize)]
470pub struct DashboardStats {
471    #[serde(rename = "userCount")]
472    pub user_count: i64,
473    #[serde(rename = "volumeCount")]
474    pub volume_count: i64,
475    #[serde(rename = "regionCount")]
476    pub region_count: i64,
477    #[serde(rename = "storageCount")]
478    pub storage_count: i64,
479    #[serde(rename = "totalVolumeUsed")]
480    pub total_volume_used: i64,
481    #[serde(rename = "totalQuotaLimit")]
482    pub total_quota_limit: i64,
483    #[serde(rename = "activeSessionCount")]
484    pub active_session_count: i64,
485    #[serde(rename = "regionBreakdown")]
486    pub region_breakdown: Vec<RegionVolumeMetrics>,
487}
488
489#[derive(Debug, Clone, Serialize, Deserialize)]
490pub struct LicenseDetails {
491    #[serde(rename = "licenseId")]
492    pub license_id: String,
493    pub licensee: String,
494    pub contact: String,
495    #[serde(rename = "licenseType")]
496    pub license_type: String,
497    #[serde(rename = "issuedAt")]
498    pub issued_at: String,
499    #[serde(rename = "expiresAt")]
500    pub expires_at: String,
501    #[serde(rename = "gracePeriodDays")]
502    pub grace_period_days: i64,
503    #[serde(rename = "expiredAccessDays")]
504    pub expired_access_days: i64,
505    #[serde(rename = "maxNodes")]
506    pub max_nodes: i64,
507    #[serde(rename = "maxVolumes")]
508    pub max_volumes: i64,
509    #[serde(rename = "maxUsers")]
510    pub max_users: i64,
511    #[serde(rename = "maxAccounts")]
512    pub max_accounts: i64,
513    #[serde(rename = "maxRegions")]
514    pub max_regions: i64,
515    #[serde(rename = "maxStorageBytes")]
516    pub max_storage_bytes: i64,
517    pub status: LicenseStatus,
518    #[serde(rename = "daysRemaining")]
519    pub days_remaining: i64,
520    #[serde(rename = "graceEndsAt")]
521    pub grace_ends_at: String,
522    #[serde(rename = "graceDaysLeft")]
523    pub grace_days_left: i64,
524    #[serde(rename = "expiredAccessEndsAt")]
525    pub expired_access_ends_at: String,
526    #[serde(rename = "expiredAccessDaysLeft")]
527    pub expired_access_days_left: i64,
528    pub quota: LicenseQuota,
529}
530
531#[derive(Debug, Clone, Serialize, Deserialize)]
532pub struct LicenseTerms {
533    pub terms: String,
534}
535
536#[derive(Debug, Clone, Serialize, Deserialize)]
537pub struct ServiceAlert {
538    pub id: i64,
539    #[serde(rename = "alertId")]
540    pub alert_id: String,
541    pub source: String,
542    #[serde(rename = "nodeId")]
543    pub node_id: String,
544    pub severity: i64,
545    pub category: String,
546    pub title: String,
547    #[serde(skip_serializing_if = "Option::is_none")]
548    pub description: Option<String>,
549    #[serde(skip_serializing_if = "Option::is_none")]
550    pub region: Option<Ref>,
551    #[serde(skip_serializing_if = "Option::is_none")]
552    pub account: Option<Ref>,
553    #[serde(rename = "eventTime")]
554    pub event_time: String,
555    #[serde(rename = "resolvedAt", skip_serializing_if = "Option::is_none")]
556    pub resolved_at: Option<String>,
557    #[serde(rename = "createdAt", skip_serializing_if = "Option::is_none")]
558    pub created_at: Option<String>,
559}
560
561#[derive(Debug, Clone, Serialize, Deserialize)]
562pub struct AlertCountResponse {
563    pub active: i64,
564    pub recent: i64,
565    #[serde(rename = "infoCount")]
566    pub info_count: i64,
567    #[serde(rename = "warningCount")]
568    pub warning_count: i64,
569    #[serde(rename = "criticalCount")]
570    pub critical_count: i64,
571}
572
573#[derive(Debug, Clone, Serialize, Deserialize)]
574pub struct RegionAlert {
575    pub id: i64,
576    #[serde(rename = "alertId")]
577    pub alert_id: String,
578    pub source: String,
579    #[serde(rename = "nodeId")]
580    pub node_id: String,
581    #[serde(rename = "regionClusterId", skip_serializing_if = "Option::is_none")]
582    pub region_cluster_id: Option<i64>,
583    pub severity: i64,
584    pub category: String,
585    pub title: String,
586    #[serde(skip_serializing_if = "Option::is_none")]
587    pub description: Option<String>,
588    #[serde(rename = "eventTime")]
589    pub event_time: String,
590    #[serde(rename = "resolvedAt", skip_serializing_if = "Option::is_none")]
591    pub resolved_at: Option<String>,
592    #[serde(rename = "createdAt", skip_serializing_if = "Option::is_none")]
593    pub created_at: Option<String>,
594}
595
596#[derive(Debug, Clone, Serialize, Deserialize)]
597pub struct BlockMember {
598    #[serde(skip_serializing_if = "Option::is_none")]
599    pub name: Option<String>,
600    #[serde(rename = "regionClusterId")]
601    pub region_cluster_id: i64,
602}
603
604#[derive(Debug, Clone, Serialize, Deserialize)]
605pub struct DashboardUser {
606    pub id: String,
607    pub name: String,
608    #[serde(skip_serializing_if = "Option::is_none")]
609    pub email: Option<String>,
610    pub role: String,
611    #[serde(skip_serializing_if = "Option::is_none")]
612    pub username: Option<String>,
613    #[serde(rename = "accountId", skip_serializing_if = "Option::is_none")]
614    pub account_id: Option<i64>,
615    #[serde(rename = "userId", skip_serializing_if = "Option::is_none")]
616    pub user_id: Option<i64>,
617    #[serde(rename = "volumeId", skip_serializing_if = "Option::is_none")]
618    pub volume_id: Option<i64>,
619    #[serde(skip_serializing_if = "Option::is_none")]
620    pub exp: Option<i64>,
621}
622
623#[derive(Debug, Clone, Serialize, Deserialize)]
624pub struct DiscoverEndpoint {
625    #[serde(rename = "nodeId")]
626    pub node_id: String,
627    pub addr: String,
628    pub status: String,
629}
630
631#[derive(Debug, Clone, Serialize, Deserialize)]
632pub struct LicenseQuota {
633    pub state: LicenseQuotaState,
634    #[serde(rename = "liveVolume")]
635    pub live_volume: i64,
636    #[serde(rename = "totalVolume")]
637    pub total_volume: i64,
638    pub generation: i64,
639    #[serde(rename = "lastTransitionAtMs")]
640    pub last_transition_at_ms: i64,
641}
642
643#[derive(Debug, Clone, Serialize, Deserialize)]
644pub struct Ref {
645    pub id: i64,
646    pub name: String,
647}
648
649#[derive(Debug, Clone, Serialize, Deserialize)]
650pub struct RegionVolumeMetrics {
651    #[serde(rename = "regionId")]
652    pub region_id: i64,
653    #[serde(rename = "regionName")]
654    pub region_name: String,
655    #[serde(rename = "volumeCount")]
656    pub volume_count: i64,
657    #[serde(rename = "totalVolumeUsed")]
658    pub total_volume_used: i64,
659    #[serde(rename = "totalQuotaLimit")]
660    pub total_quota_limit: i64,
661}
662
663#[derive(Debug, Clone, Serialize, Deserialize)]
664pub struct SessionSummaryFacet {
665    pub label: String,
666    pub count: i64,
667}
668
669#[derive(Debug, Clone, Serialize, Deserialize)]
670pub struct SessionSummaryStatusEntry {
671    #[serde(rename = "clientType")]
672    pub client_type: String,
673    pub status: String,
674    pub count: i64,
675}
676
677#[derive(Debug, Clone, Serialize, Deserialize)]
678pub struct UserLite {
679    pub id: i64,
680    pub username: String,
681    pub name: String,
682}
683
684#[derive(Debug, Clone, Serialize, Deserialize)]
685pub struct VolumeRef {
686    pub id: i64,
687    pub name: String,
688    #[serde(skip_serializing_if = "Option::is_none")]
689    pub r#type: Option<String>,
690}
691
692#[derive(Debug, Clone, Serialize, Deserialize)]
693pub struct VolumeSizePoint {
694    #[serde(rename = "bucketEnd")]
695    pub bucket_end: String,
696    #[serde(rename = "liveVolume")]
697    pub live_volume: i64,
698    #[serde(rename = "totalVolume")]
699    pub total_volume: i64,
700    #[serde(rename = "pendingVolume")]
701    pub pending_volume: i64,
702    #[serde(rename = "liveInactiveVolume")]
703    pub live_inactive_volume: i64,
704}
705
706// Accounts
707
708#[derive(Debug, Clone, Serialize)]
709pub struct CreateAccountRequest {
710    pub name: String,
711    #[serde(skip_serializing_if = "Option::is_none")]
712    pub description: Option<String>,
713    #[serde(rename = "iconUrl", skip_serializing_if = "Option::is_none")]
714    pub icon_url: Option<String>,
715    #[serde(rename = "providerInfo", skip_serializing_if = "Option::is_none")]
716    pub provider_info: Option<serde_json::Value>,
717}
718
719#[derive(Debug, Clone, Serialize)]
720pub struct EditAccountRequest {
721    pub name: String,
722    #[serde(skip_serializing_if = "Option::is_none")]
723    pub description: Option<String>,
724    #[serde(rename = "iconUrl", skip_serializing_if = "Option::is_none")]
725    pub icon_url: Option<String>,
726    #[serde(rename = "providerInfo", skip_serializing_if = "Option::is_none")]
727    pub provider_info: Option<serde_json::Value>,
728}
729
730#[derive(Debug, Clone, Serialize)]
731pub struct UpdateAccountQuotaRequest {
732    #[serde(rename = "quotaLimit")]
733    pub quota_limit: i64,
734    #[serde(rename = "quotaExcessPct", skip_serializing_if = "Option::is_none")]
735    pub quota_excess_pct: Option<i32>,
736}
737
738#[derive(Debug, Clone, Default)]
739pub struct AccountListOptions {
740    pub is_active: Option<bool>,
741    pub page: Option<i64>,
742    pub limit: Option<i64>,
743}
744
745// Users
746
747#[derive(Debug, Clone, Serialize)]
748pub struct AddUserRequest {
749    #[serde(rename = "accountId")]
750    pub account_id: i64,
751    pub username: String,
752    pub email: String,
753    #[serde(skip_serializing_if = "Option::is_none")]
754    pub name: Option<String>,
755    #[serde(rename = "providerInfo", skip_serializing_if = "Option::is_none")]
756    pub provider_info: Option<serde_json::Value>,
757}
758
759#[derive(Debug, Clone, Serialize)]
760pub struct BulkUserRequest {
761    pub ids: Vec<i64>,
762}
763
764#[derive(Debug, Clone, Serialize, Deserialize)]
765pub struct BulkUserResponse {
766    pub users: Vec<UserLite>,
767}
768
769#[derive(Debug, Clone, Serialize)]
770pub struct EditUserRequest {
771    pub username: String,
772    pub email: String,
773    #[serde(skip_serializing_if = "Option::is_none")]
774    pub name: Option<String>,
775    #[serde(rename = "providerInfo", skip_serializing_if = "Option::is_none")]
776    pub provider_info: Option<serde_json::Value>,
777}
778
779#[derive(Debug, Clone, Default)]
780pub struct UserListOptions {
781    pub account_id: i64,
782    pub search: Option<String>,
783    pub is_active: Option<bool>,
784    pub page: Option<i64>,
785    pub limit: Option<i64>,
786}
787
788// Regions
789
790#[derive(Debug, Clone, Serialize)]
791pub struct CreateRegionRequest {
792    #[serde(rename = "accountId")]
793    pub account_id: i64,
794    pub name: String,
795    pub dns: String,
796}
797
798#[derive(Debug, Clone, Serialize)]
799pub struct EditRegionRequest {
800    #[serde(rename = "accountId")]
801    pub account_id: i64,
802    pub name: String,
803    pub dns: String,
804}
805
806#[derive(Debug, Clone, Default)]
807pub struct RegionListOptions {
808    pub account_id: i64,
809    pub is_active: Option<bool>,
810    pub page: Option<i64>,
811    pub limit: Option<i64>,
812}
813
814// Clusters
815
816#[derive(Debug, Clone, Default)]
817pub struct ClusterListOptions {
818    pub account_id: i64,
819    pub region_id: Option<i64>,
820    pub is_active: Option<bool>,
821    pub page: Option<i64>,
822    pub limit: Option<i64>,
823}
824
825// RegionClusters
826
827#[derive(Debug, Clone, Serialize)]
828pub struct CreateRegionClusterRequest {
829    pub name: String,
830}
831
832#[derive(Debug, Clone, Serialize)]
833pub struct EditRegionClusterRequest {
834    pub name: String,
835}
836
837#[derive(Debug, Clone, Serialize)]
838pub struct SetRegionClusterReadyRequest {
839    pub ready: bool,
840}
841
842#[derive(Debug, Clone, Serialize, Deserialize)]
843pub struct SetReadyRegionClusterResponse {
844    pub id: i64,
845    pub ready: bool,
846}
847
848#[derive(Debug, Clone, Default)]
849pub struct RegionClusterListOptions {
850    pub is_active: Option<bool>,
851    pub page: Option<i64>,
852    pub limit: Option<i64>,
853}
854
855// Storages
856
857#[derive(Debug, Clone, Serialize)]
858pub struct CreateStorageRequest {
859    #[serde(rename = "accountId")]
860    pub account_id: i64,
861    #[serde(rename = "regionId")]
862    pub region_id: i64,
863    pub name: String,
864    #[serde(skip_serializing_if = "Option::is_none")]
865    pub description: Option<String>,
866    #[serde(rename = "storageType")]
867    pub storage_type: String,
868    #[serde(rename = "providerType")]
869    pub provider_type: String,
870    pub endpoint: String,
871    #[serde(skip_serializing_if = "Option::is_none")]
872    pub region: Option<String>,
873    #[serde(skip_serializing_if = "Option::is_none")]
874    pub bucket: Option<String>,
875    #[serde(skip_serializing_if = "Option::is_none")]
876    pub base: Option<String>,
877    #[serde(rename = "blockRegion", skip_serializing_if = "Option::is_none")]
878    pub block_region: Option<String>,
879    #[serde(rename = "blockSize", skip_serializing_if = "Option::is_none")]
880    pub block_size: Option<i32>,
881    #[serde(skip_serializing_if = "Option::is_none")]
882    pub members: Option<Vec<BlockMember>>,
883    #[serde(rename = "accessKey", skip_serializing_if = "Option::is_none")]
884    pub access_key: Option<String>,
885    #[serde(rename = "secretKey", skip_serializing_if = "Option::is_none")]
886    pub secret_key: Option<String>,
887}
888
889#[derive(Debug, Clone, Serialize, Deserialize)]
890pub struct CreateStorageResponse {
891    pub id: i64,
892    #[serde(rename = "blockVolumeIds", skip_serializing_if = "Option::is_none")]
893    pub block_volume_ids: Option<Vec<String>>,
894}
895
896#[derive(Debug, Clone, Serialize)]
897pub struct EditStorageRequest {
898    pub name: String,
899    #[serde(skip_serializing_if = "Option::is_none")]
900    pub description: Option<String>,
901    #[serde(skip_serializing_if = "Option::is_none")]
902    pub endpoint: Option<String>,
903    #[serde(rename = "accessKey", skip_serializing_if = "Option::is_none")]
904    pub access_key: Option<String>,
905    #[serde(rename = "secretKey", skip_serializing_if = "Option::is_none")]
906    pub secret_key: Option<String>,
907}
908
909#[derive(Debug, Clone, Serialize)]
910pub struct TestStorageBucketRequest {
911    pub endpoint: String,
912    #[serde(skip_serializing_if = "Option::is_none")]
913    pub region: Option<String>,
914    pub bucket: String,
915    #[serde(rename = "accessKey")]
916    pub access_key: String,
917    #[serde(rename = "secretKey")]
918    pub secret_key: String,
919    #[serde(rename = "providerType", skip_serializing_if = "Option::is_none")]
920    pub provider_type: Option<String>,
921}
922
923#[derive(Debug, Clone, Serialize, Deserialize)]
924pub struct TestBucketStorageResponse {
925    #[serde(rename = "bucketExists")]
926    pub bucket_exists: bool,
927    pub list: bool,
928    pub write: bool,
929    pub read: bool,
930    pub delete: bool,
931    pub multipart: bool,
932}
933
934#[derive(Debug, Clone, Serialize, Deserialize)]
935pub struct TestStorageBucketStorageResponse {
936    #[serde(rename = "bucketExists")]
937    pub bucket_exists: bool,
938    pub list: bool,
939    pub write: bool,
940    pub read: bool,
941    pub delete: bool,
942    pub multipart: bool,
943}
944
945#[derive(Debug, Clone, Default)]
946pub struct StorageListOptions {
947    pub account_id: i64,
948    pub search: Option<String>,
949    pub region_id: Option<i64>,
950    pub storage_type: Option<String>,
951    pub provider_type: Option<String>,
952    pub is_active: Option<bool>,
953    pub page: Option<i64>,
954    pub limit: Option<i64>,
955}
956
957// Volumes
958
959#[derive(Debug, Clone, Serialize)]
960pub struct CreateVolumeRequest {
961    #[serde(rename = "accountId")]
962    pub account_id: i64,
963    #[serde(rename = "storageId")]
964    pub storage_id: i64,
965    pub name: String,
966    #[serde(skip_serializing_if = "Option::is_none")]
967    pub description: Option<String>,
968    #[serde(rename = "volumeType")]
969    pub volume_type: String,
970    #[serde(skip_serializing_if = "Option::is_none")]
971    pub encryption: Option<bool>,
972    #[serde(rename = "encryptionKey", skip_serializing_if = "Option::is_none")]
973    pub encryption_key: Option<String>,
974    #[serde(rename = "retentionPeriod", skip_serializing_if = "Option::is_none")]
975    pub retention_period: Option<i32>,
976    #[serde(rename = "gracePeriod", skip_serializing_if = "Option::is_none")]
977    pub grace_period: Option<i32>,
978    #[serde(rename = "forkGracePeriod", skip_serializing_if = "Option::is_none")]
979    pub fork_grace_period: Option<i32>,
980    #[serde(rename = "eventLogRetentionPeriod", skip_serializing_if = "Option::is_none")]
981    pub event_log_retention_period: Option<i32>,
982    #[serde(rename = "quotaLimit", skip_serializing_if = "Option::is_none")]
983    pub quota_limit: Option<i64>,
984    #[serde(rename = "regionClusterId", skip_serializing_if = "Option::is_none")]
985    pub region_cluster_id: Option<i64>,
986    #[serde(rename = "regionClusterUuid", skip_serializing_if = "Option::is_none")]
987    pub region_cluster_uuid: Option<String>,
988}
989
990#[derive(Debug, Clone, Serialize, Deserialize)]
991pub struct CreateVolumeResponse {
992    pub id: i64,
993    #[serde(rename = "encryptionKey", skip_serializing_if = "Option::is_none")]
994    pub encryption_key: Option<String>,
995}
996
997#[derive(Debug, Clone, Serialize)]
998pub struct EditVolumeRequest {
999    #[serde(skip_serializing_if = "Option::is_none")]
1000    pub description: Option<String>,
1001    #[serde(rename = "retentionPeriod", skip_serializing_if = "Option::is_none")]
1002    pub retention_period: Option<i32>,
1003    #[serde(rename = "gracePeriod", skip_serializing_if = "Option::is_none")]
1004    pub grace_period: Option<i32>,
1005    #[serde(rename = "forkGracePeriod", skip_serializing_if = "Option::is_none")]
1006    pub fork_grace_period: Option<i32>,
1007    #[serde(rename = "eventLogRetentionPeriod", skip_serializing_if = "Option::is_none")]
1008    pub event_log_retention_period: Option<i32>,
1009}
1010
1011#[derive(Debug, Clone, Serialize)]
1012pub struct MoveVolumeClusterRequest {
1013    #[serde(rename = "targetClusterId", skip_serializing_if = "Option::is_none")]
1014    pub target_cluster_id: Option<i64>,
1015    #[serde(rename = "targetClusterUuid", skip_serializing_if = "Option::is_none")]
1016    pub target_cluster_uuid: Option<String>,
1017}
1018
1019#[derive(Debug, Clone, Serialize, Deserialize)]
1020pub struct MoveClusterVolumeResponse {
1021    pub id: i64,
1022    #[serde(rename = "sourceClusterId")]
1023    pub source_cluster_id: i64,
1024    #[serde(rename = "targetClusterId")]
1025    pub target_cluster_id: i64,
1026    #[serde(rename = "handoverUntil")]
1027    pub handover_until: i64,
1028}
1029
1030#[derive(Debug, Clone, Serialize)]
1031pub struct DeactivateVolumeRequest {
1032    #[serde(rename = "isCleanupMetaEnabled", skip_serializing_if = "Option::is_none")]
1033    pub is_cleanup_meta_enabled: Option<bool>,
1034    #[serde(rename = "isCleanupStorageEnabled", skip_serializing_if = "Option::is_none")]
1035    pub is_cleanup_storage_enabled: Option<bool>,
1036    #[serde(rename = "isCleanupVaultEnabled", skip_serializing_if = "Option::is_none")]
1037    pub is_cleanup_vault_enabled: Option<bool>,
1038}
1039
1040#[derive(Debug, Clone, Serialize)]
1041pub struct GenerateVolumeAPIKeysRequest {
1042    #[serde(rename = "userId")]
1043    pub user_id: i64,
1044}
1045
1046#[derive(Debug, Clone, Serialize, Deserialize)]
1047pub struct GenerateAPIKeysVolumeResponse {
1048    #[serde(rename = "apiKey")]
1049    pub api_key: String,
1050    #[serde(rename = "apiSecret")]
1051    pub api_secret: String,
1052}
1053
1054#[derive(Debug, Clone, Serialize)]
1055pub struct RevokeVolumeAPIKeyRequest {
1056    #[serde(rename = "apiKey")]
1057    pub api_key: String,
1058}
1059
1060#[derive(Debug, Clone, Serialize)]
1061pub struct RevokeVolumeAPIKeysByUserRequest {
1062    #[serde(rename = "userId")]
1063    pub user_id: i64,
1064}
1065
1066#[derive(Debug, Clone, Serialize)]
1067pub struct UpdateVolumeQuotaRequest {
1068    #[serde(rename = "quotaLimit")]
1069    pub quota_limit: i64,
1070}
1071
1072#[derive(Debug, Clone, Serialize, Deserialize)]
1073pub struct StatsVolumeResponse {
1074    #[serde(rename = "volumeId")]
1075    pub volume_id: String,
1076    #[serde(rename = "liveVolume")]
1077    pub live_volume: i64,
1078    #[serde(rename = "totalVolume")]
1079    pub total_volume: i64,
1080    #[serde(rename = "pendingVolume")]
1081    pub pending_volume: i64,
1082    #[serde(rename = "liveInactiveVolume")]
1083    pub live_inactive_volume: i64,
1084}
1085
1086#[derive(Debug, Clone, Serialize, Deserialize)]
1087pub struct SizeHistoryVolumeResponse {
1088    pub points: Vec<VolumeSizePoint>,
1089}
1090
1091#[derive(Debug, Clone, Serialize)]
1092pub struct CreateVolumeForkRequest {
1093    pub name: String,
1094    #[serde(rename = "parentName", skip_serializing_if = "Option::is_none")]
1095    pub parent_name: Option<String>,
1096    #[serde(rename = "asOf", skip_serializing_if = "Option::is_none")]
1097    pub as_of: Option<i64>,
1098    #[serde(rename = "volumeType", skip_serializing_if = "Option::is_none")]
1099    pub volume_type: Option<String>,
1100}
1101
1102#[derive(Debug, Clone, Serialize)]
1103pub struct DeleteVolumeForkRequest {
1104    #[serde(skip_serializing_if = "Option::is_none")]
1105    pub force: Option<bool>,
1106    #[serde(rename = "volumeType", skip_serializing_if = "Option::is_none")]
1107    pub volume_type: Option<String>,
1108}
1109
1110#[derive(Debug, Clone, Serialize, Deserialize)]
1111pub struct DeleteForkVolumeResponse {
1112    #[serde(rename = "inactivatedFids")]
1113    pub inactivated_fids: Vec<i32>,
1114}
1115
1116#[derive(Debug, Clone, Serialize)]
1117pub struct RestoreVolumeForkRequest {
1118    #[serde(rename = "volumeType", skip_serializing_if = "Option::is_none")]
1119    pub volume_type: Option<String>,
1120}
1121
1122#[derive(Debug, Clone, Default)]
1123pub struct VolumeListOptions {
1124    pub account_id: i64,
1125    pub region_id: Option<i64>,
1126    pub region_cluster_id: Option<i64>,
1127    pub storage_id: Option<i64>,
1128    pub volume_type: Option<String>,
1129    pub locked: Option<bool>,
1130    pub is_active: Option<bool>,
1131    pub page: Option<i64>,
1132    pub limit: Option<i64>,
1133}
1134
1135// VolumeForkTrees
1136
1137#[derive(Debug, Clone, Default)]
1138pub struct VolumeForkTreeListOptions {
1139    pub path: Option<String>,
1140    pub as_of: Option<i64>,
1141    pub cursor: Option<i64>,
1142    pub limit: Option<i64>,
1143    pub sort: Option<String>,
1144    pub kind: Option<String>,
1145}
1146
1147// VolumeForkEntries
1148
1149#[derive(Debug, Clone, Default)]
1150pub struct VolumeForkEntryListOptions {
1151    pub path: Option<String>,
1152    pub cursor: Option<i64>,
1153    pub limit: Option<i64>,
1154}
1155
1156// VolumeForkSearches
1157
1158#[derive(Debug, Clone, Default)]
1159pub struct VolumeForkSearchListOptions {
1160    pub q: Option<String>,
1161    pub path: Option<String>,
1162    pub as_of: Option<i64>,
1163    pub exact: Option<bool>,
1164    pub cursor: Option<i64>,
1165    pub limit: Option<i64>,
1166    pub kind: Option<String>,
1167}
1168
1169// AuditLogs
1170
1171#[derive(Debug, Clone, Default)]
1172pub struct AuditLogListOptions {
1173    pub account_id: i64,
1174    pub region_id: Option<i64>,
1175    pub region_cluster_id: Option<i64>,
1176    pub cursor: Option<i64>,
1177    pub limit: Option<i64>,
1178    pub subject: Option<String>,
1179}
1180
1181// RegionAuditLogs
1182
1183#[derive(Debug, Clone, Default)]
1184pub struct RegionAuditLogListOptions {
1185    pub region_cluster_id: Option<i64>,
1186    pub cursor: Option<i64>,
1187    pub limit: Option<i64>,
1188    pub subject: Option<String>,
1189    pub node: Option<String>,
1190}
1191
1192// ServiceNodes
1193
1194// Nodes
1195
1196// ClientSessions
1197
1198#[derive(Debug, Clone, Default)]
1199pub struct ClientSessionListOptions {
1200    pub account_id: i64,
1201    pub region_id: Option<i64>,
1202    pub region_cluster_id: Option<i64>,
1203    pub volume_id: Option<i64>,
1204    pub user_id: Option<i64>,
1205    pub client_type: Option<String>,
1206    pub status: Option<ClientSessionStatus>,
1207    pub is_active: Option<String>,
1208    pub os_name: Option<String>,
1209    pub platform: Option<String>,
1210    pub search: Option<String>,
1211    pub page: Option<i64>,
1212    pub limit: Option<i64>,
1213}
1214
1215// Discover
1216
1217// Dashboard
1218
1219// License
1220
1221// Alerts
1222
1223#[derive(Debug, Clone, Default)]
1224pub struct AlertListOptions {
1225    pub active: Option<bool>,
1226    pub account_id: Option<i64>,
1227    pub region_id: Option<i64>,
1228    pub severity: Option<i64>,
1229    pub category: Option<String>,
1230    pub since: Option<String>,
1231    pub page: Option<i64>,
1232    pub limit: Option<i64>,
1233}
1234
1235// RegionAlerts
1236
1237#[derive(Debug, Clone, Default)]
1238pub struct RegionAlertListOptions {
1239    pub active: Option<bool>,
1240    pub severity: Option<i64>,
1241    pub category: Option<String>,
1242    pub node_id: Option<String>,
1243    pub region_cluster_id: Option<i64>,
1244    pub since: Option<String>,
1245    pub page: Option<i64>,
1246    pub limit: Option<i64>,
1247}
1248
1249// Vault