ReactOS 0.4.16-dev-1946-g52006dd
rpc_message.h File Reference
#include "rpc_defs.h"
Include dependency graph for rpc_message.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Typedefs

typedef unsigned int NCA_STATUS
 

Functions

RpcPktHdrRPCRT4_BuildFaultHeader (ULONG DataRepresentation, RPC_STATUS Status)
 
RpcPktHdrRPCRT4_BuildResponseHeader (ULONG DataRepresentation, ULONG BufferLength)
 
RpcPktHdrRPCRT4_BuildBindHeader (ULONG DataRepresentation, unsigned short MaxTransmissionSize, unsigned short MaxReceiveSize, ULONG AssocGroupId, const RPC_SYNTAX_IDENTIFIER *AbstractId, const RPC_SYNTAX_IDENTIFIER *TransferId)
 
RpcPktHdrRPCRT4_BuildBindNackHeader (ULONG DataRepresentation, unsigned char RpcVersion, unsigned char RpcVersionMinor, unsigned short RejectReason)
 
RpcPktHdrRPCRT4_BuildBindAckHeader (ULONG DataRepresentation, unsigned short MaxTransmissionSize, unsigned short MaxReceiveSize, ULONG AssocGroupId, LPCSTR ServerAddress, unsigned char ResultCount, const RpcResult *Results)
 
RpcPktHdrRPCRT4_BuildHttpHeader (ULONG DataRepresentation, unsigned short flags, unsigned short num_data_items, unsigned int payload_size)
 
RpcPktHdrRPCRT4_BuildHttpConnectHeader (int out_pipe, const UUID *connection_uuid, const UUID *pipe_uuid, const UUID *association_uuid)
 
RpcPktHdrRPCRT4_BuildHttpFlowControlHeader (BOOL server, ULONG bytes_transmitted, ULONG flow_control_increment, const UUID *pipe_uuid)
 
RPC_STATUS RPCRT4_Send (RpcConnection *Connection, RpcPktHdr *Header, void *Buffer, unsigned int BufferLength)
 
RPC_STATUS RPCRT4_SendWithAuth (RpcConnection *Connection, RpcPktHdr *Header, void *Buffer, unsigned int BufferLength, const void *Auth, unsigned int AuthLength)
 
RPC_STATUS RPCRT4_ReceiveWithAuth (RpcConnection *Connection, RpcPktHdr **Header, PRPC_MESSAGE pMsg, unsigned char **auth_data_out, ULONG *auth_length_out)
 
DWORD RPCRT4_GetHeaderSize (const RpcPktHdr *Header)
 
RPC_STATUS RPCRT4_ValidateCommonHeader (const RpcPktCommonHdr *hdr)
 
BOOL RPCRT4_IsValidHttpPacket (RpcPktHdr *hdr, unsigned char *data, unsigned short data_len)
 
RPC_STATUS RPCRT4_ParseHttpPrepareHeader1 (RpcPktHdr *header, unsigned char *data, ULONG *field1)
 
RPC_STATUS RPCRT4_ParseHttpPrepareHeader2 (RpcPktHdr *header, unsigned char *data, ULONG *field1, ULONG *bytes_until_next_packet, ULONG *field3)
 
RPC_STATUS RPCRT4_ParseHttpFlowControlHeader (RpcPktHdr *header, unsigned char *data, BOOL server, ULONG *bytes_transmitted, ULONG *flow_control_increment, UUID *pipe_uuid)
 
NCA_STATUS RPC2NCA_STATUS (RPC_STATUS status)
 
RPC_STATUS RPCRT4_ClientConnectionAuth (RpcConnection *conn, BYTE *challenge, ULONG count)
 
RPC_STATUS RPCRT4_ServerConnectionAuth (RpcConnection *conn, BOOL start, RpcAuthVerifier *auth_data_in, ULONG auth_length_in, unsigned char **auth_data_out, ULONG *auth_length_out)
 
RPC_STATUS RPCRT4_AuthorizeConnection (RpcConnection *conn, BYTE *challenge, ULONG count)
 
RPC_STATUS RPCRT4_ServerGetRegisteredAuthInfo (USHORT auth_type, CredHandle *cred, TimeStamp *exp, ULONG *max_token)
 
RPC_STATUS RPCRT4_default_authorize (RpcConnection *conn, BOOL first_time, unsigned char *in_buffer, unsigned int in_size, unsigned char *out_buffer, unsigned int *out_size)
 
BOOL RPCRT4_default_is_authorized (RpcConnection *Connection)
 
RPC_STATUS RPCRT4_default_secure_packet (RpcConnection *Connection, enum secure_packet_direction dir, RpcPktHdr *hdr, unsigned int hdr_size, unsigned char *stub_data, unsigned int stub_data_size, RpcAuthVerifier *auth_hdr, unsigned char *auth_value, unsigned int auth_value_size)
 
RPC_STATUS RPCRT4_default_impersonate_client (RpcConnection *conn)
 
RPC_STATUS RPCRT4_default_revert_to_self (RpcConnection *conn)
 
RPC_STATUS RPCRT4_default_inquire_auth_client (RpcConnection *conn, RPC_AUTHZ_HANDLE *privs, RPC_WSTR *server_princ_name, ULONG *authn_level, ULONG *authn_svc, ULONG *authz_svc, ULONG flags)
 

Typedef Documentation

◆ NCA_STATUS

Definition at line 26 of file rpc_message.h.

Function Documentation

◆ RPC2NCA_STATUS()

NCA_STATUS RPC2NCA_STATUS ( RPC_STATUS  status)

Definition at line 404 of file rpc_message.c.

405{
406 switch (status)
407 {
411 case RPC_S_UNKNOWN_IF: return NCA_S_UNK_IF;
433 default: return status;
434 }
435}
#define STATUS_INTEGER_OVERFLOW
Definition: log.c:20
#define ERROR_OUTOFMEMORY
Definition: deptool.c:13
#define ERROR_INVALID_HANDLE
Definition: compat.h:98
#define NCA_S_UNK_IF
Definition: ncastatus.h:25
#define NCA_S_MANAGER_NOT_ENTERED
Definition: ncastatus.h:45
#define NCA_S_FAULT_INT_DIV_BY_ZERO
Definition: ncastatus.h:34
#define NCA_S_FAULT_INT_OVERFLOW
Definition: ncastatus.h:49
#define NCA_S_FAULT_REMOTE_NO_MEMORY
Definition: ncastatus.h:59
#define NCA_S_COMM_FAILURE
Definition: ncastatus.h:23
#define NCA_S_SERVER_TOO_BUSY
Definition: ncastatus.h:30
#define NCA_S_FAULT_FP_OVERFLOW
Definition: ncastatus.h:38
#define NCA_S_FAULT_UNSPEC
Definition: ncastatus.h:50
#define NCA_S_FAULT_FP_DIV_ZERO
Definition: ncastatus.h:36
#define NCA_S_FAULT_FP_ERROR
Definition: ncastatus.h:48
#define NCA_S_FAULT_PIPE_CLOSED
Definition: ncastatus.h:53
#define NCA_S_FAULT_CONTEXT_MISMATCH
Definition: ncastatus.h:58
#define NCA_S_UNSUPPORTED_TYPE
Definition: ncastatus.h:32
#define NCA_S_FAULT_PIPE_DISCIPLINE
Definition: ncastatus.h:55
#define NCA_S_FAULT_PIPE_EMPTY
Definition: ncastatus.h:52
#define NCA_S_FAULT_CANCEL
Definition: ncastatus.h:46
#define NCA_S_OP_RNG_ERROR
Definition: ncastatus.h:24
#define NCA_S_FAULT_FP_UNDERFLOW
Definition: ncastatus.h:37
#define NCA_S_FAULT_INVALID_TAG
Definition: ncastatus.h:39
#define NCA_S_FAULT_INVALID_BOUND
Definition: ncastatus.h:40
#define NCA_S_PROTO_ERROR
Definition: ncastatus.h:28
#define NCA_S_FAULT_PIPE_ORDER
Definition: ncastatus.h:54
#define STATUS_FLOAT_UNDERFLOW
Definition: ntstatus.h:477
#define STATUS_FLOAT_OVERFLOW
Definition: ntstatus.h:475
#define STATUS_FLOAT_DIVIDE_BY_ZERO
Definition: ntstatus.h:472
#define STATUS_FLOAT_INVALID_OPERATION
Definition: ntstatus.h:474
#define STATUS_INTEGER_DIVIDE_BY_ZERO
Definition: ntstatus.h:478
Definition: ps.c:97
#define RPC_S_SERVER_TOO_BUSY
Definition: winerror.h:1390
#define RPC_S_CALL_FAILED_DNE
Definition: winerror.h:1394
#define RPC_X_SS_HANDLES_MISMATCH
Definition: winerror.h:1442
#define RPC_X_WRONG_PIPE_ORDER
Definition: winerror.h:1495
#define RPC_S_INVALID_BOUND
Definition: winerror.h:1400
#define RPC_S_CALL_FAILED
Definition: winerror.h:1393
#define RPC_S_INVALID_TAG
Definition: winerror.h:1399
#define RPC_X_PIPE_DISCIPLINE_ERROR
Definition: winerror.h:1520
#define RPC_S_UNSUPPORTED_TYPE
Definition: winerror.h:1398
#define RPC_S_UNKNOWN_IF
Definition: winerror.h:1384
#define RPC_S_CALL_CANCELLED
Definition: winerror.h:1482
#define RPC_S_PROTOCOL_ERROR
Definition: winerror.h:1395
#define RPC_X_PIPE_CLOSED
Definition: winerror.h:1519
#define RPC_X_PIPE_EMPTY
Definition: winerror.h:1521
#define RPC_S_NOT_LISTENING
Definition: winerror.h:1382
#define RPC_S_COMM_FAILURE
Definition: winerror.h:1484
#define RPC_S_PROCNUM_OUT_OF_RANGE
Definition: winerror.h:1410

