diff options
| author | Jiri Moskovcak <jmoskovc@redhat.com> | 2011-03-14 18:10:41 +0100 |
|---|---|---|
| committer | Jiri Moskovcak <jmoskovc@redhat.com> | 2011-03-14 18:10:41 +0100 |
| commit | 73cc48d58dd43bd54d0c00f2fb6b5441bb250dcf (patch) | |
| tree | fc5ff9c77878ced3eae716b8fab2e6e2434bdefe /src/daemon | |
| parent | 3763e47fe054d46e5b217b4c0704930b3707ffcd (diff) | |
| parent | cbe3dd9930e68140ca8aeb17e4fb20fce09981df (diff) | |
| download | abrt-73cc48d58dd43bd54d0c00f2fb6b5441bb250dcf.tar.gz abrt-73cc48d58dd43bd54d0c00f2fb6b5441bb250dcf.tar.xz abrt-73cc48d58dd43bd54d0c00f2fb6b5441bb250dcf.zip | |
Merge branch 'master' of ssh://git.fedorahosted.org/git/abrt
Diffstat (limited to 'src/daemon')
| -rw-r--r-- | src/daemon/MiddleWare.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/daemon/MiddleWare.cpp b/src/daemon/MiddleWare.cpp index 8d62c697..84400361 100644 --- a/src/daemon/MiddleWare.cpp +++ b/src/daemon/MiddleWare.cpp @@ -744,6 +744,16 @@ int CreateReportThread(const char* crash_id, long caller_uid, int force, const c /* Remove dump dir */ int DeleteDebugDump(const char *dump_dir_name, long caller_uid) { + /* If doesn't start with "DEBUG_DUMPS_DIR/"... */ + if (strncmp(dump_dir_name, DEBUG_DUMPS_DIR"/", strlen(DEBUG_DUMPS_DIR"/")) != 0 + /* or contains "/." anywhere (-> might contain ".." component) */ + || strstr(dump_dir_name + strlen(DEBUG_DUMPS_DIR), "/.") + ) { + /* Then refuse to operate on it (someone is attacking us??) */ + error_msg("Bad dump directory name '%s', not deleting", dump_dir_name); + return MW_ERROR; + } + struct dump_dir *dd = dd_opendir(dump_dir_name, /*flags:*/ 0); if (!dd) return MW_NOENT_ERROR; @@ -760,7 +770,7 @@ int DeleteDebugDump(const char *dump_dir_name, long caller_uid) if (!string_to_bool(inform_all)) { dd_close(dd); - error_msg("crash '%s' can't be accessed by user with uid %ld", dump_dir_name, caller_uid); + error_msg("Dump directory '%s' can't be accessed by user with uid %ld", dump_dir_name, caller_uid); return 1; } } |
