summaryrefslogtreecommitdiff
path: root/source3/librpc/idl/xattr.idl
blob: e19e2f89d8a99a0e8d97d1ba4ab46a63d5258a4b (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
#include "idl_types.h"

/*
   IDL structures for xattrs
*/

[
  pointer_default(unique)
]
interface xattr
{
	/* xattrs for file systems that don't have any */

	typedef [public] struct {
		utf8string name;
		DATA_BLOB value;
	} tdb_xattr;

	typedef [public] struct {
		uint32 num_xattrs;
		tdb_xattr xattrs[num_xattrs];
	} tdb_xattrs;

	/* we store the NT ACL a NTACL xattr. It is versioned so we
	   can later add other acl attribs (such as posix acl mapping)

	   we put this xattr in the security namespace to ensure that
	   only trusted users can write to the ACL

	   stored in "security.NTACL"

	   Version 1. raw SD stored as Samba4 does it.
	   Version 2. raw SD + last changed timestamp so we
		      can discard if this doesn't match the POSIX st_ctime.
        */

	typedef [public] struct {
		security_descriptor *sd;
		NTTIME last_changed;
	} security_descriptor_timestamp;

        typedef [switch_type(uint16)] union {
                [case(1)] security_descriptor *sd;
		[case(2)] security_descriptor_timestamp *sd_ts;
        } xattr_NTACL_Info;

        typedef [public] struct {
                uint16 version;
                [switch_is(version)] xattr_NTACL_Info info;
        } xattr_NTACL;

}