From 461000c8812a99a81a9f3fc87f93c1b7c67f42bd Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Thu, 18 Aug 2016 14:02:24 -0700 Subject: [PATCH] s3: libsmb: Plumb in additional_flags2 = FLAGS2_REPARSE_PATH to cli_getatr_send(). BUG: https://bugzilla.samba.org/show_bug.cgi?id=12165 Signed-off-by: Jeremy Allison Reviewed-by: Uri Simchoni --- source3/libsmb/clifile.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/source3/libsmb/clifile.c b/source3/libsmb/clifile.c index 593cdea78c8..cfe8856cd74 100644 --- a/source3/libsmb/clifile.c +++ b/source3/libsmb/clifile.c @@ -3743,6 +3743,7 @@ struct tevent_req *cli_getatr_send(TALLOC_CTX *mem_ctx, struct tevent_req *req = NULL, *subreq = NULL; struct cli_getatr_state *state = NULL; uint8_t additional_flags = 0; + uint16_t additional_flags2 = 0; uint8_t *bytes = NULL; req = tevent_req_create(mem_ctx, &state, struct cli_getatr_state); @@ -3764,8 +3765,13 @@ struct tevent_req *cli_getatr_send(TALLOC_CTX *mem_ctx, return tevent_req_post(req, ev); } - subreq = cli_smb_send(state, ev, cli, SMBgetatr, additional_flags, 0, - 0, NULL, talloc_get_size(bytes), bytes); + if (clistr_is_previous_version_path(fname)) { + additional_flags2 = FLAGS2_REPARSE_PATH; + } + + subreq = cli_smb_send(state, ev, cli, SMBgetatr, additional_flags, + additional_flags2, + 0, NULL, talloc_get_size(bytes), bytes); if (tevent_req_nomem(subreq, req)) { return tevent_req_post(req, ev); }