rawfile.c

来自「samba最新软件」· C语言 代码 · 共 972 行 · 第 1/3 页

C
972
字号
/*    Unix SMB/CIFS implementation.   client file operations   Copyright (C) Andrew Tridgell 1994-1998   Copyright (C) Jeremy Allison 2001-2002   Copyright (C) James Myers 2003      This program is free software; you can redistribute it and/or modify   it under the terms of the GNU General Public License as published by   the Free Software Foundation; either version 3 of the License, or   (at your option) any later version.      This program is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the   GNU General Public License for more details.      You should have received a copy of the GNU General Public License   along with this program.  If not, see <http://www.gnu.org/licenses/>.*/#include "includes.h"#include "smb.h"#include "libcli/raw/libcliraw.h"#include "libcli/raw/raw_proto.h"#include "librpc/gen_ndr/ndr_security.h"#define SETUP_REQUEST(cmd, wct, buflen) do { \	req = smbcli_request_setup(tree, cmd, wct, buflen); \	if (!req) return NULL; \} while (0)/**************************************************************************** Rename a file - async interface****************************************************************************/struct smbcli_request *smb_raw_rename_send(struct smbcli_tree *tree,					union smb_rename *parms){	struct smbcli_request *req = NULL; 	struct smb_nttrans nt;	TALLOC_CTX *mem_ctx;	switch (parms->generic.level) {	case RAW_RENAME_RENAME:		SETUP_REQUEST(SMBmv, 1, 0);		SSVAL(req->out.vwv, VWV(0), parms->rename.in.attrib);		smbcli_req_append_ascii4(req, parms->rename.in.pattern1, STR_TERMINATE);		smbcli_req_append_ascii4(req, parms->rename.in.pattern2, STR_TERMINATE);		break;	case RAW_RENAME_NTRENAME:		SETUP_REQUEST(SMBntrename, 4, 0);		SSVAL(req->out.vwv, VWV(0), parms->ntrename.in.attrib);		SSVAL(req->out.vwv, VWV(1), parms->ntrename.in.flags);		SIVAL(req->out.vwv, VWV(2), parms->ntrename.in.cluster_size);		smbcli_req_append_ascii4(req, parms->ntrename.in.old_name, STR_TERMINATE);		smbcli_req_append_ascii4(req, parms->ntrename.in.new_name, STR_TERMINATE);		break;	case RAW_RENAME_NTTRANS:		mem_ctx = talloc_new(tree);		nt.in.max_setup = 0;		nt.in.max_param = 0;		nt.in.max_data = 0;		nt.in.setup_count = 0;		nt.in.setup = NULL;		nt.in.function = NT_TRANSACT_RENAME;		nt.in.params = data_blob_talloc(mem_ctx, NULL, 4);		nt.in.data = data_blob(NULL, 0);		SSVAL(nt.in.params.data, VWV(0), parms->nttrans.in.file.fnum);		SSVAL(nt.in.params.data, VWV(1), parms->nttrans.in.flags);		smbcli_blob_append_string(tree->session, mem_ctx,					  &nt.in.params, parms->nttrans.in.new_name,					  STR_TERMINATE);		req = smb_raw_nttrans_send(tree, &nt);		talloc_free(mem_ctx);		return req;	}	if (!smbcli_request_send(req)) {		smbcli_request_destroy(req);		return NULL;	}	return req;}/**************************************************************************** Rename a file - sync interface****************************************************************************/_PUBLIC_ NTSTATUS smb_raw_rename(struct smbcli_tree *tree,			union smb_rename *parms){	struct smbcli_request *req = smb_raw_rename_send(tree, parms);	return smbcli_request_simple_recv(req);}/**************************************************************************** Delete a file - async interface****************************************************************************/struct smbcli_request *smb_raw_unlink_send(struct smbcli_tree *tree,					   union smb_unlink *parms){	struct smbcli_request *req; 	SETUP_REQUEST(SMBunlink, 1, 0);	SSVAL(req->out.vwv, VWV(0), parms->unlink.in.attrib);	smbcli_req_append_ascii4(req, parms->unlink.in.pattern, STR_TERMINATE);	if (!smbcli_request_send(req)) {		smbcli_request_destroy(req);		return NULL;	}	return req;}/*  delete a file - sync interface*/_PUBLIC_ NTSTATUS smb_raw_unlink(struct smbcli_tree *tree,			union smb_unlink *parms){	struct smbcli_request *req = smb_raw_unlink_send(tree, parms);	return smbcli_request_simple_recv(req);}/**************************************************************************** create a directory  using TRANSACT2_MKDIR - async interface****************************************************************************/static struct smbcli_request *smb_raw_t2mkdir_send(struct smbcli_tree *tree, 						union smb_mkdir *parms){	struct smb_trans2 t2;	uint16_t setup = TRANSACT2_MKDIR;	TALLOC_CTX *mem_ctx;	struct smbcli_request *req;	uint16_t data_total;	mem_ctx = talloc_init("t2mkdir");	data_total = ea_list_size(parms->t2mkdir.in.num_eas, parms->t2mkdir.in.eas);	t2.in.max_param = 2;	t2.in.max_data = 0;	t2.in.max_setup = 0;	t2.in.flags = 0;	t2.in.timeout = 0;	t2.in.setup_count = 1;	t2.in.setup = &setup;	t2.in.params = data_blob_talloc(mem_ctx, NULL, 4);	t2.in.data = data_blob_talloc(mem_ctx, NULL, data_total);	SIVAL(t2.in.params.data, VWV(0), 0); /* reserved */	smbcli_blob_append_string(tree->session, mem_ctx, 				  &t2.in.params, parms->t2mkdir.in.path, STR_TERMINATE);	ea_put_list(t2.in.data.data, parms->t2mkdir.in.num_eas, parms->t2mkdir.in.eas);	req = smb_raw_trans2_send(tree, &t2);	talloc_free(mem_ctx);	return req;}/**************************************************************************** Create a directory - async interface****************************************************************************/struct smbcli_request *smb_raw_mkdir_send(struct smbcli_tree *tree,				       union smb_mkdir *parms){	struct smbcli_request *req; 	if (parms->generic.level == RAW_MKDIR_T2MKDIR) {		return smb_raw_t2mkdir_send(tree, parms);	}	if (parms->generic.level != RAW_MKDIR_MKDIR) {		return NULL;	}	SETUP_REQUEST(SMBmkdir, 0, 0);		smbcli_req_append_ascii4(req, parms->mkdir.in.path, STR_TERMINATE);	if (!smbcli_request_send(req)) {		return NULL;	}	return req;}/**************************************************************************** Create a directory - sync interface****************************************************************************/_PUBLIC_ NTSTATUS smb_raw_mkdir(struct smbcli_tree *tree,		       union smb_mkdir *parms){	struct smbcli_request *req = smb_raw_mkdir_send(tree, parms);	return smbcli_request_simple_recv(req);}/**************************************************************************** Remove a directory - async interface****************************************************************************/struct smbcli_request *smb_raw_rmdir_send(struct smbcli_tree *tree,				       struct smb_rmdir *parms){	struct smbcli_request *req; 	SETUP_REQUEST(SMBrmdir, 0, 0);		smbcli_req_append_ascii4(req, parms->in.path, STR_TERMINATE);	if (!smbcli_request_send(req)) {		smbcli_request_destroy(req);		return NULL;	}	return req;}/**************************************************************************** Remove a directory - sync interface****************************************************************************/_PUBLIC_ NTSTATUS smb_raw_rmdir(struct smbcli_tree *tree,		       struct smb_rmdir *parms){	struct smbcli_request *req = smb_raw_rmdir_send(tree, parms);	return smbcli_request_simple_recv(req);}/* Open a file using TRANSACT2_OPEN - async recv*/static NTSTATUS smb_raw_nttrans_create_recv(struct smbcli_request *req, 					    TALLOC_CTX *mem_ctx, 					    union smb_open *parms){	NTSTATUS status;	struct smb_nttrans nt;	uint8_t *params;	status = smb_raw_nttrans_recv(req, mem_ctx, &nt);	if (!NT_STATUS_IS_OK(status)) return status;	if (nt.out.params.length < 69) {		return NT_STATUS_INVALID_PARAMETER;	}	params = nt.out.params.data;	parms->ntcreatex.out.oplock_level =                 CVAL(params, 0);	parms->ntcreatex.out.file.fnum =                    SVAL(params, 2);	parms->ntcreatex.out.create_action =                IVAL(params, 4);	parms->ntcreatex.out.create_time =   smbcli_pull_nttime(params, 12);	parms->ntcreatex.out.access_time =   smbcli_pull_nttime(params, 20);	parms->ntcreatex.out.write_time =    smbcli_pull_nttime(params, 28);	parms->ntcreatex.out.change_time =   smbcli_pull_nttime(params, 36);	parms->ntcreatex.out.attrib =                      IVAL(params, 44);	parms->ntcreatex.out.alloc_size =                  BVAL(params, 48);	parms->ntcreatex.out.size =                        BVAL(params, 56);	parms->ntcreatex.out.file_type =                   SVAL(params, 64);	parms->ntcreatex.out.ipc_state =                   SVAL(params, 66);	parms->ntcreatex.out.is_directory =                CVAL(params, 68);		return NT_STATUS_OK;}/* Open a file using NTTRANS CREATE - async send */static struct smbcli_request *smb_raw_nttrans_create_send(struct smbcli_tree *tree, 							  union smb_open *parms){	struct smb_nttrans nt;	uint8_t *params;	TALLOC_CTX *mem_ctx = talloc_new(tree);	uint16_t fname_len;	DATA_BLOB sd_blob, ea_blob;	struct smbcli_request *req;	nt.in.max_setup = 0;	nt.in.max_param = 101;	nt.in.max_data  = 0;	nt.in.setup_count = 0;	nt.in.function = NT_TRANSACT_CREATE;	nt.in.setup = NULL;	sd_blob = data_blob(NULL, 0);	ea_blob = data_blob(NULL, 0);	if (parms->ntcreatex.in.sec_desc) {		enum ndr_err_code ndr_err;		ndr_err = ndr_push_struct_blob(&sd_blob, mem_ctx, NULL,					       parms->ntcreatex.in.sec_desc,					       (ndr_push_flags_fn_t)ndr_push_security_descriptor);		if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {			talloc_free(mem_ctx);			return NULL;		}	}	if (parms->ntcreatex.in.ea_list) {		uint32_t ea_size = ea_list_size_chained(parms->ntcreatex.in.ea_list->num_eas,							parms->ntcreatex.in.ea_list->eas, 4);		ea_blob = data_blob_talloc(mem_ctx, NULL, ea_size);		if (ea_blob.data == NULL) {			return NULL;		}		ea_put_list_chained(ea_blob.data, 				    parms->ntcreatex.in.ea_list->num_eas,				    parms->ntcreatex.in.ea_list->eas, 4);

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?