LCOV - code coverage report
Current view: top level - librpc/ndr - ndr_nbt.c (source / functions) Hit Total Coverage
Test: coverage report for fix-15632 9995c5c2 Lines: 202 231 87.4 %
Date: 2024-04-13 12:30:31 Functions: 11 11 100.0 %

          Line data    Source code
       1             : /*
       2             :    Unix SMB/CIFS implementation.
       3             : 
       4             :    CLDAP server structures
       5             : 
       6             :    Copyright (C) Andrew Tridgell 2005
       7             :    Copyright (C) Andrew Bartlett <abartlet@samba.org> 2008
       8             : 
       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.
      13             : 
      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.
      18             : 
      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/>.
      21             : */
      22             : 
      23             : /* parser auto-generated by pidl, then hand-modified by abartlet */
      24             : 
      25             : #include "includes.h"
      26             : #include "../libcli/nbt/libnbt.h"
      27             : #include "../libcli/netlogon/netlogon.h"
      28             : #include "ndr_dns_utils.h"
      29             : 
      30             : 
      31             : /* don't allow an unlimited number of name components */
      32             : #define MAX_COMPONENTS 128
      33             : 
      34             : /**
      35             :   print a nbt string
      36             : */
      37          81 : _PUBLIC_ void ndr_print_nbt_string(struct ndr_print *ndr, const char *name, const char *s)
      38             : {
      39          81 :         ndr_print_string(ndr, name, s);
      40          81 : }
      41             : 
      42             : /*
      43             :   pull one component of a nbt_string
      44             : */
      45      101514 : static enum ndr_err_code ndr_pull_component(struct ndr_pull *ndr,
      46             :                                             uint8_t **component,
      47             :                                             uint32_t *offset,
      48             :                                             uint32_t *max_offset)
      49             : {
      50        1692 :         uint8_t len;
      51      101514 :         unsigned int loops = 0;
      52      114185 :         while (loops < 5) {
      53      114185 :                 if (*offset >= ndr->data_size) {
      54           0 :                         return ndr_pull_error(ndr, NDR_ERR_STRING,
      55             :                                               "BAD NBT NAME component");
      56             :                 }
      57      114185 :                 len = ndr->data[*offset];
      58      114185 :                 if (len == 0) {
      59       39359 :                         *offset += 1;
      60       39359 :                         *max_offset = MAX(*max_offset, *offset);
      61       39359 :                         *component = NULL;
      62       39359 :                         return NDR_ERR_SUCCESS;
      63             :                 }
      64       74826 :                 if ((len & 0xC0) == 0xC0) {
      65             :                         /* its a label pointer */
      66       12671 :                         if (1 + *offset >= ndr->data_size) {
      67           0 :                                 return ndr_pull_error(ndr, NDR_ERR_STRING,
      68             :                                                       "BAD NBT NAME component");
      69             :                         }
      70       12671 :                         *max_offset = MAX(*max_offset, *offset + 2);
      71       12671 :                         *offset = ((len&0x3F)<<8) | ndr->data[1 + *offset];
      72       12671 :                         *max_offset = MAX(*max_offset, *offset);
      73       12671 :                         loops++;
      74       12671 :                         continue;
      75             :                 }
      76       62155 :                 if ((len & 0xC0) != 0) {
      77             :                         /* its a reserved length field */
      78           0 :                         return ndr_pull_error(ndr, NDR_ERR_STRING,
      79             :                                               "BAD NBT NAME component");
      80             :                 }
      81       62155 :                 if (*offset + len + 1 > ndr->data_size) {
      82           0 :                         return ndr_pull_error(ndr, NDR_ERR_STRING,
      83             :                                               "BAD NBT NAME component");
      84             :                 }
      85      124310 :                 *component = (uint8_t*)talloc_strndup(
      86       62155 :                         ndr->current_mem_ctx,
      87       62155 :                         (const char *)&ndr->data[1 + *offset], len);
      88       62155 :                 NDR_ERR_HAVE_NO_MEMORY(*component);
      89       62155 :                 *offset += len + 1;
      90       62155 :                 *max_offset = MAX(*max_offset, *offset);
      91       62155 :                 return NDR_ERR_SUCCESS;
      92             :         }
      93             : 
      94             :         /* too many pointers */
      95           0 :         return ndr_pull_error(ndr, NDR_ERR_STRING, "BAD NBT NAME component");
      96             : }
      97             : 
      98             : /**
      99             :   pull a nbt_string from the wire
     100             : */
     101       39359 : _PUBLIC_ enum ndr_err_code ndr_pull_nbt_string(struct ndr_pull *ndr, ndr_flags_type ndr_flags, const char **s)
     102             : {
     103       39359 :         uint32_t offset = ndr->offset;
     104       39359 :         uint32_t max_offset = offset;
     105         535 :         unsigned num_components;
     106         535 :         char *name;
     107             : 
     108       39359 :         if (!(ndr_flags & NDR_SCALARS)) {
     109           0 :                 return NDR_ERR_SUCCESS;
     110             :         }
     111             : 
     112       38824 :         name = NULL;
     113             : 
     114             :         /* break up name into a list of components */
     115      101514 :         for (num_components=0;num_components<MAX_COMPONENTS;num_components++) {
     116      101514 :                 uint8_t *component = NULL;
     117      101514 :                 NDR_CHECK(ndr_pull_component(ndr, &component, &offset, &max_offset));
     118      101514 :                 if (component == NULL) break;
     119       62155 :                 if (name) {
     120       24922 :                         name = talloc_asprintf_append_buffer(name, ".%s", component);
     121       24922 :                         NDR_ERR_HAVE_NO_MEMORY(name);
     122             :                 } else {
     123       36738 :                         name = (char *)component;
     124             :                 }
     125             :         }
     126       39359 :         if (num_components == MAX_COMPONENTS) {
     127           0 :                 return ndr_pull_error(ndr, NDR_ERR_STRING,
     128             :                                       "BAD NBT NAME too many components");
     129             :         }
     130       39359 :         if (num_components == 0) {
     131        2126 :                 name = talloc_strdup(ndr->current_mem_ctx, "");
     132        2126 :                 NDR_ERR_HAVE_NO_MEMORY(name);
     133             :         }
     134             : 
     135       39359 :         (*s) = name;
     136       39359 :         ndr->offset = max_offset;
     137             : 
     138       39359 :         return NDR_ERR_SUCCESS;
     139             : }
     140             : 
     141             : /**
     142             :   push a nbt string to the wire
     143             : */
     144       35835 : _PUBLIC_ enum ndr_err_code ndr_push_nbt_string(struct ndr_push *ndr, ndr_flags_type ndr_flags, const char *s)
     145             : {
     146       35835 :         return ndr_push_dns_string_list(ndr,
     147             :                                         &ndr->dns_string_list,
     148             :                                         ndr_flags,
     149             :                                         s,
     150             :                                         true);
     151             : }
     152             : 
     153             : 
     154             : /* Manually modified to handle the dom_sid being optional based on if it is present or all zero */
     155          66 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_REQUEST(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct NETLOGON_SAM_LOGON_REQUEST *r)
     156             : {
     157          66 :         if (ndr_flags & NDR_SCALARS) {
     158          33 :                 NDR_CHECK(ndr_push_align(ndr, 4));
     159          33 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->request_count));
     160             :                 {
     161          33 :                         libndr_flags _flags_save_string = ndr->flags;
     162          33 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     163          33 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->computer_name));
     164          33 :                         ndr->flags = _flags_save_string;
     165             :                 }
     166             :                 {
     167          33 :                         libndr_flags _flags_save_string = ndr->flags;
     168          33 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     169          33 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->user_name));
     170          33 :                         ndr->flags = _flags_save_string;
     171             :                 }
     172             :                 {
     173          33 :                         libndr_flags _flags_save_string = ndr->flags;
     174          33 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
     175          33 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->mailslot_name));
     176          33 :                         ndr->flags = _flags_save_string;
     177             :                 }
     178          33 :                 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->acct_control));
     179          33 :                 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     180          33 :                 if (ndr_size_dom_sid0(&r->sid, ndr->flags)) {
     181           2 :                         struct ndr_push *_ndr_sid;
     182          16 :                         libndr_flags _flags_save_DATA_BLOB = ndr->flags;
     183          16 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
     184          16 :                         NDR_CHECK(ndr_push_DATA_BLOB(ndr, NDR_SCALARS, r->_pad));
     185          16 :                         ndr->flags = _flags_save_DATA_BLOB;
     186          16 :                         NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     187          16 :                         NDR_CHECK(ndr_push_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
     188          16 :                         NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     189             :                 }
     190          33 :                 NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
     191          33 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
     192          33 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
     193             :         }
     194          66 :         if (ndr_flags & NDR_BUFFERS) {
     195           4 :         }
     196          66 :         return NDR_ERR_SUCCESS;
     197             : }
     198             : 
     199             : /* Manually modified to handle the dom_sid being optional based on if it is present (size is non-zero) or not */
     200          80 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_REQUEST(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct NETLOGON_SAM_LOGON_REQUEST *r)
     201             : {
     202          80 :         if (ndr_flags & NDR_SCALARS) {
     203          40 :                 NDR_CHECK(ndr_pull_align(ndr, 4));
     204          40 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->request_count));
     205             :                 {
     206          40 :                         libndr_flags _flags_save_string = ndr->flags;
     207          40 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     208          40 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->computer_name));
     209          40 :                         ndr->flags = _flags_save_string;
     210             :                 }
     211             :                 {
     212          40 :                         libndr_flags _flags_save_string = ndr->flags;
     213          40 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     214          40 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->user_name));
     215          40 :                         ndr->flags = _flags_save_string;
     216             :                 }
     217             :                 {
     218          40 :                         libndr_flags _flags_save_string = ndr->flags;
     219          40 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
     220          40 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->mailslot_name));
     221          40 :                         ndr->flags = _flags_save_string;
     222             :                 }
     223          40 :                 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->acct_control));
     224          40 :                 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->sid_size));
     225          40 :                 if (r->sid_size) {
     226          23 :                         libndr_flags _flags_save_DATA_BLOB = ndr->flags;
     227           2 :                         struct ndr_pull *_ndr_sid;
     228          23 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
     229          23 :                         NDR_CHECK(ndr_pull_DATA_BLOB(ndr, NDR_SCALARS, &r->_pad));
     230          23 :                         ndr->flags = _flags_save_DATA_BLOB;
     231          23 :                         NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sid, 0, r->sid_size));
     232          23 :                         NDR_CHECK(ndr_pull_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
     233          23 :                         NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sid, 0, r->sid_size));
     234             :                 } else {
     235          17 :                         ZERO_STRUCT(r->sid);
     236             :                 }
     237          40 :                 NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
     238          40 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
     239          40 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
     240             :         }
     241          80 :         if (ndr_flags & NDR_BUFFERS) {
     242           4 :         }
     243          80 :         return NDR_ERR_SUCCESS;
     244             : }
     245             : 
     246             : /* Manually modified to only push some parts of the structure if certain flags are set */
     247        2539 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct NETLOGON_SAM_LOGON_RESPONSE_EX *r)
     248             : {
     249             :         {
     250        2539 :                 libndr_flags _flags_save_STRUCT = ndr->flags;
     251        2539 :                 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
     252        2539 :                 if (ndr_flags & NDR_SCALARS) {
     253        2539 :                         NDR_CHECK(ndr_push_align(ndr, 4));
     254        2539 :                         NDR_CHECK(ndr_push_netlogon_command(ndr, NDR_SCALARS, r->command));
     255        2539 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->sbz));
     256        2539 :                         NDR_CHECK(ndr_push_nbt_server_type(ndr, NDR_SCALARS, r->server_type));
     257        2539 :                         NDR_CHECK(ndr_push_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
     258        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->forest));
     259        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->dns_domain));
     260        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_dns_name));
     261        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->domain_name));
     262        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_name));
     263        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->user_name));
     264        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->server_site));
     265        2539 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->client_site));
     266        2539 :                         if (r->nt_version & NETLOGON_NT_VERSION_5EX_WITH_IP) {
     267         261 :                                 NDR_CHECK(ndr_push_uint8(ndr, NDR_SCALARS, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     268             :                                 {
     269           0 :                                         struct ndr_push *_ndr_sockaddr;
     270         261 :                                         NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     271         261 :                                         NDR_CHECK(ndr_push_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
     272         261 :                                         NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     273             :                                 }
     274             :                         }
     275        2539 :                         if (r->nt_version & NETLOGON_NT_VERSION_WITH_CLOSEST_SITE) {
     276           0 :                                 NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->next_closest_site));
     277             :                         }
     278        2539 :                         NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
     279        2539 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
     280        2539 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
     281             :                 }
     282        2539 :                 if (ndr_flags & NDR_BUFFERS) {
     283        2539 :                         NDR_CHECK(ndr_push_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
     284             :                 }
     285        2539 :                 ndr->flags = _flags_save_STRUCT;
     286             :         }
     287        2539 :         return NDR_ERR_SUCCESS;
     288             : }
     289             : 
     290             : /* Manually modified to only pull some parts of the structure if certain flags provided */
     291        2293 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct NETLOGON_SAM_LOGON_RESPONSE_EX *r,
     292             :                                                                      uint32_t nt_version_flags)
     293             : {
     294             :         {
     295        2293 :                 libndr_flags _flags_save_STRUCT = ndr->flags;
     296        2293 :                 ZERO_STRUCTP(r);
     297        2293 :                 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
     298        2293 :                 if (ndr_flags & NDR_SCALARS) {
     299        2293 :                         NDR_CHECK(ndr_pull_align(ndr, 4));
     300        2293 :                         NDR_CHECK(ndr_pull_netlogon_command(ndr, NDR_SCALARS, &r->command));
     301        2293 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->sbz));
     302        2293 :                         NDR_CHECK(ndr_pull_nbt_server_type(ndr, NDR_SCALARS, &r->server_type));
     303        2293 :                         NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
     304        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->forest));
     305        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->dns_domain));
     306        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_dns_name));
     307        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->domain_name));
     308        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_name));
     309        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->user_name));
     310        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->server_site));
     311        2293 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->client_site));
     312        2293 :                         if (nt_version_flags & NETLOGON_NT_VERSION_5EX_WITH_IP) {
     313         261 :                                 NDR_CHECK(ndr_pull_uint8(ndr, NDR_SCALARS, &r->sockaddr_size));
     314             :                                 {
     315           0 :                                         struct ndr_pull *_ndr_sockaddr;
     316         261 :                                         NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sockaddr, 0, r->sockaddr_size));
     317         261 :                                         NDR_CHECK(ndr_pull_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
     318         261 :                                         NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sockaddr, 0, r->sockaddr_size));
     319             :                                 }
     320             :                         }
     321        2293 :                         if (nt_version_flags & NETLOGON_NT_VERSION_WITH_CLOSEST_SITE) {
     322           0 :                                 NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->next_closest_site));
     323             :                         }
     324        2293 :                         NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
     325        2293 :                         if (r->nt_version != nt_version_flags) {
     326           0 :                                 return NDR_ERR_VALIDATE;
     327             :                         }
     328        2293 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
     329        2293 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
     330             :                 }
     331        2293 :                 if (ndr_flags & NDR_BUFFERS) {
     332        2293 :                         NDR_CHECK(ndr_pull_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
     333             :                 }
     334        2293 :                 ndr->flags = _flags_save_STRUCT;
     335             :         }
     336        2293 :         return NDR_ERR_SUCCESS;
     337             : }
     338             : 
     339           4 : _PUBLIC_ enum ndr_err_code ndr_push_netlogon_samlogon_response(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct netlogon_samlogon_response *r)
     340             : {
     341           4 :         if (r->ntver == NETLOGON_NT_VERSION_1) {
     342           0 :                 NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE_NT40(
     343             :                         ndr, ndr_flags, &r->data.nt4));
     344           4 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     345           4 :                 NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
     346             :                         ndr, ndr_flags, &r->data.nt5_ex));
     347           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5) {
     348           0 :                 NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE(
     349             :                         ndr, ndr_flags, &r->data.nt5));
     350             :         } else {
     351           0 :                 return NDR_ERR_BAD_SWITCH;
     352             :         }
     353             : 
     354           0 :         return NDR_ERR_SUCCESS;
     355             : }
     356             : 
     357           6 : _PUBLIC_ enum ndr_err_code ndr_pull_netlogon_samlogon_response(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct netlogon_samlogon_response *r)
     358             : {
     359           6 :         if (ndr->data_size < 8) {
     360           0 :                 return NDR_ERR_BUFSIZE;
     361             :         }
     362             : 
     363             :         /* lmnttoken */
     364           6 :         if (SVAL(ndr->data, ndr->data_size - 4) != 0xffff) {
     365           0 :                 return NDR_ERR_TOKEN;
     366             :         }
     367             :         /* lm20token */
     368           6 :         if (SVAL(ndr->data, ndr->data_size - 2) != 0xffff) {
     369           0 :                 return NDR_ERR_TOKEN;
     370             :         }
     371             : 
     372           6 :         r->ntver = IVAL(ndr->data, ndr->data_size - 8);
     373             : 
     374           6 :         if (r->ntver == NETLOGON_NT_VERSION_1) {
     375           0 :                 NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_NT40(
     376             :                         ndr, ndr_flags, &r->data.nt4));
     377           6 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     378           6 :                 NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
     379             :                         ndr, ndr_flags, &r->data.nt5_ex, r->ntver));
     380           6 :                 if (ndr->offset < ndr->data_size) {
     381           0 :                         return ndr_pull_error(ndr, NDR_ERR_UNREAD_BYTES,
     382             :                                                  "not all bytes consumed ofs[%"PRIu32"] size[%"PRIu32"]",
     383             :                                                  ndr->offset, ndr->data_size);
     384             :                 }
     385           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5) {
     386           0 :                 NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE(
     387             :                         ndr, ndr_flags, &r->data.nt5));
     388             :         } else {
     389           0 :                 return NDR_ERR_BAD_SWITCH;
     390             :         }
     391             : 
     392           0 :         return NDR_ERR_SUCCESS;
     393             : }
     394             : 
     395           6 : _PUBLIC_ void ndr_print_netlogon_samlogon_response(struct ndr_print *ndr, const char *name, struct netlogon_samlogon_response *r)
     396             : {
     397           6 :         ndr_print_struct(ndr, name, "netlogon_samlogon_response");
     398           6 :         if (r == NULL) { ndr_print_null(ndr); return; }
     399           6 :         if (r->ntver == NETLOGON_NT_VERSION_1) {
     400           0 :                 ndr_print_NETLOGON_SAM_LOGON_RESPONSE_NT40(ndr, "data.nt4", &r->data.nt4);
     401           6 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     402           6 :                 ndr_print_NETLOGON_SAM_LOGON_RESPONSE_EX(ndr, "data.nt5_ex", &r->data.nt5_ex);
     403           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5) {
     404           0 :                 ndr_print_NETLOGON_SAM_LOGON_RESPONSE(ndr, "data.nt5", &r->data.nt5);
     405             :         }
     406             : }

Generated by: LCOV version 1.14