Referenced by process_request_packet().

◆ RPCRT4_AuthorizeConnection()

RPC_STATUS RPCRT4_AuthorizeConnection ( RpcConnection conn,
BYTE challenge,
ULONG  count 
)

◆ RPCRT4_BuildBindAckHeader()

RpcPktHdr * RPCRT4_BuildBindAckHeader ( ULONG  DataRepresentation,
unsigned short  MaxTransmissionSize,
unsigned short  MaxReceiveSize,
ULONG  AssocGroupId,
LPCSTR  ServerAddress,
unsigned char  ResultCount,
const RpcResult Results 
)

Definition at line 254 of file rpc_message.c.

261{
263 ULONG header_size;
264 RpcAddressString *server_address;
266
267 header_size = sizeof(header->bind_ack) +
268 ROUND_UP(FIELD_OFFSET(RpcAddressString, string[strlen(ServerAddress) + 1]), 4) +
269 FIELD_OFFSET(RpcResultList, results[ResultCount]);
270
271 header = calloc(1, header_size);
272 if (header == NULL) {
273 return NULL;
274 }
275
276 RPCRT4_BuildCommonHeader(&header->common, PKT_BIND_ACK, DataRepresentation);
277 header->common.frag_len = header_size;
278 header->bind_ack.max_tsize = MaxTransmissionSize;
279 header->bind_ack.max_rsize = MaxReceiveSize;
280 header->bind_ack.assoc_gid = AssocGroupId;
281 server_address = (RpcAddressString*)(&header->bind_ack + 1);
282 server_address->length = strlen(ServerAddress) + 1;
283 strcpy(server_address->string, ServerAddress);
284 /* results is 4-byte aligned */
285 results = (RpcResultList*)((ULONG_PTR)server_address + ROUND_UP(FIELD_OFFSET(RpcAddressString, string[server_address->length]), 4));
286 results->num_results = ResultCount;
287 memcpy(&results->results[0], Results, ResultCount * sizeof(*Results));
288
289 return header;
290}
static struct _test_info results[8]
Definition: SetCursorPos.c:31
ACPI_SIZE strlen(const char *String)
Definition: utclib.c:269
#define NULL
Definition: types.h:112
#define memcpy(s1, s2, n)
Definition: mkisofs.h:878
#define calloc
Definition: rosglue.h:14
@ PKT_BIND_ACK
Definition: rpc_defs.h:200
#define ROUND_UP(value, alignment)
Definition: rpc_message.c:54
static VOID RPCRT4_BuildCommonHeader(RpcPktCommonHdr *Header, unsigned char PacketType, ULONG DataRepresentation)
Definition: rpc_message.c:109
strcpy
Definition: string.h:131
unsigned short length
Definition: rpc_defs.h:91
char string[ANYSIZE_ARRAY]
Definition: rpc_defs.h:92
#define FIELD_OFFSET(t, f)
Definition: typedefs.h:255
uint32_t ULONG_PTR
Definition: typedefs.h:65
uint32_t ULONG
Definition: typedefs.h:59

Referenced by process_bind_packet_no_send().

◆ RPCRT4_BuildBindHeader()

RpcPktHdr * RPCRT4_BuildBindHeader ( ULONG  DataRepresentation,
unsigned short  MaxTransmissionSize,
unsigned short  MaxReceiveSize,
ULONG  AssocGroupId,
const RPC_SYNTAX_IDENTIFIER AbstractId,
const RPC_SYNTAX_IDENTIFIER TransferId 
)

Definition at line 186 of file rpc_message.c.

192{
194 RpcContextElement *ctxt_elem;
195
196 header = calloc(1, sizeof(header->bind) + FIELD_OFFSET(RpcContextElement, transfer_syntaxes[1]));
197 if (header == NULL) {
198 return NULL;
199 }
200 ctxt_elem = (RpcContextElement *)(&header->bind + 1);
201
202 RPCRT4_BuildCommonHeader(&header->common, PKT_BIND, DataRepresentation);
203 header->common.frag_len = sizeof(header->bind) + FIELD_OFFSET(RpcContextElement, transfer_syntaxes[1]);
204 header->bind.max_tsize = MaxTransmissionSize;
205 header->bind.max_rsize = MaxReceiveSize;
206 header->bind.assoc_gid = AssocGroupId;
207 header->bind.num_elements = 1;
208 ctxt_elem->num_syntaxes = 1;
209 ctxt_elem->abstract_syntax = *AbstractId;
210 ctxt_elem->transfer_syntaxes[0] = *TransferId;
211
212 return header;
213}
@ PKT_BIND
Definition: rpc_defs.h:199
RPC_SYNTAX_IDENTIFIER transfer_syntaxes[ANYSIZE_ARRAY]
Definition: rpc_defs.h:72
RPC_SYNTAX_IDENTIFIER abstract_syntax
Definition: rpc_defs.h:71
unsigned char num_syntaxes
Definition: rpc_defs.h:69

Referenced by RpcAssoc_BindConnection().

◆ RPCRT4_BuildBindNackHeader()

RpcPktHdr * RPCRT4_BuildBindNackHeader ( ULONG  DataRepresentation,
unsigned char  RpcVersion,
unsigned char  RpcVersionMinor,
unsigned short  RejectReason 
)

Definition at line 229 of file rpc_message.c.

233{
235#ifndef _MSC_VER
237#endif
238
239 header = calloc(1, sizeof(*header));
240 if (header == NULL) {
241 return NULL;
242 }
243
244 RPCRT4_BuildCommonHeader(&header->common, PKT_BIND_NACK, DataRepresentation);
245 header->common.frag_len = FIELD_OFFSET(RpcPktBindNAckHdr, protocols[1]);
246 header->reject_reason = RejectReason;
247 header->protocols_count = 1;
248 header->protocols[0].rpc_ver = RpcVersion;
249 header->protocols[0].rpc_ver_minor = RpcVersionMinor;
250
251 return (RpcPktHdr *)header;
252}
struct protocol * protocols
Definition: dispatch.c:56
#define C_ASSERT(e)
Definition: intsafe.h:73
@ PKT_BIND_NACK
Definition: rpc_defs.h:201

Referenced by handle_bind_error().

◆ RPCRT4_BuildFaultHeader()

RpcPktHdr * RPCRT4_BuildFaultHeader ( ULONG  DataRepresentation,
RPC_STATUS  Status 
)

Definition at line 170 of file rpc_message.c.

171{
173
174 header = calloc(1, sizeof(*header));
175 if (header == NULL) {
176 return NULL;
177 }
178
179 RPCRT4_BuildCommonHeader(&header->common, PKT_FAULT, DataRepresentation);
180 header->common.frag_len = sizeof(*header);
181 header->status = Status;
182
183 return (RpcPktHdr *)header;
184}
Status
Definition: gdiplustypes.h:25
@ PKT_FAULT
Definition: rpc_defs.h:191

Referenced by process_request_packet().

◆ RPCRT4_BuildHttpConnectHeader()

RpcPktHdr * RPCRT4_BuildHttpConnectHeader ( int  out_pipe,
const UUID connection_uuid,
const UUID pipe_uuid,
const UUID association_uuid 
)

Definition at line 345 of file rpc_message.c.

349{
351 unsigned int size;
352 char *payload;
353
354 size = 8 + 4 + sizeof(UUID) + 4 + sizeof(UUID) + 8;
355 if (!out_pipe)
356 size += 8 + 4 + sizeof(UUID);
357
359 out_pipe ? 4 : 6, size);
360 if (!header) return NULL;
361 payload = (char *)(&header->http+1);
362
363 /* FIXME: what does this part of the payload do? */
364 WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, 0x00000006, 0x00000001);
365
366 WRITE_HTTP_PAYLOAD_FIELD_UUID(payload, 0x00000003, *connection_uuid);
367 WRITE_HTTP_PAYLOAD_FIELD_UUID(payload, 0x00000003, *pipe_uuid);
368
369 if (out_pipe)
370 /* FIXME: what does this part of the payload do? */
371 WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, 0x00000000, 0x00010000);
372 else
373 {
374 /* FIXME: what does this part of the payload do? */
375 WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, 0x00000004, 0x40000000);
376 /* FIXME: what does this part of the payload do? */
377 WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, 0x00000005, 0x000493e0);
378
379 WRITE_HTTP_PAYLOAD_FIELD_UUID(payload, 0x0000000c, *association_uuid);
380 }
381
382 return header;
383}
GLsizeiptr size
Definition: glext.h:5919
GUID UUID
Definition: module.h:1093
#define WRITE_HTTP_PAYLOAD_FIELD_UUID(payload, type, uuid)
Definition: rpc_message.c:325
RpcPktHdr * RPCRT4_BuildHttpHeader(ULONG DataRepresentation, unsigned short flags, unsigned short num_data_items, unsigned int payload_size)
Definition: rpc_message.c:292
#define WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, type, value)
Definition: rpc_message.c:317
#define NDR_LOCAL_DATA_REPRESENTATION
Definition: rpcndr.h:68

