diff options
Diffstat (limited to 'source3')
-rw-r--r-- | source3/smbd/smb2_close.c | 90 |
1 files changed, 71 insertions, 19 deletions
diff --git a/source3/smbd/smb2_close.c b/source3/smbd/smb2_close.c index 2cc8266fe1..04c80dee17 100644 --- a/source3/smbd/smb2_close.c +++ b/source3/smbd/smb2_close.c @@ -26,7 +26,14 @@ static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, uint16_t in_flags, uint64_t in_file_id_volatile, - DATA_BLOB *outbody); + uint16_t *out_flags, + NTTIME *out_creation_time, + NTTIME *out_last_access_time, + NTTIME *out_last_write_time, + NTTIME *out_change_time, + uint64_t *out_allocation_size, + uint64_t *out_end_of_file, + uint32_t *out_file_attributes); NTSTATUS smbd_smb2_request_process_close(struct smbd_smb2_request *req) { @@ -36,6 +43,14 @@ NTSTATUS smbd_smb2_request_process_close(struct smbd_smb2_request *req) uint16_t in_flags; uint64_t in_file_id_persistent; uint64_t in_file_id_volatile; + uint16_t out_flags; + NTTIME out_creation_time; + NTTIME out_last_access_time; + NTTIME out_last_write_time; + NTTIME out_change_time; + uint64_t out_allocation_size; + uint64_t out_end_of_file; + uint32_t out_file_attributes; NTSTATUS status; status = smbd_smb2_request_verify_sizes(req, 0x18); @@ -62,18 +77,43 @@ NTSTATUS smbd_smb2_request_process_close(struct smbd_smb2_request *req) status = smbd_smb2_close(req, in_flags, in_file_id_volatile, - &outbody); + &out_flags, + &out_creation_time, + &out_last_access_time, + &out_last_write_time, + &out_change_time, + &out_allocation_size, + &out_end_of_file, + &out_file_attributes); if (!NT_STATUS_IS_OK(status)) { return smbd_smb2_request_error(req, status); } + SSVAL(outbody.data, 0x00, 0x3C); /* struct size */ + SSVAL(outbody.data, 0x02, out_flags); + SIVAL(outbody.data, 0x04, 0); /* reserved */ + SBVAL(outbody.data, 0x08, out_creation_time); + SBVAL(outbody.data, 0x10, out_last_access_time); + SBVAL(outbody.data, 0x18, out_last_write_time); + SBVAL(outbody.data, 0x20, out_change_time); + SBVAL(outbody.data, 0x28, out_allocation_size); + SBVAL(outbody.data, 0x30, out_end_of_file); + SIVAL(outbody.data, 0x38, out_file_attributes); + return smbd_smb2_request_done(req, outbody, NULL); } static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, uint16_t in_flags, uint64_t in_file_id_volatile, - DATA_BLOB *outbody) + uint16_t *out_flags, + NTTIME *out_creation_time, + NTTIME *out_last_access_time, + NTTIME *out_last_write_time, + NTTIME *out_change_time, + uint64_t *out_allocation_size, + uint64_t *out_end_of_file, + uint32_t *out_file_attributes) { NTSTATUS status; struct smb_request *smbreq; @@ -84,7 +124,7 @@ static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, uint64_t allocation_size = 0; uint64_t file_size = 0; uint32_t dos_attrs = 0; - uint16_t out_flags = 0; + uint16_t flags = 0; bool posix_open = false; ZERO_STRUCT(create_date_ts); @@ -92,6 +132,15 @@ static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, ZERO_STRUCT(mdate_ts); ZERO_STRUCT(cdate_ts); + *out_flags = 0; + *out_creation_time = 0; + *out_last_access_time = 0; + *out_last_write_time = 0; + *out_change_time = 0; + *out_allocation_size = 0; + *out_end_of_file = 0; + *out_file_attributes = 0; + DEBUG(10,("smbd_smb2_close: file_id[0x%016llX]\n", (unsigned long long)in_file_id_volatile)); @@ -134,7 +183,7 @@ static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, ret = SMB_VFS_STAT(conn, smb_fname); } if (ret == 0) { - out_flags = SMB2_CLOSE_FLAGS_FULL_INFORMATION; + flags = SMB2_CLOSE_FLAGS_FULL_INFORMATION; dos_attrs = dos_mode(conn, smb_fname); mdate_ts = smb_fname->st.st_ex_mtime; adate_ts = smb_fname->st.st_ex_atime; @@ -155,20 +204,23 @@ static NTSTATUS smbd_smb2_close(struct smbd_smb2_request *req, } } - SSVAL(outbody->data, 0x00, 0x3C); /* struct size */ - SSVAL(outbody->data, 0x02, out_flags); /* flags */ - SIVAL(outbody->data, 0x04, 0); /* reserved */ - put_long_date_timespec(conn->ts_res, - (char *)&outbody->data[0x8],create_date_ts); /* creation time */ - put_long_date_timespec(conn->ts_res, - (char *)&outbody->data[0x10],adate_ts); /* last access time */ - put_long_date_timespec(conn->ts_res, - (char *)&outbody->data[0x18],mdate_ts); /* last write time */ - put_long_date_timespec(conn->ts_res, - (char *)&outbody->data[0x20],cdate_ts); /* change time */ - SBVAL(outbody->data, 0x28, allocation_size);/* allocation size */ - SBVAL(outbody->data, 0x30, file_size); /* end of file */ - SIVAL(outbody->data, 0x38, dos_attrs); /* file attributes */ + *out_flags = flags; + + round_timespec(conn->ts_res, &create_date_ts); + unix_timespec_to_nt_time(out_creation_time, create_date_ts); + + round_timespec(conn->ts_res, &adate_ts); + unix_timespec_to_nt_time(out_last_access_time, adate_ts); + + round_timespec(conn->ts_res, &mdate_ts); + unix_timespec_to_nt_time(out_last_write_time, mdate_ts); + + round_timespec(conn->ts_res, &cdate_ts); + unix_timespec_to_nt_time(out_change_time, cdate_ts); + + *out_allocation_size = allocation_size; + *out_end_of_file = file_size; + *out_file_attributes = dos_attrs; return NT_STATUS_OK; } |