mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
b4e0c0d38f
Signed-off-by: Bjoern Jacke <bjacke@samba.org> Reviewed-by: Martin Schwenke <martin@meltin.net>
358 lines
15 KiB
C
358 lines
15 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
SMB parameters and setup
|
|
Copyright (C) Andrew Tridgell 2004
|
|
Copyright (C) James Myers 2003 <myersjj@samba.org>
|
|
|
|
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/>.
|
|
*/
|
|
|
|
#ifndef __LIBCLI_H__
|
|
#define __LIBCLI_H__
|
|
|
|
#include "librpc/gen_ndr/nbt.h"
|
|
#include "libcli/raw/libcliraw.h"
|
|
|
|
struct substitute_context;
|
|
|
|
/*
|
|
smbcli_state: internal state used in libcli library for single-threaded callers,
|
|
i.e. a single session on a single socket.
|
|
*/
|
|
struct smbcli_state {
|
|
struct smbcli_options options;
|
|
struct smbcli_socket *sock; /* NULL if connected */
|
|
struct smbcli_transport *transport;
|
|
struct smbcli_session *session;
|
|
struct smbcli_tree *tree;
|
|
struct substitute_context *substitute;
|
|
struct smblsa_state *lsa;
|
|
};
|
|
|
|
struct clilist_file_info {
|
|
uint64_t size;
|
|
uint16_t attrib;
|
|
time_t mtime;
|
|
const char *name;
|
|
const char *short_name;
|
|
};
|
|
|
|
struct nbt_dc_name {
|
|
const char *address;
|
|
const char *name;
|
|
};
|
|
|
|
struct cli_credentials;
|
|
struct tevent_context;
|
|
|
|
/* passed to br lock code. */
|
|
enum brl_type {
|
|
READ_LOCK,
|
|
WRITE_LOCK,
|
|
PENDING_READ_LOCK,
|
|
PENDING_WRITE_LOCK
|
|
};
|
|
|
|
#include "libcli/raw/libcliraw.h"
|
|
struct gensec_settings;
|
|
|
|
ssize_t smbcli_read(struct smbcli_tree *tree, int fnum, void *_buf, off_t offset, size_t size);
|
|
|
|
/****************************************************************************
|
|
write to a file
|
|
write_mode: 0x0001 disallow write caching
|
|
0x0002 return bytes remaining
|
|
0x0004 use raw named pipe protocol
|
|
0x0008 start of message mode named pipe protocol
|
|
****************************************************************************/
|
|
ssize_t smbcli_write(struct smbcli_tree *tree,
|
|
int fnum, uint16_t write_mode,
|
|
const void *_buf, off_t offset, size_t size);
|
|
|
|
/****************************************************************************
|
|
write to a file using a SMBwrite and not bypassing 0 byte writes
|
|
****************************************************************************/
|
|
ssize_t smbcli_smbwrite(struct smbcli_tree *tree,
|
|
int fnum, const void *_buf, off_t offset, size_t size1);
|
|
|
|
bool smbcli_socket_connect(struct smbcli_state *cli, const char *server,
|
|
const char **ports,
|
|
struct tevent_context *ev_ctx,
|
|
struct resolve_context *resolve_ctx,
|
|
struct smbcli_options *options,
|
|
const char *socket_options,
|
|
struct nbt_name *calling,
|
|
struct nbt_name *called);
|
|
NTSTATUS smbcli_negprot(struct smbcli_state *cli, bool unicode, int maxprotocol);
|
|
NTSTATUS smbcli_session_setup(struct smbcli_state *cli,
|
|
struct cli_credentials *credentials,
|
|
const char *workgroup,
|
|
struct smbcli_session_options options,
|
|
struct gensec_settings *gensec_settings);
|
|
NTSTATUS smbcli_tconX(struct smbcli_state *cli, const char *sharename,
|
|
const char *devtype, const char *password);
|
|
NTSTATUS smbcli_full_connection(TALLOC_CTX *parent_ctx,
|
|
struct smbcli_state **ret_cli,
|
|
const char *host,
|
|
const char **ports,
|
|
const char *sharename,
|
|
const char *devtype,
|
|
const char *socket_options,
|
|
struct cli_credentials *credentials,
|
|
struct resolve_context *resolve_ctx,
|
|
struct tevent_context *ev,
|
|
struct smbcli_options *options,
|
|
struct smbcli_session_options *session_options,
|
|
struct gensec_settings *gensec_settings);
|
|
NTSTATUS smbcli_tdis(struct smbcli_state *cli);
|
|
|
|
/****************************************************************************
|
|
Initialise a client state structure.
|
|
****************************************************************************/
|
|
struct smbcli_state *smbcli_state_init(TALLOC_CTX *mem_ctx);
|
|
bool smbcli_parse_unc(const char *unc_name, TALLOC_CTX *mem_ctx,
|
|
char **hostname, char **sharename);
|
|
|
|
/****************************************************************************
|
|
Symlink a file (UNIX extensions).
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unix_symlink(struct smbcli_tree *tree, const char *fname_src,
|
|
const char *fname_dst);
|
|
|
|
/****************************************************************************
|
|
Hard a file (UNIX extensions).
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unix_hardlink(struct smbcli_tree *tree, const char *fname_src,
|
|
const char *fname_dst);
|
|
|
|
/****************************************************************************
|
|
chmod a file (UNIX extensions).
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unix_chmod(struct smbcli_tree *tree, const char *fname, mode_t mode);
|
|
|
|
/****************************************************************************
|
|
chown a file (UNIX extensions).
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unix_chown(struct smbcli_tree *tree, const char *fname, uid_t uid,
|
|
gid_t gid);
|
|
|
|
/****************************************************************************
|
|
Rename a file.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_rename(struct smbcli_tree *tree, const char *fname_src,
|
|
const char *fname_dst);
|
|
|
|
/****************************************************************************
|
|
Delete a file.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unlink(struct smbcli_tree *tree, const char *fname);
|
|
|
|
/****************************************************************************
|
|
Create a directory.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_mkdir(struct smbcli_tree *tree, const char *dname);
|
|
|
|
/****************************************************************************
|
|
Remove a directory.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_rmdir(struct smbcli_tree *tree, const char *dname);
|
|
|
|
/****************************************************************************
|
|
Set or clear the delete on close flag.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_nt_delete_on_close(struct smbcli_tree *tree, int fnum,
|
|
bool flag);
|
|
|
|
/****************************************************************************
|
|
Create/open a file - exposing the full horror of the NT API :-).
|
|
Used in CIFS-on-CIFS NTVFS.
|
|
****************************************************************************/
|
|
int smbcli_nt_create_full(struct smbcli_tree *tree, const char *fname,
|
|
uint32_t CreatFlags, uint32_t DesiredAccess,
|
|
uint32_t FileAttributes, uint32_t ShareAccess,
|
|
uint32_t CreateDisposition, uint32_t CreateOptions,
|
|
uint8_t SecurityFlags);
|
|
|
|
/****************************************************************************
|
|
Open a file (using SMBopenx)
|
|
WARNING: if you open with O_WRONLY then getattrE won't work!
|
|
****************************************************************************/
|
|
int smbcli_open(struct smbcli_tree *tree, const char *fname, int flags,
|
|
int share_mode);
|
|
|
|
/****************************************************************************
|
|
Close a file.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_close(struct smbcli_tree *tree, int fnum);
|
|
|
|
/****************************************************************************
|
|
send a lock with a specified locktype
|
|
this is used for testing LOCKING_ANDX_CANCEL_LOCK
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_locktype(struct smbcli_tree *tree, int fnum,
|
|
uint32_t offset, uint32_t len, int timeout,
|
|
uint8_t locktype);
|
|
|
|
/****************************************************************************
|
|
Lock a file.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_lock(struct smbcli_tree *tree, int fnum,
|
|
uint32_t offset, uint32_t len, int timeout,
|
|
enum brl_type lock_type);
|
|
|
|
/****************************************************************************
|
|
Unlock a file.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unlock(struct smbcli_tree *tree, int fnum, uint32_t offset, uint32_t len);
|
|
|
|
/****************************************************************************
|
|
Lock a file with 64 bit offsets.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_lock64(struct smbcli_tree *tree, int fnum,
|
|
off_t offset, off_t len, int timeout,
|
|
enum brl_type lock_type);
|
|
|
|
/****************************************************************************
|
|
Unlock a file with 64 bit offsets.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_unlock64(struct smbcli_tree *tree, int fnum, off_t offset,
|
|
off_t len);
|
|
|
|
/****************************************************************************
|
|
Do a SMBgetattrE call.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_getattrE(struct smbcli_tree *tree, int fnum,
|
|
uint16_t *attr, size_t *size,
|
|
time_t *c_time, time_t *a_time, time_t *m_time);
|
|
|
|
/****************************************************************************
|
|
Do a SMBgetatr call
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_getatr(struct smbcli_tree *tree, const char *fname,
|
|
uint16_t *attr, size_t *size, time_t *t);
|
|
|
|
/****************************************************************************
|
|
Do a SMBsetatr call.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_setatr(struct smbcli_tree *tree, const char *fname, uint16_t mode,
|
|
time_t t);
|
|
|
|
/****************************************************************************
|
|
Do a setfileinfo basic_info call.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_fsetatr(struct smbcli_tree *tree, int fnum, uint16_t mode,
|
|
NTTIME create_time, NTTIME access_time,
|
|
NTTIME write_time, NTTIME change_time);
|
|
|
|
/****************************************************************************
|
|
truncate a file to a given size
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_ftruncate(struct smbcli_tree *tree, int fnum, uint64_t size);
|
|
|
|
/****************************************************************************
|
|
Check for existence of a dir.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_chkpath(struct smbcli_tree *tree, const char *path);
|
|
|
|
/****************************************************************************
|
|
Query disk space.
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_dskattr(struct smbcli_tree *tree, uint32_t *bsize,
|
|
uint64_t *total, uint64_t *avail);
|
|
|
|
/****************************************************************************
|
|
Create and open a temporary file.
|
|
****************************************************************************/
|
|
int smbcli_ctemp(struct smbcli_tree *tree, const char *path, char **tmp_path);
|
|
|
|
/****************************************************************************
|
|
Interpret a long filename structure.
|
|
****************************************************************************/
|
|
int smbcli_list_new(struct smbcli_tree *tree, const char *Mask, uint16_t attribute,
|
|
enum smb_search_data_level level,
|
|
void (*fn)(struct clilist_file_info *, const char *, void *),
|
|
void *caller_state);
|
|
|
|
/****************************************************************************
|
|
Interpret a short filename structure.
|
|
The length of the structure is returned.
|
|
****************************************************************************/
|
|
int smbcli_list_old(struct smbcli_tree *tree, const char *Mask, uint16_t attribute,
|
|
void (*fn)(struct clilist_file_info *, const char *, void *),
|
|
void *caller_state);
|
|
|
|
/****************************************************************************
|
|
Do a directory listing, calling fn on each file found.
|
|
This auto-switches between old and new style.
|
|
****************************************************************************/
|
|
int smbcli_list(struct smbcli_tree *tree, const char *Mask,uint16_t attribute,
|
|
void (*fn)(struct clilist_file_info *, const char *, void *), void *state);
|
|
|
|
/****************************************************************************
|
|
send a qpathinfo call
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_qpathinfo(struct smbcli_tree *tree, const char *fname,
|
|
time_t *c_time, time_t *a_time, time_t *m_time,
|
|
size_t *size, uint16_t *mode);
|
|
|
|
/****************************************************************************
|
|
send a qpathinfo call with the SMB_QUERY_FILE_ALL_INFO info level
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_qpathinfo2(struct smbcli_tree *tree, const char *fname,
|
|
time_t *c_time, time_t *a_time, time_t *m_time,
|
|
time_t *w_time, size_t *size, uint16_t *mode,
|
|
ino_t *ino);
|
|
|
|
/****************************************************************************
|
|
send a qfileinfo QUERY_FILE_NAME_INFO call
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_qfilename(struct smbcli_tree *tree, int fnum, const char **name);
|
|
|
|
/****************************************************************************
|
|
send a qfileinfo call
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_qfileinfo(struct smbcli_tree *tree, int fnum,
|
|
uint16_t *mode, size_t *size,
|
|
time_t *c_time, time_t *a_time, time_t *m_time,
|
|
time_t *w_time, ino_t *ino);
|
|
|
|
/****************************************************************************
|
|
send a qpathinfo SMB_QUERY_FILE_ALT_NAME_INFO call
|
|
****************************************************************************/
|
|
NTSTATUS smbcli_qpathinfo_alt_name(struct smbcli_tree *tree, const char *fname,
|
|
const char **alt_name);
|
|
|
|
/* The following definitions come from ../source4/libcli/climessage.c */
|
|
|
|
|
|
/****************************************************************************
|
|
start a message sequence
|
|
****************************************************************************/
|
|
bool smbcli_message_start(struct smbcli_tree *tree, const char *host, const char *username,
|
|
int *grp);
|
|
|
|
/****************************************************************************
|
|
send a message
|
|
****************************************************************************/
|
|
bool smbcli_message_text(struct smbcli_tree *tree, char *msg, int len, int grp);
|
|
|
|
/****************************************************************************
|
|
end a message
|
|
****************************************************************************/
|
|
bool smbcli_message_end(struct smbcli_tree *tree, int grp);
|
|
|
|
int smbcli_deltree(struct smbcli_tree *tree, const char *dname);
|
|
|
|
#endif /* __LIBCLI_H__ */
|