Referenced by rpcrt4_http_prepare_in_pipe(), and rpcrt4_http_prepare_out_pipe().

◆ RPCRT4_BuildHttpFlowControlHeader()

RpcPktHdr * RPCRT4_BuildHttpFlowControlHeader ( BOOL  server,
ULONG  bytes_transmitted,
ULONG  flow_control_increment,
const UUID pipe_uuid 
)

Definition at line 385 of file rpc_message.c.

388{
390 char *payload;
391
393 5 * sizeof(ULONG) + sizeof(UUID));
394 if (!header) return NULL;
395 payload = (char *)(&header->http+1);
396
397 WRITE_HTTP_PAYLOAD_FIELD_UINT32(payload, 0x0000000d, (server ? 0x0 : 0x3));
398
399 WRITE_HTTP_PAYLOAD_FIELD_FLOW_CONTROL(payload, bytes_transmitted,
400 flow_control_increment, *pipe_uuid);
401 return header;
402}
#define WRITE_HTTP_PAYLOAD_FIELD_FLOW_CONTROL(payload, bytes_transmitted, flow_control_increment, uuid)
Definition: rpc_message.c:333
static rfbScreenInfoPtr server
Definition: vnc.c:74

Referenced by rpcrt4_ncacn_http_receive_fragment().

◆ RPCRT4_BuildHttpHeader()

RpcPktHdr * RPCRT4_BuildHttpHeader ( ULONG  DataRepresentation,
unsigned short  flags,
unsigned short  num_data_items,
unsigned int  payload_size 
)

Definition at line 292 of file rpc_message.c.

296{
298
299 header = calloc(1, sizeof(header->http) + payload_size);
300 if (header == NULL) {
301 ERR("failed to allocate memory\n");
302 return NULL;
303 }
304
305 RPCRT4_BuildCommonHeader(&header->common, PKT_HTTP, DataRepresentation);
306 /* since the packet isn't current sent using RPCRT4_Send, set the flags
307 * manually here */
308 header->common.flags = RPC_FLG_FIRST|RPC_FLG_LAST;
309 header->common.call_id = 0;
310 header->common.frag_len = sizeof(header->http) + payload_size;
311 header->http.flags = flags;
312 header->http.num_data_items = num_data_items;
313
314 return header;
315}
#define ERR(fmt,...)
Definition: precomp.h:57
GLbitfield flags
Definition: glext.h:7161
#define RPC_FLG_LAST
Definition: rpc_defs.h:180
#define RPC_FLG_FIRST
Definition: rpc_defs.h:179
@ PKT_HTTP
Definition: rpc_defs.h:208

Referenced by RPCRT4_BuildHttpConnectHeader(), RPCRT4_BuildHttpFlowControlHeader(), and rpcrt4_http_keep_connection_active_timer_proc().

◆ RPCRT4_BuildResponseHeader()

RpcPktHdr * RPCRT4_BuildResponseHeader ( ULONG  DataRepresentation,
ULONG  BufferLength 
)

Definition at line 154 of file rpc_message.c.

155{
157
158 header = calloc(1, sizeof(*header));
159 if (header == NULL) {
160 return NULL;
161 }
162
163 RPCRT4_BuildCommonHeader(&header->common, PKT_RESPONSE, DataRepresentation);
164 header->common.frag_len = sizeof(*header);
165 header->alloc_hint = BufferLength;
166
167 return (RpcPktHdr *)header;
168}
@ PKT_RESPONSE
Definition: rpc_defs.h:190
_Must_inspect_result_ _In_ WDFDEVICE _In_ DEVICE_REGISTRY_PROPERTY _In_ ULONG BufferLength
Definition: wdfdevice.h:3777

Referenced by process_request_packet().

◆ RPCRT4_ClientConnectionAuth()

RPC_STATUS RPCRT4_ClientConnectionAuth ( RpcConnection conn,
BYTE challenge,
ULONG  count 
)

Definition at line 988 of file rpc_message.c.

990{
991 RpcPktHdr *resp_hdr;
993 unsigned char *out_buffer;
994 unsigned int out_len = 0;
995
996 TRACE("challenge %s, %ld bytes\n", challenge, count);
997
998 status = rpcrt4_conn_authorize(conn, FALSE, challenge, count, NULL, &out_len);
999 if (status) return status;
1000 out_buffer = malloc(out_len);
1002 status = rpcrt4_conn_authorize(conn, FALSE, challenge, count, out_buffer, &out_len);
1003 if (status) return status;
1004
1006
1007 if (resp_hdr)
1008 status = RPCRT4_SendWithAuth(conn, resp_hdr, NULL, 0, out_buffer, out_len);
1009 else
1011
1013 free(resp_hdr);
1014
1015 return status;
1016}
#define free
Definition: debug_ros.c:5
#define malloc
Definition: debug_ros.c:4
#define FALSE
Definition: types.h:117
GLuint GLuint GLsizei count
Definition: gl.h:1545
static HANDLE PIO_APC_ROUTINE PVOID PIO_STATUS_BLOCK ULONG PVOID ULONG PVOID out_buffer
Definition: file.c:100
static RPC_STATUS rpcrt4_conn_authorize(RpcConnection *conn, BOOL first_time, unsigned char *in_buffer, unsigned int in_len, unsigned char *out_buffer, unsigned int *out_len)
Definition: rpc_binding.h:221
static RpcPktHdr * RPCRT4_BuildAuthHeader(ULONG DataRepresentation)
Definition: rpc_message.c:215
RPC_STATUS RPCRT4_SendWithAuth(RpcConnection *Connection, RpcPktHdr *Header, void *Buffer, unsigned int BufferLength, const void *Auth, unsigned int AuthLength)
Definition: rpc_message.c:757
long RPC_STATUS
Definition: rpc.h:48
#define TRACE(s)
Definition: solgame.cpp:4
#define RPC_S_OUT_OF_RESOURCES
Definition: winerror.h:1388

Referenced by RpcAssoc_BindConnection().

◆ RPCRT4_default_authorize()

RPC_STATUS RPCRT4_default_authorize ( RpcConnection conn,
BOOL  first_time,
unsigned char in_buffer,
unsigned int  in_size,
unsigned char out_buffer,
unsigned int out_size 
)

Definition at line 868 of file rpc_message.c.

