2 * Unix SMB/CIFS implementation.
3 * RPC Pipe client / server routines
4 * Copyright (C) Andrew Tridgell 1992-1997,
5 * Copyright (C) Luke Kenneth Casson Leighton 1996-1997,
6 * Copyright (C) Paul Ashton 1997.
7 * Copyright (C) Jeremy Allison 1999.
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, see <http://www.gnu.org/licenses/>.
26 #define DBGC_CLASS DBGC_RPC_PARSE
28 /*******************************************************************
29 Inits an RPC_HDR structure.
30 ********************************************************************/
32 void init_rpc_hdr(RPC_HDR
*hdr
, enum RPC_PKT_TYPE pkt_type
, uint8 flags
,
33 uint32 call_id
, int data_len
, int auth_len
)
35 hdr
->major
= 5; /* RPC version 5 */
36 hdr
->minor
= 0; /* minor version 0 */
37 hdr
->pkt_type
= pkt_type
; /* RPC packet type */
38 hdr
->flags
= flags
; /* dce/rpc flags */
39 hdr
->pack_type
[0] = 0x10; /* little-endian data representation */
40 hdr
->pack_type
[1] = 0; /* packed data representation */
41 hdr
->pack_type
[2] = 0; /* packed data representation */
42 hdr
->pack_type
[3] = 0; /* packed data representation */
43 hdr
->frag_len
= data_len
; /* fragment length, fill in later */
44 hdr
->auth_len
= auth_len
; /* authentication length */
45 hdr
->call_id
= call_id
; /* call identifier - match incoming RPC */
48 /*******************************************************************
49 Reads or writes an RPC_HDR structure.
50 ********************************************************************/
52 bool smb_io_rpc_hdr(const char *desc
, RPC_HDR
*rpc
, prs_struct
*ps
, int depth
)
57 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr");
60 if(!prs_uint8 ("major ", ps
, depth
, &rpc
->major
))
63 if(!prs_uint8 ("minor ", ps
, depth
, &rpc
->minor
))
65 if(!prs_uint8 ("pkt_type ", ps
, depth
, &rpc
->pkt_type
))
67 if(!prs_uint8 ("flags ", ps
, depth
, &rpc
->flags
))
70 /* We always marshall in little endian format. */
72 rpc
->pack_type
[0] = 0x10;
74 if(!prs_uint8("pack_type0", ps
, depth
, &rpc
->pack_type
[0]))
76 if(!prs_uint8("pack_type1", ps
, depth
, &rpc
->pack_type
[1]))
78 if(!prs_uint8("pack_type2", ps
, depth
, &rpc
->pack_type
[2]))
80 if(!prs_uint8("pack_type3", ps
, depth
, &rpc
->pack_type
[3]))
84 * If reading and pack_type[0] == 0 then the data is in big-endian
85 * format. Set the flag in the prs_struct to specify reverse-endainness.
88 if (UNMARSHALLING(ps
) && rpc
->pack_type
[0] == 0) {
89 DEBUG(10,("smb_io_rpc_hdr: PDU data format is big-endian. Setting flag.\n"));
90 prs_set_endian_data(ps
, RPC_BIG_ENDIAN
);
93 if(!prs_uint16("frag_len ", ps
, depth
, &rpc
->frag_len
))
95 if(!prs_uint16("auth_len ", ps
, depth
, &rpc
->auth_len
))
97 if(!prs_uint32("call_id ", ps
, depth
, &rpc
->call_id
))
102 /*******************************************************************
103 Reads or writes an RPC_IFACE structure.
104 ********************************************************************/
106 static bool smb_io_rpc_iface(const char *desc
, RPC_IFACE
*ifc
, prs_struct
*ps
, int depth
)
111 prs_debug(ps
, depth
, desc
, "smb_io_rpc_iface");
117 if (!smb_io_uuid( "uuid", &ifc
->uuid
, ps
, depth
))
120 if(!prs_uint32 ("version", ps
, depth
, &ifc
->if_version
))
126 /*******************************************************************
127 Inits an RPC_ADDR_STR structure.
128 ********************************************************************/
130 static void init_rpc_addr_str(RPC_ADDR_STR
*str
, const char *name
)
132 str
->len
= strlen(name
) + 1;
133 fstrcpy(str
->str
, name
);
136 /*******************************************************************
137 Reads or writes an RPC_ADDR_STR structure.
138 ********************************************************************/
140 static bool smb_io_rpc_addr_str(const char *desc
, RPC_ADDR_STR
*str
, prs_struct
*ps
, int depth
)
145 prs_debug(ps
, depth
, desc
, "smb_io_rpc_addr_str");
150 if(!prs_uint16 ( "len", ps
, depth
, &str
->len
))
152 if(!prs_uint8s (True
, "str", ps
, depth
, (uchar
*)str
->str
, MIN(str
->len
, sizeof(str
->str
)) ))
157 /*******************************************************************
158 Inits an RPC_HDR_BBA structure.
159 ********************************************************************/
161 static void init_rpc_hdr_bba(RPC_HDR_BBA
*bba
, uint16 max_tsize
, uint16 max_rsize
, uint32 assoc_gid
)
163 bba
->max_tsize
= max_tsize
; /* maximum transmission fragment size (0x1630) */
164 bba
->max_rsize
= max_rsize
; /* max receive fragment size (0x1630) */
165 bba
->assoc_gid
= assoc_gid
; /* associated group id (0x0) */
168 /*******************************************************************
169 Reads or writes an RPC_HDR_BBA structure.
170 ********************************************************************/
172 static bool smb_io_rpc_hdr_bba(const char *desc
, RPC_HDR_BBA
*rpc
, prs_struct
*ps
, int depth
)
177 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_bba");
180 if(!prs_uint16("max_tsize", ps
, depth
, &rpc
->max_tsize
))
182 if(!prs_uint16("max_rsize", ps
, depth
, &rpc
->max_rsize
))
184 if(!prs_uint32("assoc_gid", ps
, depth
, &rpc
->assoc_gid
))
189 /*******************************************************************
190 Inits an RPC_CONTEXT structure.
191 Note the transfer pointer must remain valid until this is marshalled.
192 ********************************************************************/
194 void init_rpc_context(RPC_CONTEXT
*rpc_ctx
, uint16 context_id
,
195 const RPC_IFACE
*abstract
, const RPC_IFACE
*transfer
)
197 rpc_ctx
->context_id
= context_id
; /* presentation context identifier (0x0) */
198 rpc_ctx
->num_transfer_syntaxes
= 1 ; /* the number of syntaxes (has always been 1?)(0x1) */
200 /* num and vers. of interface client is using */
201 rpc_ctx
->abstract
= *abstract
;
203 /* vers. of interface to use for replies */
204 rpc_ctx
->transfer
= CONST_DISCARD(RPC_IFACE
*, transfer
);
207 /*******************************************************************
208 Inits an RPC_HDR_RB structure.
209 Note the context pointer must remain valid until this is marshalled.
210 ********************************************************************/
212 void init_rpc_hdr_rb(RPC_HDR_RB
*rpc
,
213 uint16 max_tsize
, uint16 max_rsize
, uint32 assoc_gid
,
214 RPC_CONTEXT
*context
)
216 init_rpc_hdr_bba(&rpc
->bba
, max_tsize
, max_rsize
, assoc_gid
);
218 rpc
->num_contexts
= 1;
219 rpc
->rpc_context
= context
;
222 /*******************************************************************
223 Reads or writes an RPC_CONTEXT structure.
224 ********************************************************************/
226 bool smb_io_rpc_context(const char *desc
, RPC_CONTEXT
*rpc_ctx
, prs_struct
*ps
, int depth
)
235 if(!prs_uint16("context_id ", ps
, depth
, &rpc_ctx
->context_id
))
237 if(!prs_uint8 ("num_transfer_syntaxes", ps
, depth
, &rpc_ctx
->num_transfer_syntaxes
))
240 /* num_transfer_syntaxes must not be zero. */
241 if (rpc_ctx
->num_transfer_syntaxes
== 0)
244 if(!smb_io_rpc_iface("", &rpc_ctx
->abstract
, ps
, depth
))
247 if (UNMARSHALLING(ps
)) {
248 if (!(rpc_ctx
->transfer
= PRS_ALLOC_MEM(ps
, RPC_IFACE
, rpc_ctx
->num_transfer_syntaxes
))) {
253 for (i
= 0; i
< rpc_ctx
->num_transfer_syntaxes
; i
++ ) {
254 if (!smb_io_rpc_iface("", &rpc_ctx
->transfer
[i
], ps
, depth
))
260 /*******************************************************************
261 Reads or writes an RPC_HDR_RB structure.
262 ********************************************************************/
264 bool smb_io_rpc_hdr_rb(const char *desc
, RPC_HDR_RB
*rpc
, prs_struct
*ps
, int depth
)
271 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_rb");
274 if(!smb_io_rpc_hdr_bba("", &rpc
->bba
, ps
, depth
))
277 if(!prs_uint8("num_contexts", ps
, depth
, &rpc
->num_contexts
))
280 /* 3 pad bytes following - will be mopped up by the prs_align in smb_io_rpc_context(). */
282 /* num_contexts must not be zero. */
283 if (rpc
->num_contexts
== 0)
286 if (UNMARSHALLING(ps
)) {
287 if (!(rpc
->rpc_context
= PRS_ALLOC_MEM(ps
, RPC_CONTEXT
, rpc
->num_contexts
))) {
292 for (i
= 0; i
< rpc
->num_contexts
; i
++ ) {
293 if (!smb_io_rpc_context("", &rpc
->rpc_context
[i
], ps
, depth
))
300 /*******************************************************************
301 Inits an RPC_RESULTS structure.
303 lkclXXXX only one reason at the moment!
304 ********************************************************************/
306 static void init_rpc_results(RPC_RESULTS
*res
,
307 uint8 num_results
, uint16 result
, uint16 reason
)
309 res
->num_results
= num_results
; /* the number of results (0x01) */
310 res
->result
= result
; /* result (0x00 = accept) */
311 res
->reason
= reason
; /* reason (0x00 = no reason specified) */
314 /*******************************************************************
315 Reads or writes an RPC_RESULTS structure.
317 lkclXXXX only one reason at the moment!
318 ********************************************************************/
320 static bool smb_io_rpc_results(const char *desc
, RPC_RESULTS
*res
, prs_struct
*ps
, int depth
)
325 prs_debug(ps
, depth
, desc
, "smb_io_rpc_results");
331 if(!prs_uint8 ("num_results", ps
, depth
, &res
->num_results
))
337 if(!prs_uint16("result ", ps
, depth
, &res
->result
))
339 if(!prs_uint16("reason ", ps
, depth
, &res
->reason
))
344 /*******************************************************************
345 Init an RPC_HDR_BA structure.
347 lkclXXXX only one reason at the moment!
349 ********************************************************************/
351 void init_rpc_hdr_ba(RPC_HDR_BA
*rpc
,
352 uint16 max_tsize
, uint16 max_rsize
, uint32 assoc_gid
,
353 const char *pipe_addr
,
354 uint8 num_results
, uint16 result
, uint16 reason
,
357 init_rpc_hdr_bba (&rpc
->bba
, max_tsize
, max_rsize
, assoc_gid
);
358 init_rpc_addr_str(&rpc
->addr
, pipe_addr
);
359 init_rpc_results (&rpc
->res
, num_results
, result
, reason
);
361 /* the transfer syntax from the request */
362 memcpy(&rpc
->transfer
, transfer
, sizeof(rpc
->transfer
));
365 /*******************************************************************
366 Reads or writes an RPC_HDR_BA structure.
367 ********************************************************************/
369 bool smb_io_rpc_hdr_ba(const char *desc
, RPC_HDR_BA
*rpc
, prs_struct
*ps
, int depth
)
374 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_ba");
377 if(!smb_io_rpc_hdr_bba("", &rpc
->bba
, ps
, depth
))
379 if(!smb_io_rpc_addr_str("", &rpc
->addr
, ps
, depth
))
381 if(!smb_io_rpc_results("", &rpc
->res
, ps
, depth
))
383 if(!smb_io_rpc_iface("", &rpc
->transfer
, ps
, depth
))
388 /*******************************************************************
389 Init an RPC_HDR_REQ structure.
390 ********************************************************************/
392 void init_rpc_hdr_req(RPC_HDR_REQ
*hdr
, uint32 alloc_hint
, uint16 opnum
)
394 hdr
->alloc_hint
= alloc_hint
; /* allocation hint */
395 hdr
->context_id
= 0; /* presentation context identifier */
396 hdr
->opnum
= opnum
; /* opnum */
399 /*******************************************************************
400 Reads or writes an RPC_HDR_REQ structure.
401 ********************************************************************/
403 bool smb_io_rpc_hdr_req(const char *desc
, RPC_HDR_REQ
*rpc
, prs_struct
*ps
, int depth
)
408 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_req");
411 if(!prs_uint32("alloc_hint", ps
, depth
, &rpc
->alloc_hint
))
413 if(!prs_uint16("context_id", ps
, depth
, &rpc
->context_id
))
415 if(!prs_uint16("opnum ", ps
, depth
, &rpc
->opnum
))
420 /*******************************************************************
421 Reads or writes an RPC_HDR_RESP structure.
422 ********************************************************************/
424 bool smb_io_rpc_hdr_resp(const char *desc
, RPC_HDR_RESP
*rpc
, prs_struct
*ps
, int depth
)
429 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_resp");
432 if(!prs_uint32("alloc_hint", ps
, depth
, &rpc
->alloc_hint
))
434 if(!prs_uint16("context_id", ps
, depth
, &rpc
->context_id
))
436 if(!prs_uint8 ("cancel_ct ", ps
, depth
, &rpc
->cancel_count
))
438 if(!prs_uint8 ("reserved ", ps
, depth
, &rpc
->reserved
))
443 /*******************************************************************
444 Reads or writes an RPC_HDR_FAULT structure.
445 ********************************************************************/
447 bool smb_io_rpc_hdr_fault(const char *desc
, RPC_HDR_FAULT
*rpc
, prs_struct
*ps
, int depth
)
452 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_fault");
455 if(!prs_dcerpc_status("status ", ps
, depth
, &rpc
->status
))
457 if(!prs_uint32("reserved", ps
, depth
, &rpc
->reserved
))
463 /*******************************************************************
464 Inits an RPC_HDR_AUTH structure.
465 ********************************************************************/
467 void init_rpc_hdr_auth(RPC_HDR_AUTH
*rai
,
468 uint8 auth_type
, uint8 auth_level
,
470 uint32 auth_context_id
)
472 rai
->auth_type
= auth_type
;
473 rai
->auth_level
= auth_level
;
474 rai
->auth_pad_len
= auth_pad_len
;
475 rai
->auth_reserved
= 0;
476 rai
->auth_context_id
= auth_context_id
;
479 /*******************************************************************
480 Reads or writes an RPC_HDR_AUTH structure.
481 ********************************************************************/
483 bool smb_io_rpc_hdr_auth(const char *desc
, RPC_HDR_AUTH
*rai
, prs_struct
*ps
, int depth
)
488 prs_debug(ps
, depth
, desc
, "smb_io_rpc_hdr_auth");
494 if(!prs_uint8 ("auth_type ", ps
, depth
, &rai
->auth_type
))
496 if(!prs_uint8 ("auth_level ", ps
, depth
, &rai
->auth_level
))
498 if(!prs_uint8 ("auth_pad_len ", ps
, depth
, &rai
->auth_pad_len
))
500 if(!prs_uint8 ("auth_reserved", ps
, depth
, &rai
->auth_reserved
))
502 if(!prs_uint32("auth_context_id", ps
, depth
, &rai
->auth_context_id
))
508 /*******************************************************************
509 Checks an RPC_AUTH_VERIFIER structure.
510 ********************************************************************/
512 bool rpc_auth_verifier_chk(RPC_AUTH_VERIFIER
*rav
,
513 const char *signature
, uint32 msg_type
)
515 return (strequal(rav
->signature
, signature
) && rav
->msg_type
== msg_type
);
518 /*******************************************************************
519 Inits an RPC_AUTH_VERIFIER structure.
520 ********************************************************************/
522 void init_rpc_auth_verifier(RPC_AUTH_VERIFIER
*rav
,
523 const char *signature
, uint32 msg_type
)
525 fstrcpy(rav
->signature
, signature
); /* "NTLMSSP" */
526 rav
->msg_type
= msg_type
; /* NTLMSSP_MESSAGE_TYPE */
529 /*******************************************************************
530 Reads or writes an RPC_AUTH_VERIFIER structure.
531 ********************************************************************/
533 bool smb_io_rpc_auth_verifier(const char *desc
, RPC_AUTH_VERIFIER
*rav
, prs_struct
*ps
, int depth
)
538 prs_debug(ps
, depth
, desc
, "smb_io_rpc_auth_verifier");
542 if(!prs_string("signature", ps
, depth
, rav
->signature
,
543 sizeof(rav
->signature
)))
545 if(!prs_uint32("msg_type ", ps
, depth
, &rav
->msg_type
)) /* NTLMSSP_MESSAGE_TYPE */
551 /*******************************************************************
552 This parses an RPC_AUTH_VERIFIER for schannel. I think
553 ********************************************************************/
555 bool smb_io_rpc_schannel_verifier(const char *desc
, RPC_AUTH_VERIFIER
*rav
, prs_struct
*ps
, int depth
)
560 prs_debug(ps
, depth
, desc
, "smb_io_rpc_schannel_verifier");
563 if(!prs_string("signature", ps
, depth
, rav
->signature
, sizeof(rav
->signature
)))
565 if(!prs_uint32("msg_type ", ps
, depth
, &rav
->msg_type
))
571 /*******************************************************************
572 creates an RPC_AUTH_SCHANNEL_NEG structure.
573 ********************************************************************/
575 void init_rpc_auth_schannel_neg(RPC_AUTH_SCHANNEL_NEG
*neg
,
576 const char *domain
, const char *myname
)
580 fstrcpy(neg
->domain
, domain
);
581 fstrcpy(neg
->myname
, myname
);
584 /*******************************************************************
585 Reads or writes an RPC_AUTH_SCHANNEL_NEG structure.
586 ********************************************************************/
588 bool smb_io_rpc_auth_schannel_neg(const char *desc
, RPC_AUTH_SCHANNEL_NEG
*neg
,
589 prs_struct
*ps
, int depth
)
594 prs_debug(ps
, depth
, desc
, "smb_io_rpc_auth_schannel_neg");
600 if(!prs_uint32("type1", ps
, depth
, &neg
->type1
))
602 if(!prs_uint32("type2", ps
, depth
, &neg
->type2
))
604 if(!prs_string("domain ", ps
, depth
, neg
->domain
, sizeof(neg
->domain
)))
606 if(!prs_string("myname ", ps
, depth
, neg
->myname
, sizeof(neg
->myname
)))
612 /*******************************************************************
613 reads or writes an RPC_AUTH_SCHANNEL_CHK structure.
614 ********************************************************************/
616 bool smb_io_rpc_auth_schannel_chk(const char *desc
, int auth_len
,
617 RPC_AUTH_SCHANNEL_CHK
* chk
,
618 prs_struct
*ps
, int depth
)
623 prs_debug(ps
, depth
, desc
, "smb_io_rpc_auth_schannel_chk");
626 if ( !prs_uint8s(False
, "sig ", ps
, depth
, chk
->sig
, sizeof(chk
->sig
)) )
629 if ( !prs_uint8s(False
, "seq_num", ps
, depth
, chk
->seq_num
, sizeof(chk
->seq_num
)) )
632 if ( !prs_uint8s(False
, "packet_digest", ps
, depth
, chk
->packet_digest
, sizeof(chk
->packet_digest
)) )
635 if ( auth_len
== RPC_AUTH_SCHANNEL_SIGN_OR_SEAL_CHK_LEN
) {
636 if ( !prs_uint8s(False
, "confounder", ps
, depth
, chk
->confounder
, sizeof(chk
->confounder
)) )
643 const struct ndr_syntax_id syntax_spoolss
= {
645 0x12345678, 0x1234, 0xabcd,
648 0x45, 0x67, 0x89, 0xab }