diff options
Diffstat (limited to 'hosts/vidhar')
| -rwxr-xr-x | hosts/vidhar/borg/copy.py | 17 | 
1 files changed, 9 insertions, 8 deletions
| diff --git a/hosts/vidhar/borg/copy.py b/hosts/vidhar/borg/copy.py index 8cfcbd56..de62dfa5 100755 --- a/hosts/vidhar/borg/copy.py +++ b/hosts/vidhar/borg/copy.py | |||
| @@ -110,14 +110,15 @@ def copy_archive(src_repo_path, dst_repo_path, entry): | |||
| 110 | gid_map.write(f'0 {gid} 1') | 110 | gid_map.write(f'0 {gid} 1') | 
| 111 | subprocess.run(['mount', '--make-rprivate', '/'], check=True) | 111 | subprocess.run(['mount', '--make-rprivate', '/'], check=True) | 
| 112 | chroot = pathlib.Path(tmpdir) / 'chroot' | 112 | chroot = pathlib.Path(tmpdir) / 'chroot' | 
| 113 | upper = pathlib.Path(tmpdir) / 'upper' | 113 | chroot.mkdir() | 
| 114 | work = pathlib.Path(tmpdir) / 'work' | 114 | # upper = pathlib.Path(tmpdir) / 'upper' | 
| 115 | for path in [chroot,upper,work]: | 115 | # work = pathlib.Path(tmpdir) / 'work' | 
| 116 | path.mkdir() | 116 | # for path in [chroot,upper,work]: | 
| 117 | print(f'euid={os.getuid()}', file=stderr) | 117 | # path.mkdir() | 
| 118 | subprocess.run(['stat', '/', upper, work, chroot], check=True) | 118 | # print(f'euid={os.getuid()}', file=stderr) | 
| 119 | subprocess.run(['mount', '-t', 'overlay', 'overlay', '-o', f'lowerdir=/,upperdir={upper},workdir={work}', chroot], check=True) | 119 | # subprocess.run(['stat', '/', upper, work, chroot], check=True) | 
| 120 | bindMounts = ['nix', 'run', 'proc', 'dev', 'sys', pathlib.Path(os.path.expanduser('~')).relative_to('/')] | 120 | # subprocess.run(['mount', '-t', 'overlay', 'overlay', '-o', f'lowerdir=/,upperdir={upper},workdir={work}', chroot], check=True) | 
| 121 | bindMounts = ['etc', 'nix', 'run', 'proc', 'dev', 'sys', pathlib.Path(os.path.expanduser('~')).relative_to('/')] | ||
| 121 | if not ":" in src_repo_path: | 122 | if not ":" in src_repo_path: | 
| 122 | bindMounts.append(pathlib.Path(src_repo_path).relative_to('/')) | 123 | bindMounts.append(pathlib.Path(src_repo_path).relative_to('/')) | 
| 123 | if 'SSH_AUTH_SOCK' in os.environ: | 124 | if 'SSH_AUTH_SOCK' in os.environ: | 