873{
875 SecBufferDesc out_desc;
876 SecBufferDesc inp_desc;
877 SecPkgContext_Sizes secctx_sizes;
878 BOOL continue_needed;
879 ULONG context_req;
881
882 if (!out_buffer)
883 {
884 *out_size = conn->AuthInfo->cbMaxToken;
885 return RPC_S_OK;
886 }
887
888 in.BufferType = SECBUFFER_TOKEN;
889 in.pvBuffer = in_buffer;
890 in.cbBuffer = in_size;
891
892 out.BufferType = SECBUFFER_TOKEN;
893 out.pvBuffer = out_buffer;
894 out.cbBuffer = *out_size;
895
896 out_desc.ulVersion = 0;
897 out_desc.cBuffers = 1;
898 out_desc.pBuffers = &out;
899
900 inp_desc.ulVersion = 0;
901 inp_desc.cBuffers = 1;
902 inp_desc.pBuffers = ∈
903
904 if (conn->server)
905 {
908
910 context_req |= ASC_REQ_INTEGRITY;
913
915 first_time ? NULL : &conn->ctx,
916 &inp_desc, context_req, SECURITY_NETWORK_DREP,
917 &conn->ctx,
918 &out_desc, &conn->attr, &conn->exp);
919 if (r == SEC_E_OK || r == SEC_I_COMPLETE_NEEDED)
920 {
921 /* authorisation done, so nothing more to send */
922 out.cbBuffer = 0;
923 }
924 }
925 else
926 {
929
931 context_req |= ISC_REQ_INTEGRITY;
934
936 first_time ? NULL: &conn->ctx,
937 first_time ? conn->AuthInfo->server_principal_name : NULL,
938 context_req, 0, SECURITY_NETWORK_DREP,
939 first_time ? NULL : &inp_desc, 0, &conn->ctx,
940 &out_desc, &conn->attr, &conn->exp);
941 }
942 if (FAILED(r))
943 {
944 WARN("InitializeSecurityContext failed with error 0x%08lx\n", r);
945 goto failed;
946 }
947
948 TRACE("r = 0x%08lx, attr = 0x%08lx\n", r, conn->attr);
949 continue_needed = ((r == SEC_I_CONTINUE_NEEDED) ||
951
953 {
954 TRACE("complete needed\n");
955 r = CompleteAuthToken(&conn->ctx, &out_desc);
956 if (FAILED(r))
957 {
958 WARN("CompleteAuthToken failed with error 0x%08lx\n", r);
959 goto failed;
960 }
961 }
962
963 TRACE("cbBuffer = %ld\n", out.cbBuffer);
964
965 if (!continue_needed)
966 {
967 r = QueryContextAttributesA(&conn->ctx, SECPKG_ATTR_SIZES, &secctx_sizes);
968 if (FAILED(r))
969 {
970 WARN("QueryContextAttributes failed with error 0x%08lx\n", r);
971 goto failed;
972 }
973 conn->signature_auth_len = secctx_sizes.cbMaxSignature;
974 conn->encryption_auth_len = secctx_sizes.cbSecurityTrailer;
975 }
976
977 *out_size = out.cbBuffer;
978 return RPC_S_OK;
979
980failed:
981 *out_size = 0;
982 return ERROR_ACCESS_DENIED; /* FIXME: is this correct? */
983}
#define WARN(fmt,...)
Definition: precomp.h:61
#define ERROR_ACCESS_DENIED
Definition: compat.h:97
unsigned int BOOL
Definition: ntddk_ex.h:94
GLdouble GLdouble GLdouble r
Definition: gl.h:2055
GLuint in
Definition: glext.h:9616
static unsigned char * in_buffer
Definition: iccvid.c:87
#define FAILED(hr)
Definition: intsafe.h:51
static HANDLE PIO_APC_ROUTINE PVOID PIO_STATUS_BLOCK ULONG PVOID ULONG PVOID ULONG out_size
Definition: file.c:100
static HANDLE PIO_APC_ROUTINE PVOID PIO_STATUS_BLOCK ULONG PVOID ULONG in_size
Definition: file.c:100
#define ISC_REQ_CONFIDENTIALITY
Definition: sspi.h:366
LONG SECURITY_STATUS
Definition: sspi.h:34
#define ASC_REQ_CONNECTION
Definition: sspi.h:435
#define ASC_REQ_DELEGATE
Definition: sspi.h:426
#define ASC_REQ_CONFIDENTIALITY
Definition: sspi.h:430
#define SECBUFFER_TOKEN
Definition: sspi.h:161
#define SECURITY_NETWORK_DREP
Definition: sspi.h:474
#define ISC_REQ_INTEGRITY
Definition: sspi.h:378
#define ISC_REQ_DELEGATE
Definition: sspi.h:362
#define ASC_REQ_USE_DCE_STYLE
Definition: sspi.h:433
#define SECPKG_ATTR_SIZES
Definition: sspi.h:521
#define ISC_REQ_MUTUAL_AUTH
Definition: sspi.h:363
#define ASC_REQ_INTEGRITY
Definition: sspi.h:440
#define ISC_REQ_CONNECTION
Definition: sspi.h:373
#define ISC_REQ_USE_DCE_STYLE
Definition: sspi.h:371
#define RPC_C_AUTHN_LEVEL_PKT_PRIVACY
Definition: rpcdce.h:151
#define RPC_C_AUTHN_LEVEL_PKT_INTEGRITY
Definition: rpcdce.h:150
#define RPC_S_OK
Definition: rpcnterr.h:22
ULONG AuthnLevel
Definition: rpc_binding.h:40
CredHandle cred
Definition: rpc_binding.h:42
ULONG cbMaxToken
Definition: rpc_binding.h:44
LPWSTR server_principal_name
Definition: rpc_binding.h:50
TimeStamp exp
Definition: rpc_binding.h:75
RpcAuthInfo * AuthInfo
Definition: rpc_binding.h:77
ULONG signature_auth_len
Definition: rpc_binding.h:80
ULONG encryption_auth_len
Definition: rpc_binding.h:79
CtxtHandle ctx
Definition: rpc_binding.h:74
ULONG cBuffers
Definition: sspi.h:182
ULONG ulVersion
Definition: sspi.h:181
ULONG cbSecurityTrailer
Definition: sspi.h:564
ULONG cbMaxSignature
Definition: sspi.h:562
wchar_t tm const _CrtWcstime_Writes_and_advances_ptr_ count wchar_t ** out
Definition: wcsftime.cpp:383
#define SEC_E_OK
Definition: winerror.h:3450
#define SEC_I_COMPLETE_NEEDED
Definition: winerror.h:4325
#define SEC_I_CONTINUE_NEEDED
Definition: winerror.h:4324
#define SEC_I_COMPLETE_AND_CONTINUE
Definition: winerror.h:4326
SECURITY_STATUS WINAPI InitializeSecurityContextW(PCredHandle phCredential, PCtxtHandle phContext, SEC_WCHAR *pszTargetName, ULONG fContextReq, ULONG Reserved1, ULONG TargetDataRep, PSecBufferDesc pInput, ULONG Reserved2, PCtxtHandle phNewContext, PSecBufferDesc pOutput, ULONG *pfContextAttr, PTimeStamp ptsExpiry)
Definition: wrapper.c:301
SECURITY_STATUS WINAPI CompleteAuthToken(PCtxtHandle phContext, PSecBufferDesc pToken)
Definition: wrapper.c:420
SECURITY_STATUS WINAPI QueryContextAttributesA(PCtxtHandle phContext, ULONG ulAttribute, void *pBuffer)
Definition: wrapper.c:505
SECURITY_STATUS WINAPI AcceptSecurityContext(PCredHandle phCredential, PCtxtHandle phContext, PSecBufferDesc pInput, ULONG fContextReq, ULONG TargetDataRep, PCtxtHandle phNewContext, PSecBufferDesc pOutput, ULONG *pfContextAttr, PTimeStamp ptsExpiry)
Definition: wrapper.c:365

◆ RPCRT4_default_impersonate_client()

RPC_STATUS RPCRT4_default_impersonate_client ( RpcConnection conn)

Definition at line 1127 of file rpc_message.c.

1128{
1129 SECURITY_STATUS sec_status;
1130
1131 TRACE("(%p)\n", conn);
1132
1133 if (!conn->AuthInfo || !SecIsValidHandle(&conn->ctx))
1135 sec_status = ImpersonateSecurityContext(&conn->ctx);
1136 if (sec_status != SEC_E_OK)
1137 WARN("ImpersonateSecurityContext returned 0x%08lx\n", sec_status);
1138 switch (sec_status)
1139 {
1141 return RPC_S_CANNOT_SUPPORT;
1144 case SEC_E_OK:
1145 return RPC_S_OK;
1146 default:
1147 return RPC_S_SEC_PKG_ERROR;
1148 }
1149}
#define SecIsValidHandle(x)
Definition: sspi.h:63
#define SEC_E_NO_IMPERSONATION
Definition: winerror.h:4317
#define RPC_S_CANNOT_SUPPORT
Definition: winerror.h:1429
#define SEC_E_UNSUPPORTED_FUNCTION
Definition: winerror.h:4308
#define RPC_S_NO_CONTEXT_AVAILABLE
Definition: winerror.h:1430
#define RPC_S_SEC_PKG_ERROR
Definition: winerror.h:1489
SECURITY_STATUS WINAPI ImpersonateSecurityContext(PCtxtHandle phContext)
Definition: wrapper.c:565

Referenced by rpcrt4_conn_np_impersonate_client().

◆ RPCRT4_default_inquire_auth_client()

RPC_STATUS RPCRT4_default_inquire_auth_client ( RpcConnection conn,
RPC_AUTHZ_HANDLE privs,
RPC_WSTR server_princ_name,
ULONG authn_level,
ULONG authn_svc,
ULONG authz_svc,
ULONG  flags 
)

Definition at line 1185 of file rpc_message.c.

1188{
1189 if (!conn->AuthInfo) return RPC_S_BINDING_HAS_NO_AUTH;
1190
1191 if (privs)
1192 {
1193 FIXME("privs not implemented\n");
1194 *privs = NULL;
1195 }
1196 if (server_princ_name)
1197 {
1198 *server_princ_name = wcsdup(conn->AuthInfo->server_principal_name);
1199 if (!*server_princ_name) return ERROR_OUTOFMEMORY;
1200 }
1201 if (authn_level) *authn_level = conn->AuthInfo->AuthnLevel;
1202 if (authn_svc) *authn_svc = conn->AuthInfo->AuthnSvc;
1203 if (authz_svc)
1204 {
1205 FIXME("authorization service not implemented\n");
1206 *authz_svc = RPC_C_AUTHZ_NONE;
1207 }
1208 if (flags)
1209 FIXME("flags 0x%lx not implemented\n", flags);
1210
1211 return RPC_S_OK;
1212}
#define FIXME(fmt,...)
Definition: precomp.h:53
#define RPC_C_AUTHZ_NONE
Definition: rpcdce.h:167
_Check_return_ _CRTIMP wchar_t *__cdecl wcsdup(_In_z_ const wchar_t *_Str)
ULONG AuthnSvc
Definition: rpc_binding.h:41
#define RPC_S_BINDING_HAS_NO_AUTH
Definition: winerror.h:1411

