summaryrefslogtreecommitdiff
path: root/source3/libsmb/clisecdesc.c
blob: b56e1ea68847cadaa4a4de4fa39b52bc3333c188 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
/* 
   Unix SMB/Netbios implementation.
   Version 3.0
   client security descriptor functions
   Copyright (C) Andrew Tridgell 2000
   
   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 2 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, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/

#define NO_SYSLOG

#include "includes.h"



/****************************************************************************
  query the security descriptor for a open file
  ****************************************************************************/
SEC_DESC *cli_query_secdesc(struct cli_state *cli,int fd)
{
	char param[8];
	char *rparam=NULL, *rdata=NULL;
	int rparam_count=0, rdata_count=0;
	TALLOC_CTX *mem_ctx;
	prs_struct pd;
	SEC_DESC *psd = NULL;
	SEC_DESC *ret;

	SIVAL(param, 0, fd);
	SSVAL(param, 4, 0x7);

	if (!cli_send_nt_trans(cli, 
			       NT_TRANSACT_QUERY_SECURITY_DESC, 
			       0, 
			       NULL, 0, 0,
			       param, 8, 4,
			       NULL, 0, 0x10000)) {
		DEBUG(1,("Failed to send NT_TRANSACT_QUERY_SECURITY_DESC\n"));
		return NULL;
	}


	if (!cli_receive_nt_trans(cli, 
				  &rparam, &rparam_count,
				  &rdata, &rdata_count)) {
		DEBUG(1,("Failed to recv NT_TRANSACT_QUERY_SECURITY_DESC\n"));
		return NULL;
	}

	if ((mem_ctx = talloc_init()) == NULL) {
		DEBUG(0,("talloc_init failed.\n"));
		return NULL;
	}

	prs_init(&pd, rdata_count, 4, mem_ctx, UNMARSHALL);
	prs_append_data(&pd, rdata, rdata_count);
	pd.data_offset = 0;

	if (!sec_io_desc("sd data", &psd, &pd, 1)) {
		DEBUG(1,("Failed to parse secdesc\n"));
		talloc_destroy(mem_ctx);
		return NULL;
	}

	ret = dup_sec_desc(psd);
	talloc_destroy(mem_ctx);
	return ret;
}




/****************************************************************************
  set the security descriptor for a open file
  ****************************************************************************/
BOOL cli_set_secdesc(struct cli_state *cli,int fd, SEC_DESC *sd)
{
	char param[8];
	char *rparam=NULL, *rdata=NULL;
	int rparam_count=0, rdata_count=0;
	TALLOC_CTX *mem_ctx;
	prs_struct pd;

	if ((mem_ctx = talloc_init()) == NULL) {
		DEBUG(0,("talloc_init failed.\n"));
		return False;
	}

	prs_init(&pd, 0, 4, mem_ctx, MARSHALL);
	prs_give_memory(&pd, NULL, 0, True);

	if (!sec_io_desc("sd data", &sd, &pd, 1)) {
		DEBUG(1,("Failed to marshall secdesc\n"));
		return False;
	}

	SIVAL(param, 0, fd);
	SSVAL(param, 4, 0x7);

	if (!cli_send_nt_trans(cli, 
			       NT_TRANSACT_SET_SECURITY_DESC, 
			       0, 
			       NULL, 0, 0,
			       param, 8, 0,
			       pd.data_p, pd.data_offset, 0)) {
		DEBUG(1,("Failed to send NT_TRANSACT_SET_SECURITY_DESC\n"));
		return False;
	}


	if (!cli_receive_nt_trans(cli, 
				  &rparam, &rparam_count,
				  &rdata, &rdata_count)) {
		DEBUG(1,("NT_TRANSACT_SET_SECURITY_DESC failed\n"));
		return False;
	}

	if (rparam) free(rparam);
	if (rdata) free(rdata);

	talloc_destroy(mem_ctx);

	return True;
}