Ticket #4535 (closed enhancement: fixed)
Temporary directory name conflicts when runnig inside containers with shared /tmp
Reported by: | eugenesan | Owned by: | andrew_b |
---|---|---|---|
Priority: | major | Milestone: | 4.8.32 |
Component: | mc-core | Version: | master |
Keywords: | Cc: | ||
Blocked By: | Blocking: | ||
Branch state: | merged | Votes for changeset: | committed-master |
Description
When running inside Distrobox container temporary directory name conflicts with mc instance running on the host machine which has different permissions:
root@ubuntu:~# mc Directory /tmp/mc-root is not owned by you Temporary files will be created in /tmp Press any key to continue...
Trivial fix I came up with is to add process ID to the directory name.
Also, that might be useful when running multiple instances on the host.
Please find the fix attached to the tocket
Attachments
Change History
Changed 4 months ago by eugenesan
- Attachment mc-tmp-pid.patch added
comment:1 Changed 4 months ago by andrew_b
- Owner set to andrew_b
- Status changed from new to accepted
- Branch state changed from no branch to on review
- Milestone changed from Future Releases to 4.8.32
Branch: 4535_tmpdir_name
changeset:ebf86c2debb8430e49057572083aa12e883bb54f
comment:2 follow-up: ↓ 3 Changed 4 months ago by zaytsev
Hi Andrew, I'm not sure what was the original reasoning behind making the directories per-user, but now that you're going into the direction of making them unique (per process), isn't it much better to use the POSIX mkdtemp API (or rather get_tmp_dir from glib) and remove all our strange black magic altogether? There was already CVE-2004-0231 in the past due to homegrown adventurous handling of temporary directories...
comment:3 in reply to: ↑ 2 Changed 4 months ago by andrew_b
Replying to zaytsev:
isn't it much better to use the POSIX mkdtemp API
Probably yes.
(or rather get_tmp_dir from glib)
g_get_tmp_dir uses $TMPDIR. mc tries to use $MC_TMPDIR if it's set and $TMPDIR otherwise.
comment:5 follow-up: ↓ 6 Changed 4 months ago by zaytsev
g_get_tmp_dir uses $TMPDIR. mc tries to use $MC_TMPDIR if it's set and $TMPDIR otherwise.
Well, there seems to be another more flexible API: g_dir_make_tmp - maybe you could use that instead.
comment:6 in reply to: ↑ 5 Changed 4 months ago by andrew_b
Replying to zaytsev:
g_get_tmp_dir uses $TMPDIR. mc tries to use $MC_TMPDIR if it's set and $TMPDIR otherwise.
Well, there seems to be another more flexible API: g_dir_make_tmp - maybe you could use that instead.
It doesn't help us: g_dir_make_tmp calls g_get_tmp_dir.
I think we should keep the $MC_TMPDIR usage, so we have to write a code for temporary directory name. Something like
g_snprintf (buffer, sizeof (buffer), "%s/mc-XXXXXX", sys_tmp); tmpdir = g_mkdtemp (buffer); if (tmpdir != NULL) g_setenv ("MC_TMPDIR", tmpdir, TRUE);
comment:10 Changed 4 months ago by zaytsev
- Votes for changeset set to zyv
- Branch state changed from on review to approved
comment:11 Changed 4 months ago by andrew_b
- Status changed from accepted to testing
- Votes for changeset changed from zyv to committed-master
- Resolution set to fixed
- Branch state changed from approved to merged
Merged to master: [794823b885b63439ab8c2ce5bc4436855c603834].
comment:12 Changed 4 months ago by andrew_b
- Status changed from testing to closed
A typo in the commit message: s/drirectory/directory/ :-(
Add process ID to the temporary directory name