◆ RPCRT4_default_is_authorized()

BOOL RPCRT4_default_is_authorized ( RpcConnection Connection)

Definition at line 1118 of file rpc_message.c.

1119{
1120 return Connection->AuthInfo && SecIsValidHandle(&Connection->ctx);
1121}

◆ RPCRT4_default_revert_to_self()

RPC_STATUS RPCRT4_default_revert_to_self ( RpcConnection conn)

Definition at line 1155 of file rpc_message.c.

1156{
1157 SECURITY_STATUS sec_status;
1158
1159 TRACE("(%p)\n", conn);
1160
1161 if (!conn->AuthInfo || !SecIsValidHandle(&conn->ctx))
1163 sec_status = RevertSecurityContext(&conn->ctx);
1164 if (sec_status != SEC_E_OK)
1165 WARN("RevertSecurityContext returned 0x%08lx\n", sec_status);
1166 switch (sec_status)
1167 {
1169 return RPC_S_CANNOT_SUPPORT;
1172 case SEC_E_OK:
1173 return RPC_S_OK;
1174 default:
1175 return RPC_S_SEC_PKG_ERROR;
1176 }
1177}
SECURITY_STATUS WINAPI RevertSecurityContext(PCtxtHandle phContext)
Definition: wrapper.c:594

Referenced by rpcrt4_conn_np_revert_to_self().

◆ RPCRT4_default_secure_packet()

RPC_STATUS RPCRT4_default_secure_packet ( RpcConnection Connection,
enum secure_packet_direction  dir,
RpcPktHdr hdr,
unsigned int  hdr_size,
unsigned char stub_data,
unsigned int  stub_data_size,
RpcAuthVerifier auth_hdr,
unsigned char auth_value,
unsigned int  auth_value_size 
)

Definition at line 678 of file rpc_message.c.

684{
687 SECURITY_STATUS sec_status;
688
689 message.ulVersion = SECBUFFER_VERSION;
690 message.cBuffers = ARRAY_SIZE(buffers);
691 message.pBuffers = buffers;
692
693 buffers[0].cbBuffer = hdr_size;
695 buffers[0].pvBuffer = hdr;
696 buffers[1].cbBuffer = stub_data_size;
697 buffers[1].BufferType = SECBUFFER_DATA;
698 buffers[1].pvBuffer = stub_data;
699 buffers[2].cbBuffer = sizeof(*auth_hdr);
701 buffers[2].pvBuffer = auth_hdr;
702 buffers[3].cbBuffer = auth_value_size;
703 buffers[3].BufferType = SECBUFFER_TOKEN;
704 buffers[3].pvBuffer = auth_value;
705
706 if (dir == SECURE_PACKET_SEND)
707 {
709 {
710 sec_status = EncryptMessage(&Connection->ctx, 0, &message, 0 /* FIXME */);
711 if (sec_status != SEC_E_OK)
712 {
713 ERR("EncryptMessage failed with 0x%08lx\n", sec_status);
714 return RPC_S_SEC_PKG_ERROR;
715 }
716 }
717 else if (auth_hdr->auth_level != RPC_C_AUTHN_LEVEL_NONE)
718 {
719 sec_status = MakeSignature(&Connection->ctx, 0, &message, 0 /* FIXME */);
720 if (sec_status != SEC_E_OK)
721 {
722 ERR("MakeSignature failed with 0x%08lx\n", sec_status);
723 return RPC_S_SEC_PKG_ERROR;
724 }
725 }
726 }
727 else if (dir == SECURE_PACKET_RECEIVE)
728 {
730 {
731 sec_status = DecryptMessage(&Connection->ctx, &message, 0 /* FIXME */, 0);
732 if (sec_status != SEC_E_OK)
733 {
734 ERR("DecryptMessage failed with 0x%08lx\n", sec_status);
735 return RPC_S_SEC_PKG_ERROR;
736 }
737 }
738 else if (auth_hdr->auth_level != RPC_C_AUTHN_LEVEL_NONE)
739 {
740 sec_status = VerifySignature(&Connection->ctx, &message, 0 /* FIXME */, NULL);
741 if (sec_status != SEC_E_OK)
742 {
743 ERR("VerifySignature failed with 0x%08lx\n", sec_status);
744 return RPC_S_SEC_PKG_ERROR;
745 }
746 }
747 }
748
749 return RPC_S_OK;
750}
unsigned int dir
Definition: maze.c:112
#define ARRAY_SIZE(A)
Definition: main.h:20
const GLuint * buffers
Definition: glext.h:5916
char hdr[14]
Definition: iptest.cpp:33
#define SECBUFFER_DATA
Definition: sspi.h:160
#define SECBUFFER_READONLY_WITH_CHECKSUM
Definition: sspi.h:177
#define SECBUFFER_VERSION
Definition: sspi.h:187
@ SECURE_PACKET_SEND
Definition: rpc_binding.h:32
@ SECURE_PACKET_RECEIVE
Definition: rpc_binding.h:33
static BOOL packet_has_body(const RpcPktHdr *Header)
Definition: rpc_message.c:81
#define RPC_C_AUTHN_LEVEL_NONE
Definition: rpcdce.h:146
unsigned char auth_level
Definition: rpc_defs.h:166
Definition: tftpd.h:60
SECURITY_STATUS WINAPI EncryptMessage(PCtxtHandle phContext, ULONG fQOP, PSecBufferDesc pMessage, ULONG MessageSeqNo)
Definition: wrapper.c:1006
SECURITY_STATUS WINAPI MakeSignature(PCtxtHandle phContext, ULONG fQOP, PSecBufferDesc pMessage, ULONG MessageSeqNo)
Definition: wrapper.c:623
SECURITY_STATUS WINAPI DecryptMessage(PCtxtHandle phContext, PSecBufferDesc pMessage, ULONG MessageSeqNo, PULONG pfQOP)
Definition: wrapper.c:1036
SECURITY_STATUS WINAPI VerifySignature(PCtxtHandle phContext, PSecBufferDesc pMessage, ULONG MessageSeqNo, PULONG pfQOP)
Definition: wrapper.c:653

◆ RPCRT4_GetHeaderSize()

DWORD RPCRT4_GetHeaderSize ( const RpcPktHdr Header)

Definition at line 58 of file rpc_message.c.

59{
60 static const DWORD header_sizes[] = {
61 sizeof(Header->request), 0, sizeof(Header->response),
62 sizeof(Header->fault), 0, 0, 0, 0, 0, 0, 0, sizeof(Header->bind),
63 sizeof(Header->bind_ack), sizeof(Header->bind_nack),
64 0, 0, sizeof(Header->auth3), 0, 0, 0, sizeof(Header->http)
65 };
66 ULONG ret = 0;
67
68 if (Header->common.ptype < ARRAY_SIZE(header_sizes)) {
69 ret = header_sizes[Header->common.ptype];
70 if (ret == 0)
71 FIXME("unhandled packet type %u\n", Header->common.ptype);
72 if (Header->common.flags & RPC_FLG_OBJECT_UUID)
73 ret += sizeof(UUID);
74 } else {
75 WARN("invalid packet type %u\n", Header->common.ptype);
76 }
77
78 return ret;
79}
Definition: Header.h:9
return ret
Definition: mutex.c:146
unsigned long DWORD
Definition: ntddk_ex.h:95
#define RPC_FLG_OBJECT_UUID
Definition: rpc_defs.h:181

Referenced by RPCRT4_default_receive_fragment(), rpcrt4_ncacn_http_receive_fragment(), RPCRT4_ReceiveWithAuth(), and RPCRT4_ValidateCommonHeader().

◆ RPCRT4_IsValidHttpPacket()

BOOL RPCRT4_IsValidHttpPacket ( RpcPktHdr hdr,
unsigned char data,
unsigned short  data_len 
)

Definition at line 479 of file rpc_message.c.

481{
482 unsigned short i;
483 BYTE *p = data;
484
485 for (i = 0; i < hdr->http.num_data_items; i++)
486 {
487 ULONG type;
488
489 if (data_len < sizeof(ULONG))
490 return FALSE;
491
492 type = *(ULONG *)p;
493 p += sizeof(ULONG);
494 data_len -= sizeof(ULONG);
495
496 switch (type)
497 {
498 case 0x3:
499 case 0xc:
500 if (data_len < sizeof(GUID))
501 return FALSE;
502 p += sizeof(GUID);
503 data_len -= sizeof(GUID);
504 break;
505 case 0x0:
506 case 0x2:
507 case 0x4:
508 case 0x5:
509 case 0x6:
510 case 0xd:
511 if (data_len < sizeof(ULONG))
512 return FALSE;
513 p += sizeof(ULONG);
514 data_len -= sizeof(ULONG);
515 break;
516 case 0x1:
517 if (data_len < 24)
518 return FALSE;
519 p += 24;
520 data_len -= 24;
521 break;
522 default:
523 FIXME("unimplemented type 0x%lx\n", type);
524 break;
525 }
526 }
527 return TRUE;
528}
#define TRUE
Definition: types.h:120
GLuint GLuint GLsizei GLenum type
Definition: gl.h:1545
GLint GLenum GLsizei GLsizei GLsizei GLint GLsizei const GLvoid * data
Definition: gl.h:1950
GLfloat GLfloat p
Definition: glext.h:8902
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
unsigned char BYTE
Definition: xxhash.c:193

