2008-10-29 12:05:10 +01:00
#include "idl_types.h"
/*
miscellaneous IDL structures
*/
2011-02-09 14:22:16 +11:00
import "netlogon.idl", "security.idl", "auth.idl";
2008-10-29 12:05:10 +01:00
[
pointer_default(unique)
]
interface named_pipe_auth
{
const char *NAMED_PIPE_AUTH_MAGIC = "NPAM";
2009-09-17 18:26:57 +02:00
typedef struct {
[charset(UTF8),string] uint8 *client_name;
[charset(DOS),string] uint8 *client_addr;
uint16 client_port;
[charset(UTF8),string] uint8 *server_name;
[charset(DOS),string] uint8 *server_addr;
uint16 server_port;
2011-02-09 14:22:16 +11:00
auth_session_info_transport *session_info;
} named_pipe_auth_req_info4;
2009-09-17 18:26:57 +02:00
2008-10-29 12:05:10 +01:00
typedef [switch_type(uint32)] union {
2011-02-09 14:22:16 +11:00
[case(4)] named_pipe_auth_req_info4 info4;
2008-10-29 12:05:10 +01:00
} named_pipe_auth_req_info;
typedef [public,gensize] struct {
[flag(NDR_BIG_ENDIAN),
2010-05-09 17:20:01 +02:00
value(ndr_size_named_pipe_auth_req(r,ndr->flags)-4)]
2008-10-29 12:05:10 +01:00
uint32 length;
[charset(DOS),value(NAMED_PIPE_AUTH_MAGIC)] uint8 magic[4];
uint32 level;
[switch_is(level)] named_pipe_auth_req_info info;
} named_pipe_auth_req;
2009-09-17 18:26:57 +02:00
typedef struct {
uint16 file_type;
uint16 device_state;
hyper allocation_size;
2011-02-09 14:22:16 +11:00
} named_pipe_auth_rep_info4;
2009-09-17 18:26:57 +02:00
2008-10-29 12:05:10 +01:00
typedef [switch_type(uint32)] union {
2011-02-09 14:22:16 +11:00
[case(4)] named_pipe_auth_rep_info4 info4;
2008-10-29 12:05:10 +01:00
} named_pipe_auth_rep_info;
typedef [public,gensize] struct {
[flag(NDR_BIG_ENDIAN),
2010-05-09 17:20:01 +02:00
value(ndr_size_named_pipe_auth_rep(r,ndr->flags)-4)]
2008-10-29 12:05:10 +01:00
uint32 length;
[charset(DOS),value(NAMED_PIPE_AUTH_MAGIC)] uint8 magic[4];
uint32 level;
[switch_is(level)] named_pipe_auth_rep_info info;
NTSTATUS status;
} named_pipe_auth_rep;
}