diff options
author | Stefan Metzmacher <metze@samba.org> | 2006-05-20 17:06:28 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:08:14 -0500 |
commit | c2c5f78f11e026d56f09a9142906d3921539204f (patch) | |
tree | d2923b5175757e9a23aff7fef2638039f181a1c0 /source4/smb_server/smb2/fileio.c | |
parent | 6af051409a0a1bcda9e2673bab1652690ab88fea (diff) | |
download | samba-c2c5f78f11e026d56f09a9142906d3921539204f.tar.gz samba-c2c5f78f11e026d56f09a9142906d3921539204f.tar.bz2 samba-c2c5f78f11e026d56f09a9142906d3921539204f.zip |
r15753: implement SMB2 Create
metze
(This used to be commit 65b67a8af6b661fe6eeabf45563c6aba12a6660a)
Diffstat (limited to 'source4/smb_server/smb2/fileio.c')
-rw-r--r-- | source4/smb_server/smb2/fileio.c | 54 |
1 files changed, 53 insertions, 1 deletions
diff --git a/source4/smb_server/smb2/fileio.c b/source4/smb_server/smb2/fileio.c index b9f36fdc7a..778dd584ed 100644 --- a/source4/smb_server/smb2/fileio.c +++ b/source4/smb_server/smb2/fileio.c @@ -20,11 +20,63 @@ #include "includes.h" #include "libcli/smb2/smb2.h" +#include "libcli/smb2/smb2_calls.h" +#include "smb_server/smb_server.h" +#include "smb_server/service_smb_proto.h" #include "smb_server/smb2/smb2_server.h" +#include "ntvfs/ntvfs.h" + +static void smb2srv_create_send(struct ntvfs_request *ntvfs) +{ + struct smb2srv_request *req; + union smb_open *io; + + SMB2SRV_CHECK_ASYNC_STATUS(io, union smb_open); + SMB2SRV_CHECK(smb2srv_setup_reply(req, 0x58, True, io->smb2.out.blob.length)); + + SSVAL(req->out.body, 0x02, io->smb2.out.oplock_flags); + SIVAL(req->out.body, 0x04, io->smb2.out.create_action); + SBVAL(req->out.body, 0x08, io->smb2.out.create_time); + SBVAL(req->out.body, 0x10, io->smb2.out.access_time); + SBVAL(req->out.body, 0x18, io->smb2.out.write_time); + SBVAL(req->out.body, 0x20, io->smb2.out.change_time); + SBVAL(req->out.body, 0x28, io->smb2.out.alloc_size); + SBVAL(req->out.body, 0x30, io->smb2.out.size); + SIVAL(req->out.body, 0x38, io->smb2.out.file_attr); + SIVAL(req->out.body, 0x3C, io->smb2.out._pad); + smb2srv_push_handle(req->out.body, 0x40,io->smb2.out.file.ntvfs); + SMB2SRV_CHECK(smb2_push_o16s16_blob(&req->out, 0x50, io->smb2.out.blob)); + + smb2srv_send_reply(req); +} void smb2srv_create_recv(struct smb2srv_request *req) { - smb2srv_send_error(req, NT_STATUS_NOT_IMPLEMENTED); + union smb_open *io; + DATA_BLOB blob; + + SMB2SRV_CHECK_BODY_SIZE(req, 0x38, True); + SMB2SRV_TALLOC_IO_PTR(io, union smb_open); + SMB2SRV_SETUP_NTVFS_REQUEST(smb2srv_create_send, NTVFS_ASYNC_STATE_MAY_ASYNC); + + io->smb2.level = RAW_OPEN_SMB2; + io->smb2.in.oplock_flags = SVAL(req->in.body, 0x02); + io->smb2.in.impersonation = IVAL(req->in.body, 0x04); + io->smb2.in.unknown3[0] = IVAL(req->in.body, 0x08); + io->smb2.in.unknown3[1] = IVAL(req->in.body, 0x0C); + io->smb2.in.unknown3[2] = IVAL(req->in.body, 0x10); + io->smb2.in.unknown3[3] = IVAL(req->in.body, 0x14); + io->smb2.in.access_mask = IVAL(req->in.body, 0x18); + io->smb2.in.file_attr = IVAL(req->in.body, 0x1C); + io->smb2.in.share_access = IVAL(req->in.body, 0x20); + io->smb2.in.open_disposition = IVAL(req->in.body, 0x24); + io->smb2.in.create_options = IVAL(req->in.body, 0x28); + SMB2SRV_CHECK(smb2_pull_o16s16_string(&req->in, io, req->in.body+0x2C, &io->smb2.in.fname)); + SMB2SRV_CHECK(smb2_pull_o32s32_blob(&req->in, io, req->in.body+0x30, &blob)); + /* TODO: parse the blob */ + ZERO_STRUCT(io->smb2.in.eas); + + SMB2SRV_CALL_NTVFS_BACKEND(ntvfs_open(req->ntvfs, io)); } void smb2srv_close_recv(struct smb2srv_request *req) |