Referenced by rpcrt4_http_read_http_packet(), and rpcrt4_ncacn_http_receive_fragment().

◆ RPCRT4_ParseHttpFlowControlHeader()

RPC_STATUS RPCRT4_ParseHttpFlowControlHeader ( RpcPktHdr header,
unsigned char data,
BOOL  server,
ULONG bytes_transmitted,
ULONG flow_control_increment,
UUID pipe_uuid 
)

Definition at line 633 of file rpc_message.c.

638{
639 ULONG type;
640 if (header->http.flags != 0x2)
641 {
642 ERR("invalid flags 0x%x\n", header->http.flags);
644 }
645 if (header->http.num_data_items != 2)
646 {
647 ERR("invalid number of data items %d\n", header->http.num_data_items);
649 }
650
652 if (type != 0x0000000d)
653 {
654 ERR("invalid type for field 1: 0x%08lx\n", type);
656 }
657 if (*(ULONG *)GET_HTTP_PAYLOAD_FIELD_DATA(data) != (server ? 0x3 : 0x0))
658 {
659 ERR("invalid type for 0xd field data: 0x%08lx\n", *(ULONG *)GET_HTTP_PAYLOAD_FIELD_DATA(data));
661 }
663
665 if (type != 0x00000001)
666 {
667 ERR("invalid type for field 2: 0x%08lx\n", type);
669 }
670 *bytes_transmitted = *(ULONG *)GET_HTTP_PAYLOAD_FIELD_DATA(data);
671 *flow_control_increment = *(ULONG *)(GET_HTTP_PAYLOAD_FIELD_DATA(data) + 4);
672 *pipe_uuid = *(UUID *)(GET_HTTP_PAYLOAD_FIELD_DATA(data) + 8);
673
674 return RPC_S_OK;
675}
static unsigned char * RPCRT4_NextHttpHeaderField(unsigned char *data)
Definition: rpc_message.c:531
#define GET_HTTP_PAYLOAD_FIELD_DATA(data)
Definition: rpc_message.c:559
#define READ_HTTP_PAYLOAD_FIELD_TYPE(data)
Definition: rpc_message.c:558

Referenced by rpcrt4_ncacn_http_receive_fragment().

◆ RPCRT4_ParseHttpPrepareHeader1()

RPC_STATUS RPCRT4_ParseHttpPrepareHeader1 ( RpcPktHdr header,
unsigned char data,
ULONG field1 
)

Definition at line 562 of file rpc_message.c.

564{
565 ULONG type;
566 if (header->http.flags != 0x0)
567 {
568 ERR("invalid flags 0x%x\n", header->http.flags);
570 }
571 if (header->http.num_data_items != 1)
572 {
573 ERR("invalid number of data items %d\n", header->http.num_data_items);
575 }
577 if (type != 0x00000002)
578 {
579 ERR("invalid type 0x%08lx\n", type);
581 }
583 return RPC_S_OK;
584}

Referenced by rpcrt4_http_prepare_out_pipe().

◆ RPCRT4_ParseHttpPrepareHeader2()

RPC_STATUS RPCRT4_ParseHttpPrepareHeader2 ( RpcPktHdr header,
unsigned char data,
ULONG field1,
ULONG bytes_until_next_packet,
ULONG field3 
)

Definition at line 587 of file rpc_message.c.

591{
592 ULONG type;
593 if (header->http.flags != 0x0)
594 {
595 ERR("invalid flags 0x%x\n", header->http.flags);
597 }
598 if (header->http.num_data_items != 3)
599 {
600 ERR("invalid number of data items %d\n", header->http.num_data_items);
602 }
603
605 if (type != 0x00000006)
606 {
607 ERR("invalid type for field 1: 0x%08lx\n", type);
609 }
612
614 if (type != 0x00000000)
615 {
616 ERR("invalid type for field 2: 0x%08lx\n", type);
618 }
619 *bytes_until_next_packet = *(ULONG *)GET_HTTP_PAYLOAD_FIELD_DATA(data);
621
623 if (type != 0x00000002)
624 {
625 ERR("invalid type for field 3: 0x%08lx\n", type);
627 }
629
630 return RPC_S_OK;
631}

Referenced by rpcrt4_http_prepare_out_pipe().

◆ RPCRT4_ReceiveWithAuth()

RPC_STATUS RPCRT4_ReceiveWithAuth ( RpcConnection Connection,
RpcPktHdr **  Header,
PRPC_MESSAGE  pMsg,
unsigned char **  auth_data_out,
ULONG auth_length_out 
)

Definition at line 1372 of file rpc_message.c.

