mirror of
https://github.com/samba-team/samba.git
synced 2025-01-19 10:03:58 +03:00
ffae01d432
- Makes union handling less special - Allows unions in arrays, etc - Compatible with midl - Pidl will warn about switch_type() and the type of the switch_is() variable being different (This used to be commit dc6b4ffc82a191631bc16a4b93a4916a39183ec6)
115 lines
2.8 KiB
Plaintext
115 lines
2.8 KiB
Plaintext
#include "idl_types.h"
|
|
|
|
/*
|
|
IDL structures for xattr file attributes
|
|
|
|
this has nothing to do with RPC, we are just using our NDR/IDL
|
|
infrastructure as a convenient way to store linearised information
|
|
about a file in a architecture independent manner
|
|
*/
|
|
|
|
[
|
|
depends(security),
|
|
pointer_default(unique)
|
|
]
|
|
interface xattr
|
|
{
|
|
const string XATTR_DOSATTRIB_NAME = "user.DosAttrib";
|
|
const string XATTR_DOSATTRIB_ESTIMATED_SIZE = 64;
|
|
|
|
/* we store basic dos attributes in a DosAttrib xattr. By
|
|
using a union we can cope with new version of this
|
|
structure more easily */
|
|
|
|
typedef struct {
|
|
uint32 attrib;
|
|
uint32 ea_size;
|
|
udlong size;
|
|
udlong alloc_size;
|
|
NTTIME create_time;
|
|
NTTIME change_time;
|
|
} xattr_DosInfo1;
|
|
|
|
const int XATTR_ATTRIB_FLAG_STICKY_WRITE_TIME = 0x1;
|
|
|
|
typedef struct {
|
|
uint32 flags;
|
|
uint32 attrib;
|
|
uint32 ea_size;
|
|
udlong size;
|
|
udlong alloc_size;
|
|
NTTIME create_time;
|
|
NTTIME change_time;
|
|
NTTIME write_time; /* only used when sticky write time is set */
|
|
utf8string name; /* will be used for case-insensitive speedup */
|
|
} xattr_DosInfo2;
|
|
|
|
typedef [switch_type(uint16)] union {
|
|
[case(1)] xattr_DosInfo1 info1;
|
|
[case(2)] xattr_DosInfo2 info2;
|
|
} xattr_DosInfo;
|
|
|
|
typedef [public] struct {
|
|
uint16 version;
|
|
[switch_is(version)] xattr_DosInfo info;
|
|
} xattr_DosAttrib;
|
|
|
|
|
|
/* we store DOS style extended attributes in a DosEAs xattr */
|
|
const string XATTR_DOSEAS_NAME = "user.DosEAs";
|
|
|
|
typedef struct {
|
|
utf8string name;
|
|
DATA_BLOB value;
|
|
} xattr_EA;
|
|
|
|
typedef [public] struct {
|
|
uint16 num_eas;
|
|
[size_is(num_eas)] xattr_EA *eas[];
|
|
} xattr_DosEAs;
|
|
|
|
/* we store stream information in this xattr structure. Then
|
|
the streams themselves are stored in
|
|
user.DosStream.STREAMNAME or in external files, according
|
|
to the flags */
|
|
const string XATTR_DOSSTREAMS_NAME = "user.DosStreams";
|
|
|
|
const int XATTR_STREAM_FLAG_INTERNAL = 0x00000001;
|
|
|
|
/* stream data is stored in attributes with the given prefix */
|
|
const string XATTR_DOSSTREAM_PREFIX = "user.DosStream.";
|
|
|
|
const int XATTR_MAX_STREAM_SIZE = 0x4000;
|
|
|
|
typedef struct {
|
|
uint32 flags;
|
|
udlong size;
|
|
udlong alloc_size;
|
|
utf8string name;
|
|
} xattr_DosStream;
|
|
|
|
typedef [public] struct {
|
|
uint32 num_streams;
|
|
[size_is(num_streams)] xattr_DosStream *streams[];
|
|
} xattr_DosStreams;
|
|
|
|
|
|
/* 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
|
|
*/
|
|
const string XATTR_NTACL_NAME = "security.NTACL";
|
|
|
|
typedef [switch_type(uint16)] union {
|
|
[case(1)] security_descriptor *sd;
|
|
} xattr_NTACL_Info;
|
|
|
|
typedef [public] struct {
|
|
uint16 version;
|
|
[switch_is(version)] xattr_NTACL_Info info;
|
|
} xattr_NTACL;
|
|
|
|
}
|