1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/openeuler-stratovirt

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
В этом репозитории не указан файл с открытой лицензией (LICENSE). При использовании обратитесь к конкретному описанию проекта и его зависимостям в коде.
Клонировать/Скачать
vnc.rs 5.3 КБ
Копировать Редактировать Исходные данные Просмотреть построчно История
MJY-HUST Отправлено 3 лет назад 8a3011b
// Copyright (c) 2022 Huawei Technologies Co.,Ltd. All rights reserved.
//
// StratoVirt is licensed under Mulan PSL v2.
// You can use this software according to the terms and conditions of the Mulan
// PSL v2.
// You may obtain a copy of Mulan PSL v2 at:
// http://license.coscl.org.cn/MulanPSL2
// THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY
// KIND, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
// NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
// See the Mulan PSL v2 for more details.
use serde::{Deserialize, Serialize};
use crate::config::ConfigError;
use crate::config::{CmdParser, VmConfig};
use anyhow::{anyhow, Result};
use std::net::Ipv4Addr;
/// Configuration of vnc.
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct VncConfig {
/// Listening ip.
pub ip: String,
/// Listening port.
pub port: String,
/// Configuration of encryption.
pub tls_creds: String,
/// Authentication switch.
pub sasl: bool,
/// Configuration of authentication.
pub sasl_authz: String,
}
const VNC_MAX_PORT_NUM: i32 = 65535;
const VNC_PORT_OFFSET: i32 = 5900;
impl VmConfig {
/// Make configuration for vnc: "chardev" -> "vnc".
pub fn add_vnc(&mut self, vnc_config: &str) -> Result<()> {
let mut cmd_parser = CmdParser::new("vnc");
cmd_parser
.push("")
.push("tls-creds")
.push("sasl")
.push("sasl-authz");
cmd_parser.parse(vnc_config)?;
let mut vnc_config = VncConfig::default();
// Parse Ip:Port.
if let Some(addr) = cmd_parser.get_value::<String>("")? {
if let Err(e) = parse_port(&mut vnc_config, addr) {
return Err(e);
}
} else {
return Err(anyhow!(ConfigError::FieldIsMissing("ip", "port")));
}
// VNC Security Type.
if let Some(tls_creds) = cmd_parser.get_value::<String>("tls-creds")? {
vnc_config.tls_creds = tls_creds
}
if let Some(_sasl) = cmd_parser.get_value::<String>("sasl")? {
vnc_config.sasl = true
} else {
vnc_config.sasl = false
}
if let Some(sasl_authz) = cmd_parser.get_value::<String>("sasl-authz")? {
vnc_config.sasl_authz = sasl_authz;
}
self.vnc = Some(vnc_config);
Ok(())
}
}
/// Parse Ip:port.
fn parse_port(vnc_config: &mut VncConfig, addr: String) -> Result<()> {
let v: Vec<&str> = addr.split(':').collect();
if v.len() != 2 {
return Err(anyhow!(ConfigError::FieldIsMissing("ip", "port")));
}
let ip = v[0]
.parse::<Ipv4Addr>()
.map_err(|_| anyhow!("Invalid Ip param for vnc!"))?;
let base_port = v[1]
.parse::<i32>()
.map_err(|_| anyhow!("Invalid Port param for vnc!"))?;
// Prevent the base_port out of bounds.
if !(0..=VNC_MAX_PORT_NUM - VNC_PORT_OFFSET).contains(&base_port) {
return Err(anyhow!(ConfigError::InvalidParam(
base_port.to_string(),
"port".to_string()
)));
}
vnc_config.ip = ip.to_string();
vnc_config.port = ((base_port + VNC_PORT_OFFSET) as u16).to_string();
Ok(())
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_add_vnc() {
let mut vm_config = VmConfig::default();
let config_line = "0.0.0.0:1,tls-creds=vnc-tls-creds0,sasl,sasl-authz=authz0";
assert!(vm_config.add_vnc(config_line).is_ok());
let vnc_config = vm_config.vnc.unwrap();
assert_eq!(vnc_config.ip, String::from("0.0.0.0"));
assert_eq!(vnc_config.port, String::from("5901"));
assert_eq!(vnc_config.tls_creds, String::from("vnc-tls-creds0"));
assert_eq!(vnc_config.sasl, true);
assert_eq!(vnc_config.sasl_authz, String::from("authz0"));
let mut vm_config = VmConfig::default();
let config_line = "0.0.0.0:5900,tls-creds=vnc-tls-creds0";
assert!(vm_config.add_vnc(config_line).is_ok());
let vnc_config = vm_config.vnc.unwrap();
assert_eq!(vnc_config.sasl, false);
assert_eq!(vnc_config.port, String::from("11800"));
let mut vm_config = VmConfig::default();
let config_line = "0.0.0.0:1,sasl,sasl-authz=authz0";
assert!(vm_config.add_vnc(config_line).is_ok());
let vnc_config = vm_config.vnc.unwrap();
assert_eq!(vnc_config.tls_creds, "".to_string());
// Invalie format of ip:port.
let config_lines = [
"tls-creds=vnc-tls-creds0", // No ip:port.
"127.0.0.1", // No port.
"1", // No ip.
"0.0.0.0:65536", // Invalid port.
"0.0.0.0:59636", // Invalid port.
"0.0.0.0:2147483647", // Invalie port.
"0.0.0.0:-1", // Invalid port.
"0.0.0.0:123ab", // Invalid port.
"127.257.0.1:0", // Invalid ip.
"127.0.0.0.1:0", // Invalid ip.
"127.12ab.0.1:0", // Invalid ip.
"127.0.1:0", // Invalid ip.
];
for config_line in config_lines {
let mut vm_config = VmConfig::default();
assert!(vm_config.add_vnc(config_line).is_err());
}
}
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/openeuler-stratovirt.git
git@gitlife.ru:oschina-mirror/openeuler-stratovirt.git
oschina-mirror
openeuler-stratovirt
openeuler-stratovirt
v2.2.0-rc6