1376{
1378 DWORD hdr_length;
1379 unsigned short first_flag;
1380 ULONG data_length;
1381 ULONG buffer_length;
1382 ULONG auth_length = 0;
1383 unsigned char *auth_data = NULL;
1384 RpcPktHdr *CurrentHeader = NULL;
1385 void *payload = NULL;
1386
1387 *Header = NULL;
1388 pMsg->Buffer = NULL;
1389 if (auth_data_out) *auth_data_out = NULL;
1390 if (auth_length_out) *auth_length_out = 0;
1391
1392 TRACE("(%p, %p, %p, %p)\n", Connection, Header, pMsg, auth_data_out);
1393
1395
1396 status = RPCRT4_receive_fragment(Connection, Header, &payload);
1397 if (status != RPC_S_OK) goto fail;
1398
1399 hdr_length = RPCRT4_GetHeaderSize(*Header);
1400
1401 /* read packet body */
1402 switch ((*Header)->common.ptype) {
1403 case PKT_RESPONSE:
1404 pMsg->BufferLength = (*Header)->response.alloc_hint;
1405 break;
1406 case PKT_REQUEST:
1407 pMsg->BufferLength = (*Header)->request.alloc_hint;
1408 break;
1409 default:
1410 pMsg->BufferLength = (*Header)->common.frag_len - hdr_length - RPC_AUTH_VERIFIER_LEN(&(*Header)->common);
1411 }
1412
1413 TRACE("buffer length = %u\n", pMsg->BufferLength);
1414
1415 pMsg->Buffer = I_RpcAllocate(pMsg->BufferLength);
1416 if (!pMsg->Buffer)
1417 {
1419 goto fail;
1420 }
1421
1422 first_flag = RPC_FLG_FIRST;
1423 auth_length = (*Header)->common.auth_len;
1424 if (auth_length) {
1425 auth_data = malloc(RPC_AUTH_VERIFIER_LEN(&(*Header)->common));
1426 if (!auth_data) {
1428 goto fail;
1429 }
1430 }
1431 CurrentHeader = *Header;
1432 buffer_length = 0;
1433 while (TRUE)
1434 {
1435 unsigned int header_auth_len = RPC_AUTH_VERIFIER_LEN(&CurrentHeader->common);
1436
1437 /* verify header fields */
1438
1439 if ((CurrentHeader->common.frag_len < hdr_length) ||
1440 (CurrentHeader->common.frag_len - hdr_length < header_auth_len)) {
1441 WARN("frag_len %d too small for hdr_length %ld and auth_len %d\n",
1442 CurrentHeader->common.frag_len, hdr_length, CurrentHeader->common.auth_len);
1444 goto fail;
1445 }
1446
1447 if (CurrentHeader->common.auth_len != auth_length) {
1448 WARN("auth_len header field changed from %ld to %d\n",
1449 auth_length, CurrentHeader->common.auth_len);
1451 goto fail;
1452 }
1453
1454 if ((CurrentHeader->common.flags & RPC_FLG_FIRST) != first_flag) {
1455 TRACE("invalid packet flags\n");
1457 goto fail;
1458 }
1459
1460 data_length = CurrentHeader->common.frag_len - hdr_length - header_auth_len;
1461 if (data_length + buffer_length > pMsg->BufferLength) {
1462 TRACE("allocation hint exceeded, new buffer length = %ld\n",
1463 data_length + buffer_length);
1464 pMsg->BufferLength = data_length + buffer_length;
1466 if (status != RPC_S_OK) goto fail;
1467 }
1468
1469 memcpy((unsigned char *)pMsg->Buffer + buffer_length, payload, data_length);
1470
1471 if (header_auth_len) {
1472 if (header_auth_len < sizeof(RpcAuthVerifier) ||
1473 header_auth_len > RPC_AUTH_VERIFIER_LEN(&(*Header)->common)) {
1474 WARN("bad auth verifier length %d\n", header_auth_len);
1476 goto fail;
1477 }
1478
1479 /* FIXME: we should accumulate authentication data for the bind,
1480 * bind_ack, alter_context and alter_context_response if necessary.
1481 * however, the details of how this is done is very sketchy in the
1482 * DCE/RPC spec. for all other packet types that have authentication
1483 * verifier data then it is just duplicated in all the fragments */
1484 memcpy(auth_data, (unsigned char *)payload + data_length, header_auth_len);
1485
1486 /* these packets are handled specially, not by the generic SecurePacket
1487 * function */
1489 {
1491 CurrentHeader, hdr_length,
1492 (unsigned char *)pMsg->Buffer + buffer_length, data_length,
1493 (RpcAuthVerifier *)auth_data,
1494 auth_data + sizeof(RpcAuthVerifier),
1495 header_auth_len - sizeof(RpcAuthVerifier));
1496 if (status != RPC_S_OK) goto fail;
1497 }
1498 }
1499
1500 buffer_length += data_length;
1501 if (!(CurrentHeader->common.flags & RPC_FLG_LAST)) {
1502 TRACE("next header\n");
1503
1504 if (*Header != CurrentHeader)
1505 {
1506 free(CurrentHeader);
1507 CurrentHeader = NULL;
1508 }
1509 free(payload);
1510 payload = NULL;
1511
1512 status = RPCRT4_receive_fragment(Connection, &CurrentHeader, &payload);
1513 if (status != RPC_S_OK) goto fail;
1514
1515 first_flag = 0;
1516 } else {
1517 break;
1518 }
1519 }
1520 pMsg->BufferLength = buffer_length;
1521
1522 /* success */
1523 status = RPC_S_OK;
1524
1525fail:
1527 if (CurrentHeader != *Header)
1528 free(CurrentHeader);
1529 if (status != RPC_S_OK) {
1530 I_RpcFree(pMsg->Buffer);
1531 pMsg->Buffer = NULL;
1532 free(*Header);
1533 *Header = NULL;
1534 }
1535 if (auth_data_out && status == RPC_S_OK) {
1536 *auth_length_out = auth_length;
1537 *auth_data_out = auth_data;
1538 }
1539 else
1540 free(auth_data);
1541 free(payload);
1542 return status;
1543}
static RPC_STATUS rpcrt4_conn_secure_packet(RpcConnection *conn, enum secure_packet_direction dir, RpcPktHdr *hdr, unsigned int hdr_size, unsigned char *stub_data, unsigned int stub_data_size, RpcAuthVerifier *auth_hdr, unsigned char *auth_value, unsigned int auth_value_size)
Definition: rpc_binding.h:228
static BOOL rpcrt4_conn_is_authorized(RpcConnection *Connection)
Definition: rpc_binding.h:216
void RPCRT4_SetThreadCurrentConnection(RpcConnection *Connection)
Definition: rpcrt4_main.c:985
@ PKT_REQUEST
Definition: rpc_defs.h:188
#define RPC_AUTH_VERIFIER_LEN(common_hdr)
Definition: rpc_defs.h:173
static BOOL packet_does_auth_negotiation(const RpcPktHdr *Header)
Definition: rpc_message.c:94
static RPC_STATUS I_RpcReAllocateBuffer(PRPC_MESSAGE pMsg)
Definition: rpc_message.c:1668
DWORD RPCRT4_GetHeaderSize(const RpcPktHdr *Header)
Definition: rpc_message.c:58
static RPC_STATUS RPCRT4_receive_fragment(RpcConnection *Connection, RpcPktHdr **Header, void **Payload)
Definition: rpc_message.c:1358
void WINAPI I_RpcFree(void *Object)
Definition: rpcrt4_main.c:755
void *WINAPI I_RpcAllocate(unsigned int Size)
Definition: rpcrt4_main.c:747
unsigned char flags
Definition: rpc_defs.h:31
unsigned short auth_len
Definition: rpc_defs.h:34
unsigned short frag_len
Definition: rpc_defs.h:33
unsigned int BufferLength
Definition: rpcdcep.h:41
void * Buffer
Definition: rpcdcep.h:40
RpcPktCommonHdr common
Definition: rpc_defs.h:152

Referenced by RpcAssoc_BindConnection(), RPCRT4_io_thread(), and RPCRT4_Receive().

◆ RPCRT4_Send()

RPC_STATUS RPCRT4_Send ( RpcConnection Connection,
RpcPktHdr Header,
void Buffer,
unsigned int  BufferLength 
)

Definition at line 1219 of file rpc_message.c.

1221{
1222 RPC_STATUS r;
1223
1225 Connection->AuthInfo &&
1226 !rpcrt4_conn_is_authorized(Connection))
1227 {
1228 unsigned int out_size = 0;
1229 unsigned char *out_buffer;
1230
1231 r = rpcrt4_conn_authorize(Connection, TRUE, NULL, 0, NULL, &out_size);
1232 if (r != RPC_S_OK) return r;
1233
1236
1237 /* tack on a negotiate packet */
1238 r = rpcrt4_conn_authorize(Connection, TRUE, NULL, 0, out_buffer, &out_size);
1239 if (r == RPC_S_OK)
1241
1243 }
1244 else
1245 r = RPCRT4_SendWithAuth(Connection, Header, Buffer, BufferLength, NULL, 0);
1246
1247 return r;
1248}
Definition: bufpool.h:45

Referenced by I_RpcSend(), process_request_packet(), and RpcAssoc_BindConnection().

◆ RPCRT4_SendWithAuth()

RPC_STATUS RPCRT4_SendWithAuth ( RpcConnection Connection,
RpcPktHdr Header,
void Buffer,
unsigned int  BufferLength,
const void Auth,
unsigned int  AuthLength 
)

Definition at line 757 of file rpc_message.c.

760{
761 PUCHAR buffer_pos;
762 DWORD hdr_size;
763 LONG count;
764 unsigned char *pkt;
765 LONG alen;
767
769
770 buffer_pos = Buffer;
771 /* The packet building functions save the packet header size, so we can use it. */
772 hdr_size = Header->common.frag_len;
773 if (AuthLength)
774 Header->common.auth_len = AuthLength;
775 else if (Connection->AuthInfo && packet_has_auth_verifier(Header))
776 {
778 Header->common.auth_len = Connection->encryption_auth_len;
779 else
780 Header->common.auth_len = Connection->signature_auth_len;
781 }
782 else
783 Header->common.auth_len = 0;
784 Header->common.flags |= RPC_FLG_FIRST;
785 Header->common.flags &= ~RPC_FLG_LAST;
786
787 alen = RPC_AUTH_VERIFIER_LEN(&Header->common);
788
789 while (!(Header->common.flags & RPC_FLG_LAST)) {
790 unsigned char auth_pad_len = Header->common.auth_len ? ROUND_UP_AMOUNT(BufferLength, AUTH_ALIGNMENT) : 0;
791 unsigned int pkt_size = BufferLength + hdr_size + alen + auth_pad_len;
792
793 /* decide if we need to split the packet into fragments */
794 if (pkt_size <= Connection->MaxTransmissionSize) {
795 Header->common.flags |= RPC_FLG_LAST;
796 Header->common.frag_len = pkt_size;
797 } else {
798 auth_pad_len = 0;
799 /* make sure packet payload will be a multiple of 16 */
800 Header->common.frag_len =
801 ((Connection->MaxTransmissionSize - hdr_size - alen) & ~(AUTH_ALIGNMENT-1)) +
802 hdr_size + alen;
803 }
804
805 pkt = calloc(1, Header->common.frag_len);
806
807 memcpy(pkt, Header, hdr_size);
808
809 /* fragment consisted of header only and is the last one */
810 if (hdr_size == Header->common.frag_len)
811 goto write;
812
813 memcpy(pkt + hdr_size, buffer_pos, Header->common.frag_len - hdr_size - auth_pad_len - alen);
814
815 /* add the authorization info */
816 if (Header->common.auth_len)
817 {
818 RpcAuthVerifier *auth_hdr = (RpcAuthVerifier *)&pkt[Header->common.frag_len - alen];
819
820 auth_hdr->auth_type = Connection->AuthInfo->AuthnSvc;
821 auth_hdr->auth_level = Connection->AuthInfo->AuthnLevel;
822 auth_hdr->auth_pad_length = auth_pad_len;
823 auth_hdr->auth_reserved = 0;
824 /* a unique number... */
825 auth_hdr->auth_context_id = Connection->auth_context_id;
826
827 if (AuthLength)
828 memcpy(auth_hdr + 1, Auth, AuthLength);
829 else
830 {
832 (RpcPktHdr *)pkt, hdr_size,
833 pkt + hdr_size, Header->common.frag_len - hdr_size - alen,
834 auth_hdr,
835 (unsigned char *)(auth_hdr + 1), Header->common.auth_len);
836 if (status != RPC_S_OK)
837 {
838 free(pkt);
840 return status;
841 }
842 }
843 }
844
845write:
846 count = rpcrt4_conn_write(Connection, pkt, Header->common.frag_len);
847 free(pkt);
848 if (count<0) {
849 WARN("rpcrt4_conn_write failed (auth)\n");
851 return RPC_S_CALL_FAILED;
852 }
853
854 buffer_pos += Header->common.frag_len - hdr_size - alen - auth_pad_len;
855 BufferLength -= Header->common.frag_len - hdr_size - alen - auth_pad_len;
856 Header->common.flags &= ~RPC_FLG_FIRST;
857 }
858
860 return RPC_S_OK;
861}
#define write
Definition: acwin.h:97
if(dx< 0)
Definition: linetemp.h:194
long LONG
Definition: pedump.c:60
static int rpcrt4_conn_write(RpcConnection *Connection, const void *buffer, unsigned int len)
Definition: rpc_binding.h:190
static BOOL packet_has_auth_verifier(const RpcPktHdr *Header)
Definition: rpc_message.c:88
#define ROUND_UP_AMOUNT(value, alignment)
Definition: rpc_message.c:52
#define AUTH_ALIGNMENT
Definition: rpc_message.c:49
unsigned char auth_type
Definition: rpc_defs.h:165
unsigned char auth_pad_length
Definition: rpc_defs.h:167
unsigned char auth_reserved
Definition: rpc_defs.h:168
unsigned int auth_context_id
Definition: rpc_defs.h:169
USHORT MaxTransmissionSize
Definition: rpc_binding.h:71
ULONG auth_context_id
Definition: rpc_binding.h:78
unsigned char * PUCHAR
Definition: typedefs.h:53

