diff options
author | Ryo Nakamura <upa@haeena.net> | 2023-08-04 15:06:14 +0900 |
---|---|---|
committer | Ryo Nakamura <upa@haeena.net> | 2023-08-04 15:06:14 +0900 |
commit | 24c1bc9149eb8f1c383eaf16d94636b62d07c152 (patch) | |
tree | 54dd5823cb8255a493a851e4ecec74aeae675370 /src/path.c | |
parent | 16f2f88cc91ffa2421393b077611d55d6cd2b771 (diff) |
do not set O_TRUNC when opening destination file.
It prevents `mscp localhost:hoge ~/hoge` from truncating the source
file. See https://bugzilla.mindrot.org/show_bug.cgi?id=3431.
https://github.com/upa/mscp/issues/1
Diffstat (limited to 'src/path.c')
-rw-r--r-- | src/path.c | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -334,8 +334,9 @@ static int touch_dst_path(struct path *p, sftp_session sftp) *needle = '/'; } - /* open file with O_TRUNC to set file size 0 */ - f = mscp_open(p->dst_path, O_WRONLY|O_CREAT|O_TRUNC, S_IRUSR|S_IWUSR, sftp); + /* Do not set O_TRUNC here. Instead, do mscp_setstat() at the + * end. see https://bugzilla.mindrot.org/show_bug.cgi?id=3431 */ + f = mscp_open(p->dst_path, O_WRONLY|O_CREAT, S_IRUSR|S_IWUSR, sftp); if (!f) { mscp_set_error("mscp_open %s: %s\n", p->dst_path, strerrno()); return -1; @@ -574,7 +575,9 @@ int copy_chunk(FILE *msg_fp, struct chunk *c, if (refcnt_dec(&c->p->refcnt) == 0) { c->p->state = FILE_STATE_DONE; - mscp_chmod(c->p->dst_path, c->p->mode, dst_sftp); + if (mscp_setstat(c->p->dst_path, c->p->mode, c->p->size, dst_sftp) < 0) + mpr_err(msg_fp, "failed to chmod and truncate %s: %s\n", + c->p->path, strerrno()); mpr_info(msg_fp, "copy done: %s\n", c->p->path); } |