Skip to main content

proxmox_api/generated/nodes/node/lxc/vmid/
remote_migrate.rs

1#[derive(Debug, Clone)]
2pub struct RemoteMigrateClient<T> {
3    client: T,
4    path: String,
5}
6impl<T> RemoteMigrateClient<T>
7where
8    T: crate::client::Client,
9{
10    pub fn new(client: T, parent_path: &str) -> Self {
11        Self {
12            client,
13            path: format!("{}{}", parent_path, "/remote_migrate"),
14        }
15    }
16}
17impl<T> RemoteMigrateClient<T>
18where
19    T: crate::client::Client,
20{
21    #[doc = "Migrate the container to another cluster. Creates a new migration task. EXPERIMENTAL feature!"]
22    #[doc = ""]
23    #[doc = "Permission check: perm(\"/vms/{vmid}\", [\"VM.Migrate\"])"]
24    pub async fn post(&self, params: PostParams) -> Result<String, T::Error> {
25        let path = self.path.to_string();
26        self.client.post(&path, &params).await
27    }
28}
29impl PostParams {
30    pub fn new(target_bridge: String, target_endpoint: String, target_storage: String) -> Self {
31        Self {
32            target_bridge,
33            target_endpoint,
34            target_storage,
35            bwlimit: ::std::default::Default::default(),
36            delete: ::std::default::Default::default(),
37            online: ::std::default::Default::default(),
38            restart: ::std::default::Default::default(),
39            target_vmid: ::std::default::Default::default(),
40            timeout: ::std::default::Default::default(),
41            additional_properties: ::std::default::Default::default(),
42        }
43    }
44}
45#[derive(Clone, Debug, :: serde :: Serialize, :: serde :: Deserialize)]
46pub struct PostParams {
47    #[serde(skip_serializing_if = "Option::is_none", default)]
48    #[doc = "Override I/O bandwidth limit (in KiB/s)."]
49    #[doc = ""]
50    pub bwlimit: Option<BwlimitNum>,
51    #[serde(
52        serialize_with = "crate::types::serialize_bool_optional",
53        deserialize_with = "crate::types::deserialize_bool_optional"
54    )]
55    #[serde(skip_serializing_if = "Option::is_none", default)]
56    #[doc = "Delete the original CT and related data after successful migration. By default the original CT is kept on the source cluster in a stopped state."]
57    #[doc = ""]
58    pub delete: Option<bool>,
59    #[serde(
60        serialize_with = "crate::types::serialize_bool_optional",
61        deserialize_with = "crate::types::deserialize_bool_optional"
62    )]
63    #[serde(skip_serializing_if = "Option::is_none", default)]
64    #[doc = "Use online/live migration."]
65    #[doc = ""]
66    pub online: Option<bool>,
67    #[serde(
68        serialize_with = "crate::types::serialize_bool_optional",
69        deserialize_with = "crate::types::deserialize_bool_optional"
70    )]
71    #[serde(skip_serializing_if = "Option::is_none", default)]
72    #[doc = "Use restart migration"]
73    #[doc = ""]
74    pub restart: Option<bool>,
75    #[serde(rename = "target-bridge")]
76    #[doc = "Mapping from source to target bridges. Providing only a single bridge ID maps all source bridges to that bridge. Providing the special value '1' will map each source bridge to itself."]
77    #[doc = ""]
78    pub target_bridge: String,
79    #[serde(rename = "target-endpoint")]
80    #[doc = "Remote target endpoint"]
81    #[doc = ""]
82    pub target_endpoint: String,
83    #[serde(rename = "target-storage")]
84    #[doc = "Mapping from source to target storages. Providing only a single storage ID maps all source storages to that storage. Providing the special value '1' will map each source storage to itself."]
85    #[doc = ""]
86    pub target_storage: String,
87    #[serde(rename = "target-vmid")]
88    #[serde(skip_serializing_if = "Option::is_none", default)]
89    #[doc = "The (unique) ID of the VM."]
90    #[doc = ""]
91    pub target_vmid: Option<TargetVmidInt>,
92    #[serde(skip_serializing_if = "Option::is_none", default)]
93    #[doc = "Timeout in seconds for shutdown for restart migration"]
94    #[doc = ""]
95    pub timeout: Option<TimeoutInt>,
96    #[serde(
97        flatten,
98        default,
99        skip_serializing_if = "::std::collections::HashMap::is_empty"
100    )]
101    pub additional_properties: ::std::collections::HashMap<String, ::serde_json::Value>,
102}
103#[derive(Debug, Clone, Copy, PartialEq, PartialOrd)]
104pub struct TargetVmidInt(i128);
105impl crate::types::bounded_integer::BoundedInteger for TargetVmidInt {
106    const MIN: Option<i128> = Some(100i128);
107    const MAX: Option<i128> = Some(999999999i128);
108    const DEFAULT: Option<i128> = None::<i128>;
109    const TYPE_DESCRIPTION: &'static str = "an integer between 100 and 999999999";
110    fn get(&self) -> i128 {
111        self.0
112    }
113    fn new(value: i128) -> Result<Self, crate::types::bounded_integer::BoundedIntegerError> {
114        Self::validate(value)?;
115        Ok(Self(value))
116    }
117}
118impl std::convert::TryFrom<i128> for TargetVmidInt {
119    type Error = crate::types::bounded_integer::BoundedIntegerError;
120    fn try_from(value: i128) -> Result<Self, Self::Error> {
121        crate::types::bounded_integer::BoundedInteger::new(value)
122    }
123}
124impl ::serde::Serialize for TargetVmidInt {
125    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
126    where
127        S: ::serde::Serializer,
128    {
129        crate::types::bounded_integer::serialize_bounded_integer(self, serializer)
130    }
131}
132impl<'de> ::serde::Deserialize<'de> for TargetVmidInt {
133    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
134    where
135        D: ::serde::Deserializer<'de>,
136    {
137        crate::types::bounded_integer::deserialize_bounded_integer(deserializer)
138    }
139}
140#[derive(Debug, Clone, Copy, PartialEq, PartialOrd)]
141pub struct TimeoutInt(i128);
142impl crate::types::bounded_integer::BoundedInteger for TimeoutInt {
143    const MIN: Option<i128> = None::<i128>;
144    const MAX: Option<i128> = None::<i128>;
145    const DEFAULT: Option<i128> = Some(180i128);
146    const TYPE_DESCRIPTION: &'static str = "a valid integer";
147    fn get(&self) -> i128 {
148        self.0
149    }
150    fn new(value: i128) -> Result<Self, crate::types::bounded_integer::BoundedIntegerError> {
151        Self::validate(value)?;
152        Ok(Self(value))
153    }
154}
155impl std::convert::TryFrom<i128> for TimeoutInt {
156    type Error = crate::types::bounded_integer::BoundedIntegerError;
157    fn try_from(value: i128) -> Result<Self, Self::Error> {
158        crate::types::bounded_integer::BoundedInteger::new(value)
159    }
160}
161impl ::serde::Serialize for TimeoutInt {
162    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
163    where
164        S: ::serde::Serializer,
165    {
166        crate::types::bounded_integer::serialize_bounded_integer(self, serializer)
167    }
168}
169impl<'de> ::serde::Deserialize<'de> for TimeoutInt {
170    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
171    where
172        D: ::serde::Deserializer<'de>,
173    {
174        crate::types::bounded_integer::deserialize_bounded_integer(deserializer)
175    }
176}
177#[derive(Debug, Clone, Copy, PartialEq, PartialOrd)]
178pub struct BwlimitNum(f64);
179impl crate::types::bounded_number::BoundedNumber for BwlimitNum {
180    const MIN: Option<f64> = Some(0f64);
181    const MAX: Option<f64> = None::<f64>;
182    const DEFAULT: Option<f64> = None::<f64>;
183    const TYPE_DESCRIPTION: &'static str = "an number greater than or equal to 0";
184    fn get(&self) -> f64 {
185        self.0
186    }
187    fn new(value: f64) -> Result<Self, crate::types::bounded_number::BoundedNumberError> {
188        Self::validate(value)?;
189        Ok(Self(value))
190    }
191}
192impl std::convert::TryFrom<f64> for BwlimitNum {
193    type Error = crate::types::bounded_number::BoundedNumberError;
194    fn try_from(value: f64) -> Result<Self, Self::Error> {
195        crate::types::bounded_number::BoundedNumber::new(value)
196    }
197}
198impl std::convert::TryFrom<f32> for BwlimitNum {
199    type Error = crate::types::bounded_number::BoundedNumberError;
200    fn try_from(value: f32) -> Result<Self, Self::Error> {
201        crate::types::bounded_number::BoundedNumber::new(value as f64)
202    }
203}
204impl std::convert::TryFrom<i32> for BwlimitNum {
205    type Error = crate::types::bounded_number::BoundedNumberError;
206    fn try_from(value: i32) -> Result<Self, Self::Error> {
207        crate::types::bounded_number::BoundedNumber::new(value as f64)
208    }
209}
210impl std::convert::TryFrom<i64> for BwlimitNum {
211    type Error = crate::types::bounded_number::BoundedNumberError;
212    fn try_from(value: i64) -> Result<Self, Self::Error> {
213        crate::types::bounded_number::BoundedNumber::new(value as f64)
214    }
215}
216impl ::serde::Serialize for BwlimitNum {
217    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
218    where
219        S: ::serde::Serializer,
220    {
221        crate::types::bounded_number::serialize_bounded_number(self, serializer)
222    }
223}
224impl<'de> ::serde::Deserialize<'de> for BwlimitNum {
225    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
226    where
227        D: ::serde::Deserializer<'de>,
228    {
229        crate::types::bounded_number::deserialize_bounded_number(deserializer)
230    }
231}