From f9969d32cec437df4305c8d1f7156cc30313c1aa Mon Sep 17 00:00:00 2001 From: "rongfu.leng" Date: Wed, 29 May 2024 15:58:49 +0800 Subject: [PATCH] add uid/gid mappings to mount Signed-off-by: rongfu.leng --- src/runtime/miscellaneous.rs | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/src/runtime/miscellaneous.rs b/src/runtime/miscellaneous.rs index 73a9a7f399..547af99d6a 100644 --- a/src/runtime/miscellaneous.rs +++ b/src/runtime/miscellaneous.rs @@ -3,6 +3,7 @@ use derive_builder::Builder; use getset::{CopyGetters, Getters, MutGetters, Setters}; use serde::{Deserialize, Serialize}; use std::path::PathBuf; +use crate::runtime::LinuxIdMapping; #[derive( Builder, Clone, CopyGetters, Debug, Deserialize, Eq, Getters, Setters, PartialEq, Serialize, @@ -76,6 +77,15 @@ pub struct Mount { #[serde(default, skip_serializing_if = "Option::is_none")] /// Options are fstab style mount options. options: Option>, + + + #[serde(default, skip_serializing_if = "Option::is_none")] + /// UID mappings used for changing file owners w/o calling chown, fs should support it. Every mount point could have its own mapping. + uid_mappings: Option>, + + #[serde(default, skip_serializing_if = "Option::is_none")] + /// GID mappings used for changing file owners w/o calling chown, fs should support it. Every mount point could have its own mapping. + gid_mappings: Option>, } /// utility function to generate default config for mounts. @@ -86,6 +96,8 @@ pub fn get_default_mounts() -> Vec { typ: "proc".to_string().into(), source: PathBuf::from("proc").into(), options: None, + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/dev"), @@ -98,6 +110,8 @@ pub fn get_default_mounts() -> Vec { "size=65536k".into(), ] .into(), + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/dev/pts"), @@ -112,6 +126,8 @@ pub fn get_default_mounts() -> Vec { "gid=5".into(), ] .into(), + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/dev/shm"), @@ -125,12 +141,16 @@ pub fn get_default_mounts() -> Vec { "size=65536k".into(), ] .into(), + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/dev/mqueue"), typ: "mqueue".to_string().into(), source: PathBuf::from("mqueue").into(), options: vec!["nosuid".into(), "noexec".into(), "nodev".into()].into(), + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/sys"), @@ -143,6 +163,8 @@ pub fn get_default_mounts() -> Vec { "ro".into(), ] .into(), + uid_mappings: None, + gid_mappings: None, }, Mount { destination: PathBuf::from("/sys/fs/cgroup"), @@ -156,6 +178,8 @@ pub fn get_default_mounts() -> Vec { "ro".into(), ] .into(), + uid_mappings: None, + gid_mappings: None, }, ] }