LCOV - code coverage report
Current view: top level - librpc/ndr - ndr_nbt.c (source / functions) Hit Total Coverage
Test: coverage report for v4-17-test 1498b464 Lines: 176 222 79.3 %
Date: 2024-06-13 04:01:37 Functions: 8 11 72.7 %

          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          18 : _PUBLIC_ void ndr_print_nbt_string(struct ndr_print *ndr, const char *name, const char *s)
      38             : {
      39          18 :         ndr_print_string(ndr, name, s);
      40          18 : }
      41             : 
      42             : /*
      43             :   pull one component of a nbt_string
      44             : */
      45       69179 : 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             :         uint8_t len;
      51       69179 :         unsigned int loops = 0;
      52      134016 :         while (loops < 5) {
      53       77654 :                 if (*offset >= ndr->data_size) {
      54           0 :                         return ndr_pull_error(ndr, NDR_ERR_STRING,
      55             :                                               "BAD NBT NAME component");
      56             :                 }
      57       77654 :                 len = ndr->data[*offset];
      58       77654 :                 if (len == 0) {
      59       28654 :                         *offset += 1;
      60       28654 :                         *max_offset = MAX(*max_offset, *offset);
      61       28654 :                         *component = NULL;
      62       28654 :                         return NDR_ERR_SUCCESS;
      63             :                 }
      64       49000 :                 if ((len & 0xC0) == 0xC0) {
      65             :                         /* its a label pointer */
      66        8475 :                         if (1 + *offset >= ndr->data_size) {
      67           0 :                                 return ndr_pull_error(ndr, NDR_ERR_STRING,
      68             :                                                       "BAD NBT NAME component");
      69             :                         }
      70        8475 :                         *max_offset = MAX(*max_offset, *offset + 2);
      71        8475 :                         *offset = ((len&0x3F)<<8) | ndr->data[1 + *offset];
      72        8475 :                         *max_offset = MAX(*max_offset, *offset);
      73        8475 :                         loops++;
      74        8475 :                         continue;
      75             :                 }
      76       40525 :                 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       40525 :                 if (*offset + len + 1 > ndr->data_size) {
      82           0 :                         return ndr_pull_error(ndr, NDR_ERR_STRING,
      83             :                                               "BAD NBT NAME component");
      84             :                 }
      85       81050 :                 *component = (uint8_t*)talloc_strndup(
      86       40525 :                         ndr->current_mem_ctx,
      87       40525 :                         (const char *)&ndr->data[1 + *offset], len);
      88       40525 :                 NDR_ERR_HAVE_NO_MEMORY(*component);
      89       40525 :                 *offset += len + 1;
      90       40525 :                 *max_offset = MAX(*max_offset, *offset);
      91       40525 :                 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       28654 : _PUBLIC_ enum ndr_err_code ndr_pull_nbt_string(struct ndr_pull *ndr, int ndr_flags, const char **s)
     102             : {
     103       28654 :         uint32_t offset = ndr->offset;
     104       28654 :         uint32_t max_offset = offset;
     105             :         unsigned num_components;
     106             :         char *name;
     107             : 
     108       28654 :         if (!(ndr_flags & NDR_SCALARS)) {
     109           0 :                 return NDR_ERR_SUCCESS;
     110             :         }
     111             : 
     112       28654 :         name = NULL;
     113             : 
     114             :         /* break up name into a list of components */
     115      125541 :         for (num_components=0;num_components<MAX_COMPONENTS;num_components++) {
     116       69179 :                 uint8_t *component = NULL;
     117       69179 :                 NDR_CHECK(ndr_pull_component(ndr, &component, &offset, &max_offset));
     118       69179 :                 if (component == NULL) break;
     119       40525 :                 if (name) {
     120       12813 :                         name = talloc_asprintf_append_buffer(name, ".%s", component);
     121       12813 :                         NDR_ERR_HAVE_NO_MEMORY(name);
     122             :                 } else {
     123       27712 :                         name = (char *)component;
     124             :                 }
     125             :         }
     126       28654 :         if (num_components == MAX_COMPONENTS) {
     127           0 :                 return ndr_pull_error(ndr, NDR_ERR_STRING,
     128             :                                       "BAD NBT NAME too many components");
     129             :         }
     130       28654 :         if (num_components == 0) {
     131         942 :                 name = talloc_strdup(ndr->current_mem_ctx, "");
     132         942 :                 NDR_ERR_HAVE_NO_MEMORY(name);
     133             :         }
     134             : 
     135       28654 :         (*s) = name;
     136       28654 :         ndr->offset = max_offset;
     137             : 
     138       28654 :         return NDR_ERR_SUCCESS;
     139             : }
     140             : 
     141             : /**
     142             :   push a nbt string to the wire
     143             : */
     144       23179 : _PUBLIC_ enum ndr_err_code ndr_push_nbt_string(struct ndr_push *ndr, int ndr_flags, const char *s)
     145             : {
     146       23179 :         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          16 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_REQUEST(struct ndr_push *ndr, int ndr_flags, const struct NETLOGON_SAM_LOGON_REQUEST *r)
     156             : {
     157          16 :         if (ndr_flags & NDR_SCALARS) {
     158           8 :                 NDR_CHECK(ndr_push_align(ndr, 4));
     159           8 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->request_count));
     160             :                 {
     161           8 :                         uint32_t _flags_save_string = ndr->flags;
     162           8 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     163           8 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->computer_name));
     164           8 :                         ndr->flags = _flags_save_string;
     165             :                 }
     166             :                 {
     167           8 :                         uint32_t _flags_save_string = ndr->flags;
     168           8 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     169           8 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->user_name));
     170           8 :                         ndr->flags = _flags_save_string;
     171             :                 }
     172             :                 {
     173           8 :                         uint32_t _flags_save_string = ndr->flags;
     174           8 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
     175           8 :                         NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->mailslot_name));
     176           8 :                         ndr->flags = _flags_save_string;
     177             :                 }
     178           8 :                 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->acct_control));
     179           8 :                 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     180           8 :                 if (ndr_size_dom_sid0(&r->sid, ndr->flags)) {
     181             :                         struct ndr_push *_ndr_sid;
     182           4 :                         uint32_t _flags_save_DATA_BLOB = ndr->flags;
     183           4 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
     184           4 :                         NDR_CHECK(ndr_push_DATA_BLOB(ndr, NDR_SCALARS, r->_pad));
     185           4 :                         ndr->flags = _flags_save_DATA_BLOB;
     186           4 :                         NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     187           4 :                         NDR_CHECK(ndr_push_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
     188           4 :                         NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
     189             :                 }
     190           8 :                 NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
     191           8 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
     192           8 :                 NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
     193             :         }
     194          16 :         if (ndr_flags & NDR_BUFFERS) {
     195             :         }
     196          16 :         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          18 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_REQUEST(struct ndr_pull *ndr, int ndr_flags, struct NETLOGON_SAM_LOGON_REQUEST *r)
     201             : {
     202          18 :         if (ndr_flags & NDR_SCALARS) {
     203           9 :                 NDR_CHECK(ndr_pull_align(ndr, 4));
     204           9 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->request_count));
     205             :                 {
     206           9 :                         uint32_t _flags_save_string = ndr->flags;
     207           9 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     208           9 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->computer_name));
     209           9 :                         ndr->flags = _flags_save_string;
     210             :                 }
     211             :                 {
     212           9 :                         uint32_t _flags_save_string = ndr->flags;
     213           9 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
     214           9 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->user_name));
     215           9 :                         ndr->flags = _flags_save_string;
     216             :                 }
     217             :                 {
     218           9 :                         uint32_t _flags_save_string = ndr->flags;
     219           9 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
     220           9 :                         NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->mailslot_name));
     221           9 :                         ndr->flags = _flags_save_string;
     222             :                 }
     223           9 :                 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->acct_control));
     224           9 :                 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->sid_size));
     225           9 :                 if (r->sid_size) {
     226           5 :                         uint32_t _flags_save_DATA_BLOB = ndr->flags;
     227             :                         struct ndr_pull *_ndr_sid;
     228           5 :                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
     229           5 :                         NDR_CHECK(ndr_pull_DATA_BLOB(ndr, NDR_SCALARS, &r->_pad));
     230           5 :                         ndr->flags = _flags_save_DATA_BLOB;
     231           5 :                         NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sid, 0, r->sid_size));
     232           5 :                         NDR_CHECK(ndr_pull_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
     233           5 :                         NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sid, 0, r->sid_size));
     234             :                 } else {
     235           4 :                         ZERO_STRUCT(r->sid);
     236             :                 }
     237           9 :                 NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
     238           9 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
     239           9 :                 NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
     240             :         }
     241          18 :         if (ndr_flags & NDR_BUFFERS) {
     242             :         }
     243          18 :         return NDR_ERR_SUCCESS;
     244             : }
     245             : 
     246             : /* Manually modified to only push some parts of the structure if certain flags are set */
     247        1365 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_push *ndr, int ndr_flags, const struct NETLOGON_SAM_LOGON_RESPONSE_EX *r)
     248             : {
     249             :         {
     250        1365 :                 uint32_t _flags_save_STRUCT = ndr->flags;
     251        1365 :                 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
     252        1365 :                 if (ndr_flags & NDR_SCALARS) {
     253        1365 :                         NDR_CHECK(ndr_push_align(ndr, 4));
     254        1365 :                         NDR_CHECK(ndr_push_netlogon_command(ndr, NDR_SCALARS, r->command));
     255        1365 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->sbz));
     256        1365 :                         NDR_CHECK(ndr_push_nbt_server_type(ndr, NDR_SCALARS, r->server_type));
     257        1365 :                         NDR_CHECK(ndr_push_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
     258        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->forest));
     259        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->dns_domain));
     260        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_dns_name));
     261        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->domain_name));
     262        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_name));
     263        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->user_name));
     264        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->server_site));
     265        1365 :                         NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->client_site));
     266        1365 :                         if (r->nt_version & NETLOGON_NT_VERSION_5EX_WITH_IP) {
     267         259 :                                 NDR_CHECK(ndr_push_uint8(ndr, NDR_SCALARS, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     268             :                                 {
     269             :                                         struct ndr_push *_ndr_sockaddr;
     270         259 :                                         NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     271         259 :                                         NDR_CHECK(ndr_push_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
     272         259 :                                         NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
     273             :                                 }
     274             :                         }
     275        1365 :                         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        1365 :                         NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
     279        1365 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
     280        1365 :                         NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
     281             :                 }
     282        1365 :                 if (ndr_flags & NDR_BUFFERS) {
     283        1365 :                         NDR_CHECK(ndr_push_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
     284             :                 }
     285        1365 :                 ndr->flags = _flags_save_STRUCT;
     286             :         }
     287        1365 :         return NDR_ERR_SUCCESS;
     288             : }
     289             : 
     290             : /* Manually modified to only pull some parts of the structure if certain flags provided */
     291        1189 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_pull *ndr, int ndr_flags, struct NETLOGON_SAM_LOGON_RESPONSE_EX *r,
     292             :                                                                      uint32_t nt_version_flags)
     293             : {
     294             :         {
     295        1189 :                 uint32_t _flags_save_STRUCT = ndr->flags;
     296        1189 :                 ZERO_STRUCTP(r);
     297        1189 :                 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
     298        1189 :                 if (ndr_flags & NDR_SCALARS) {
     299        1189 :                         NDR_CHECK(ndr_pull_align(ndr, 4));
     300        1189 :                         NDR_CHECK(ndr_pull_netlogon_command(ndr, NDR_SCALARS, &r->command));
     301        1189 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->sbz));
     302        1189 :                         NDR_CHECK(ndr_pull_nbt_server_type(ndr, NDR_SCALARS, &r->server_type));
     303        1189 :                         NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
     304        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->forest));
     305        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->dns_domain));
     306        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_dns_name));
     307        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->domain_name));
     308        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_name));
     309        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->user_name));
     310        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->server_site));
     311        1189 :                         NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->client_site));
     312        1189 :                         if (nt_version_flags & NETLOGON_NT_VERSION_5EX_WITH_IP) {
     313         259 :                                 NDR_CHECK(ndr_pull_uint8(ndr, NDR_SCALARS, &r->sockaddr_size));
     314             :                                 {
     315             :                                         struct ndr_pull *_ndr_sockaddr;
     316         259 :                                         NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sockaddr, 0, r->sockaddr_size));
     317         259 :                                         NDR_CHECK(ndr_pull_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
     318         259 :                                         NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sockaddr, 0, r->sockaddr_size));
     319             :                                 }
     320             :                         }
     321        1189 :                         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        1189 :                         NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
     325        1189 :                         if (r->nt_version != nt_version_flags) {
     326           0 :                                 return NDR_ERR_VALIDATE;
     327             :                         }
     328        1189 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
     329        1189 :                         NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
     330             :                 }
     331        1189 :                 if (ndr_flags & NDR_BUFFERS) {
     332        1189 :                         NDR_CHECK(ndr_pull_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
     333             :                 }
     334        1189 :                 ndr->flags = _flags_save_STRUCT;
     335             :         }
     336        1189 :         return NDR_ERR_SUCCESS;
     337             : }
     338             : 
     339           0 : _PUBLIC_ enum ndr_err_code ndr_push_netlogon_samlogon_response(struct ndr_push *ndr, int ndr_flags, const struct netlogon_samlogon_response *r)
     340             : {
     341           0 :         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           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     345           0 :                 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           0 : _PUBLIC_ enum ndr_err_code ndr_pull_netlogon_samlogon_response(struct ndr_pull *ndr, int ndr_flags, struct netlogon_samlogon_response *r)
     358             : {
     359           0 :         if (ndr->data_size < 8) {
     360           0 :                 return NDR_ERR_BUFSIZE;
     361             :         }
     362             : 
     363             :         /* lmnttoken */
     364           0 :         if (SVAL(ndr->data, ndr->data_size - 4) != 0xffff) {
     365           0 :                 return NDR_ERR_TOKEN;
     366             :         }
     367             :         /* lm20token */
     368           0 :         if (SVAL(ndr->data, ndr->data_size - 2) != 0xffff) {
     369           0 :                 return NDR_ERR_TOKEN;
     370             :         }
     371             : 
     372           0 :         r->ntver = IVAL(ndr->data, ndr->data_size - 8);
     373             : 
     374           0 :         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           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     378           0 :                 NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
     379             :                         ndr, ndr_flags, &r->data.nt5_ex, r->ntver));
     380           0 :                 if (ndr->offset < ndr->data_size) {
     381           0 :                         return ndr_pull_error(ndr, NDR_ERR_UNREAD_BYTES,
     382             :                                                  "not all bytes consumed ofs[%u] size[%u]",
     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           0 : _PUBLIC_ void ndr_print_netlogon_samlogon_response(struct ndr_print *ndr, const char *name, struct netlogon_samlogon_response *r)
     396             : {
     397           0 :         ndr_print_struct(ndr, name, "netlogon_samlogon_response");
     398           0 :         if (r == NULL) { ndr_print_null(ndr); return; }
     399           0 :         if (r->ntver == NETLOGON_NT_VERSION_1) {
     400           0 :                 ndr_print_NETLOGON_SAM_LOGON_RESPONSE_NT40(ndr, "data.nt4", &r->data.nt4);
     401           0 :         } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
     402           0 :                 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.13