Referenced by process_bind_packet(), RPCRT4_ClientConnectionAuth(), and RPCRT4_Send().

◆ RPCRT4_ServerConnectionAuth()

RPC_STATUS RPCRT4_ServerConnectionAuth ( RpcConnection conn,
BOOL  start,
RpcAuthVerifier auth_data_in,
ULONG  auth_length_in,
unsigned char **  auth_data_out,
ULONG auth_length_out 
)

Definition at line 1021 of file rpc_message.c.

1027{
1028 unsigned char *out_buffer;
1029 unsigned int out_size;
1031
1032 if (start)
1033 {
1034 /* remove any existing authentication information */
1035 if (conn->AuthInfo)
1036 {
1038 conn->AuthInfo = NULL;
1039 }
1040 if (SecIsValidHandle(&conn->ctx))
1041 {
1042 DeleteSecurityContext(&conn->ctx);
1043 SecInvalidateHandle(&conn->ctx);
1044 }
1045 if (auth_length_in >= sizeof(RpcAuthVerifier))
1046 {
1047 CredHandle cred;
1048 TimeStamp exp;
1049 ULONG max_token;
1050
1052 auth_data_in->auth_type, &cred, &exp, &max_token);
1053 if (status != RPC_S_OK)
1054 {
1055 ERR("unknown authentication service %u\n", auth_data_in->auth_type);
1056 return status;
1057 }
1058
1059 status = RpcAuthInfo_Create(auth_data_in->auth_level,
1060 auth_data_in->auth_type, cred, exp,
1061 max_token, NULL, &conn->AuthInfo);
1062 if (status != RPC_S_OK)
1063 {
1064 FreeCredentialsHandle(&cred);
1065 return status;
1066 }
1067
1068 /* FIXME: should auth_data_in->auth_context_id be checked in the !start case? */
1069 conn->auth_context_id = auth_data_in->auth_context_id;
1070 }
1071 }
1072
1073 if (auth_length_in < sizeof(RpcAuthVerifier))
1074 return RPC_S_OK;
1075
1076 if (!conn->AuthInfo)
1077 /* should have filled in authentication info by now */
1078 return RPC_S_PROTOCOL_ERROR;
1079
1081 conn, start, (unsigned char *)(auth_data_in + 1),
1082 auth_length_in - sizeof(RpcAuthVerifier), NULL, &out_size);
1083 if (status) return status;
1084
1087
1089 conn, start, (unsigned char *)(auth_data_in + 1),
1090 auth_length_in - sizeof(RpcAuthVerifier), out_buffer, &out_size);
1091 if (status != RPC_S_OK)
1092 {
1094 return status;
1095 }
1096
1097 if (out_size && !auth_length_out)
1098 {
1099 ERR("expected authentication to be complete but SSP returned data of "
1100 "%u bytes to be sent back to client\n", out_size);
1102 return RPC_S_SEC_PKG_ERROR;
1103 }
1104 else
1105 {
1106 *auth_data_out = out_buffer;
1107 *auth_length_out = out_size;
1108 }
1109
1110 return status;
1111}
GLuint start
Definition: gl.h:1545
DWORD exp
Definition: msg.c:16058
#define SecInvalidateHandle(x)
Definition: sspi.h:58
RPC_STATUS RpcAuthInfo_Create(ULONG AuthnLevel, ULONG AuthnSvc, CredHandle cred, TimeStamp exp, ULONG cbMaxToken, RPC_AUTH_IDENTITY_HANDLE identity, RpcAuthInfo **ret)
Definition: rpc_binding.c:1099
ULONG RpcAuthInfo_Release(RpcAuthInfo *AuthInfo)
Definition: rpc_binding.c:1170
RPC_STATUS RPCRT4_ServerGetRegisteredAuthInfo(USHORT auth_type, CredHandle *cred, TimeStamp *exp, ULONG *max_token)
Definition: rpc_server.c:1365
SECURITY_STATUS WINAPI DeleteSecurityContext(PCtxtHandle phContext)
Definition: wrapper.c:450
SECURITY_STATUS WINAPI FreeCredentialsHandle(PCredHandle phCredential)
Definition: wrapper.c:151

Referenced by process_auth3_packet(), and process_bind_packet_no_send().

◆ RPCRT4_ServerGetRegisteredAuthInfo()

RPC_STATUS RPCRT4_ServerGetRegisteredAuthInfo ( USHORT  auth_type,
CredHandle cred,
TimeStamp exp,
ULONG max_token 
)

Definition at line 1365 of file rpc_server.c.

1367{
1369 struct rpc_server_registered_auth_info *auth_info;
1370 SECURITY_STATUS sec_status;
1371
1374 {
1375 if (auth_info->auth_type == auth_type)
1376 {
1377 sec_status = AcquireCredentialsHandleW((SEC_WCHAR *)auth_info->principal, auth_info->package_name,
1379 cred, exp);
1380 if (sec_status != SEC_E_OK)
1381 {
1383 break;
1384 }
1385
1386 *max_token = auth_info->max_token;
1387 status = RPC_S_OK;
1388 break;
1389 }
1390 }
1392
1393 return status;
1394}
uint32_t entry
Definition: isohybrid.c:63
#define SECPKG_CRED_INBOUND
Definition: sspi.h:290
WCHAR SEC_WCHAR
Definition: sspi.h:29
static struct list server_registered_auth_info
Definition: rpc_server.c:71
static CRITICAL_SECTION server_auth_info_cs
Definition: rpc_server.c:91
#define LIST_FOR_EACH_ENTRY(elem, list, type, field)
Definition: list.h:198
void WINAPI LeaveCriticalSection(LPCRITICAL_SECTION)
void WINAPI EnterCriticalSection(LPCRITICAL_SECTION)
#define RPC_S_UNKNOWN_AUTHN_SERVICE
Definition: winerror.h:1412
SECURITY_STATUS WINAPI AcquireCredentialsHandleW(SEC_WCHAR *pszPrincipal, SEC_WCHAR *pszPackage, ULONG fCredentialsUse, PLUID pvLogonID, PVOID pAuthData, SEC_GET_KEY_FN pGetKeyFn, PVOID pvGetKeyArgument, PCredHandle phCredential, PTimeStamp ptsExpiry)
Definition: wrapper.c:105

Referenced by RPCRT4_ServerConnectionAuth().

◆ RPCRT4_ValidateCommonHeader()

RPC_STATUS RPCRT4_ValidateCommonHeader ( const RpcPktCommonHdr hdr)

Definition at line 1251 of file rpc_message.c.

1252{
1253 DWORD hdr_length;
1254
1255 /* verify if the header really makes sense */
1256 if (hdr->rpc_ver != RPC_VER_MAJOR ||
1257 hdr->rpc_ver_minor != RPC_VER_MINOR)
1258 {
1259 WARN("unhandled packet version\n");
1260 return RPC_S_PROTOCOL_ERROR;
1261 }
1262
1263 hdr_length = RPCRT4_GetHeaderSize((const RpcPktHdr*)hdr);
1264 if (hdr_length == 0)
1265 {
1266 WARN("header length == 0\n");
1267 return RPC_S_PROTOCOL_ERROR;
1268 }
1269
1270 if (hdr->frag_len < hdr_length)
1271 {
1272 WARN("bad frag length %d\n", hdr->frag_len);
1273 return RPC_S_PROTOCOL_ERROR;
1274 }
1275
1276 return RPC_S_OK;
1277}
#define RPC_VER_MAJOR
Definition: rpc_defs.h:176
#define RPC_VER_MINOR
Definition: rpc_defs.h:177

Referenced by RPCRT4_default_receive_fragment(), and rpcrt4_ncacn_http_receive_fragment().