mirror of
https://github.com/samba-team/samba.git
synced 2025-01-19 10:03:58 +03:00
e427f58622
The main difference in this new version is the extra data structure generated between the IDL data structure and the NDR parser: IDL -> NDR -> { ndr_parser, ndr_header, eparser, etc } This makes the ndr_parser.pm internals much more sane. Other changes include: - Remove unnecessary calls with NDR_BUFFERS (for example, GUID doesn't have any buffers, just scalars) as well as some (unnecessary) nested setting of flags. - Parse array loops in the C code rather then calling ndr_pull_array(). This allows us to have, for example, arrays of pointers or arrays of pointers to arrays, etc.. - Use if() {} rather then if () goto foo; everywhere - NDR_IN no longer implies LIBNDR_FLAG_REF_ALLOC - By default, top level pointers are now "ref" (as is the default in most other IDL compilers). This can be overridden using the default_pointer_top() property. - initial work on new ethereal parser generators by Alan DeKok and me - pidl now writes errors in the standard format used by compilers, which is parsable by most editors - ability to warn about the fact that pidl extension(s) have been used, useful for making sure IDL files work with other IDL compilers. oh, and there's probably some other things I can't think of right now.. (This used to be commit 13cf227615f6b9e0e5fa62e59197024410254f01)
98 lines
3.0 KiB
Plaintext
98 lines
3.0 KiB
Plaintext
#include "idl_types.h"
|
|
|
|
/**
|
|
DCOM interfaces
|
|
http://www.grimes.demon.co.uk/DCOM/DCOMSpec.htm
|
|
*/
|
|
|
|
/*
|
|
The OXID Resolver can turn a OXID (Object Exporter ID) into a
|
|
RPC binding string that can be used to contact an object
|
|
|
|
(used by DCOM)
|
|
*/
|
|
|
|
[
|
|
uuid("99fcfec4-5260-101b-bbcb-00aa0021347a"),
|
|
helpstring("Object Exporter ID Resolver"),
|
|
endpoint("ncacn_np:[\\pipe\\epmapper]", "ncacn_ip_tcp:[135]", "ncalrpc:"),
|
|
pointer_default(unique),
|
|
pointer_default_top(unique),
|
|
depends(dcom)
|
|
]
|
|
interface IOXIDResolver
|
|
{
|
|
#define OXID hyper
|
|
#define SETID hyper
|
|
#define IPID GUID
|
|
#define OID GUID
|
|
|
|
/* Method to get the protocol sequences, string bindings */
|
|
/* and machine id for an object server given its OXID. */
|
|
|
|
[idempotent] WERROR ResolveOxid (
|
|
[in] OXID pOxid,
|
|
[in] uint16 cRequestedProtseqs,
|
|
[in, size_is(cRequestedProtseqs)] uint16 arRequestedProtseqs[],
|
|
[out] DUALSTRINGARRAY *ppdsaOxidBindings,
|
|
[out] IPID pipidRemUnknown,
|
|
[out] uint32 pAuthnHint
|
|
);
|
|
|
|
/* Simple ping is used to ping a Set. Client machines use this */
|
|
/* to inform the object exporter that it is still using the */
|
|
/* members of the set. */
|
|
/* Returns S_TRUE if the SetId is known by the object exporter, */
|
|
/* S_FALSE if not. */
|
|
[idempotent] WERROR SimplePing (
|
|
[in] SETID *SetId /* Must not be zero */
|
|
);
|
|
|
|
/* Complex ping is used to create sets of OIDs to ping. The */
|
|
/* whole set can subsequently be pinged using SimplePing, */
|
|
/* thus reducing network traffic. */
|
|
[idempotent] WERROR ComplexPing (
|
|
[in] SETID *SetId, /* In of 0 on first call for new set. */
|
|
[out] SETID SetId,
|
|
[in] uint16 SequenceNum,
|
|
[in] uint16 cAddToSet,
|
|
[in] uint16 cDelFromSet,
|
|
/* add these OIDs to the set */
|
|
[in, size_is(cAddToSet)] OID AddToSet[],
|
|
/*remove these OIDs from the set */
|
|
[in, size_is(cDelFromSet)] OID DelFromSet[],
|
|
[out] uint16 PingBackoffFactor/* 2^factor = multipler */
|
|
);
|
|
|
|
/* In some cases the client maybe unsure that a particular */
|
|
/* binding will reach the server. (For example, when the oxid */
|
|
/* bindings have more then one TCP/IP binding) This call */
|
|
/* can be used to validate the binding */
|
|
/* from the client. */
|
|
[idempotent] WERROR ServerAlive ();
|
|
|
|
/* Method to get the protocol sequences, string bindings, */
|
|
/* RemoteUnknown IPID and COM version for an object server */
|
|
/* given its OXID. Supported by DCOM */
|
|
/* version 5.2 and above. Looks like that means
|
|
* Windows 2003/XP and above */
|
|
[idempotent] WERROR ResolveOxid2 (
|
|
[in] OXID pOxid,
|
|
[in] uint16 cRequestedProtseqs,
|
|
[in, size_is(cRequestedProtseqs)] uint16 arRequestedProtseqs[],
|
|
[out] DUALSTRINGARRAY *pdsaOxidBindings,
|
|
[out] IPID ipidRemUnknown,
|
|
[out] uint32 AuthnHint,
|
|
[out] COMVERSION ComVersion
|
|
);
|
|
typedef struct {
|
|
COMVERSION version;
|
|
uint32 unknown1;
|
|
} COMINFO;
|
|
|
|
[idempotent] WERROR ServerAlive2 (
|
|
[out] COMINFO info,
|
|
[out] DUALSTRINGARRAY dualstring,
|
|
[out] uint8 unknown2[3]);
|
|
}
|