rerun
[metze/samba/wb-ndr.git] / source / librpc / gen_ndr / ndr_winbind_protocol.c
index d2b34476a6da1e49e50a9a2343eca9f028509a7e..733451f1482e028d84a3ed4a79d9dd3a6372b724 100644 (file)
@@ -149,6 +149,7 @@ _PUBLIC_ void ndr_print_winbind_auth_level(struct ndr_print *ndr, const char *na
                case WINBIND_AUTH_LEVEL_COMPAT_AUTH_RESPONSE: val = "WINBIND_AUTH_LEVEL_COMPAT_AUTH_RESPONSE"; break;
                case WINBIND_AUTH_LEVEL_COMPAT_LOGOFF: val = "WINBIND_AUTH_LEVEL_COMPAT_LOGOFF"; break;
                case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN: val = "WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN"; break;
+               case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT: val = "WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT"; break;
        }
        ndr_print_enum(ndr, name, "ENUM", val, r);
 }
@@ -928,6 +929,132 @@ _PUBLIC_ void ndr_print_STRUCT_winbind_auth_change_password_plain_req(struct ndr
        ndr->depth--;
 }
 
+static enum ndr_err_code ndr_push_STRUCT_winbind_auth_change_password_crypt_req(struct ndr_push *ndr, int ndr_flags, const struct winbind_auth_change_password_crypt_req *r)
+{
+       if (ndr_flags & NDR_SCALARS) {
+               NDR_CHECK(ndr_push_align(ndr, 4));
+               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_charset_length(r->account_name, CH_UTF8)));
+               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
+               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_charset_length(r->account_name, CH_UTF8)));
+               NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, r->account_name, ndr_charset_length(r->account_name, CH_UTF8), sizeof(uint8_t), CH_UTF8));
+               NDR_CHECK(ndr_push_unique_ptr(ndr, r->domain_name));
+               NDR_CHECK(ndr_push_samr_CryptPassword(ndr, NDR_SCALARS, &r->nt_password));
+               NDR_CHECK(ndr_push_samr_Password(ndr, NDR_SCALARS, &r->nt_verifier));
+               NDR_CHECK(ndr_push_unique_ptr(ndr, r->lm_password));
+               NDR_CHECK(ndr_push_unique_ptr(ndr, r->lm_verifier));
+       }
+       if (ndr_flags & NDR_BUFFERS) {
+               if (r->domain_name) {
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_charset_length(r->domain_name, CH_UTF8)));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_charset_length(r->domain_name, CH_UTF8)));
+                       NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, r->domain_name, ndr_charset_length(r->domain_name, CH_UTF8), sizeof(uint8_t), CH_UTF8));
+               }
+               if (r->lm_password) {
+                       NDR_CHECK(ndr_push_samr_CryptPassword(ndr, NDR_SCALARS, r->lm_password));
+               }
+               if (r->lm_verifier) {
+                       NDR_CHECK(ndr_push_samr_Password(ndr, NDR_SCALARS, r->lm_verifier));
+               }
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+static enum ndr_err_code ndr_pull_STRUCT_winbind_auth_change_password_crypt_req(struct ndr_pull *ndr, int ndr_flags, struct winbind_auth_change_password_crypt_req *r)
+{
+       uint32_t _ptr_domain_name;
+       TALLOC_CTX *_mem_save_domain_name_0;
+       uint32_t _ptr_lm_password;
+       TALLOC_CTX *_mem_save_lm_password_0;
+       uint32_t _ptr_lm_verifier;
+       TALLOC_CTX *_mem_save_lm_verifier_0;
+       if (ndr_flags & NDR_SCALARS) {
+               NDR_CHECK(ndr_pull_align(ndr, 4));
+               NDR_CHECK(ndr_pull_array_size(ndr, &r->account_name));
+               NDR_CHECK(ndr_pull_array_length(ndr, &r->account_name));
+               if (ndr_get_array_length(ndr, &r->account_name) > ndr_get_array_size(ndr, &r->account_name)) {
+                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should exceed array length %u", ndr_get_array_size(ndr, &r->account_name), ndr_get_array_length(ndr, &r->account_name));
+               }
+               NDR_CHECK(ndr_check_string_terminator(ndr, ndr_get_array_length(ndr, &r->account_name), sizeof(uint8_t)));
+               NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, &r->account_name, ndr_get_array_length(ndr, &r->account_name), sizeof(uint8_t), CH_UTF8));
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_domain_name));
+               if (_ptr_domain_name) {
+                       NDR_PULL_ALLOC(ndr, r->domain_name);
+               } else {
+                       r->domain_name = NULL;
+               }
+               NDR_CHECK(ndr_pull_samr_CryptPassword(ndr, NDR_SCALARS, &r->nt_password));
+               NDR_CHECK(ndr_pull_samr_Password(ndr, NDR_SCALARS, &r->nt_verifier));
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_lm_password));
+               if (_ptr_lm_password) {
+                       NDR_PULL_ALLOC(ndr, r->lm_password);
+               } else {
+                       r->lm_password = NULL;
+               }
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_lm_verifier));
+               if (_ptr_lm_verifier) {
+                       NDR_PULL_ALLOC(ndr, r->lm_verifier);
+               } else {
+                       r->lm_verifier = NULL;
+               }
+       }
+       if (ndr_flags & NDR_BUFFERS) {
+               if (r->domain_name) {
+                       _mem_save_domain_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, r->domain_name, 0);
+                       NDR_CHECK(ndr_pull_array_size(ndr, &r->domain_name));
+                       NDR_CHECK(ndr_pull_array_length(ndr, &r->domain_name));
+                       if (ndr_get_array_length(ndr, &r->domain_name) > ndr_get_array_size(ndr, &r->domain_name)) {
+                               return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad array size %u should exceed array length %u", ndr_get_array_size(ndr, &r->domain_name), ndr_get_array_length(ndr, &r->domain_name));
+                       }
+                       NDR_CHECK(ndr_check_string_terminator(ndr, ndr_get_array_length(ndr, &r->domain_name), sizeof(uint8_t)));
+                       NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, &r->domain_name, ndr_get_array_length(ndr, &r->domain_name), sizeof(uint8_t), CH_UTF8));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_domain_name_0, 0);
+               }
+               if (r->lm_password) {
+                       _mem_save_lm_password_0 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, r->lm_password, 0);
+                       NDR_CHECK(ndr_pull_samr_CryptPassword(ndr, NDR_SCALARS, r->lm_password));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_lm_password_0, 0);
+               }
+               if (r->lm_verifier) {
+                       _mem_save_lm_verifier_0 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, r->lm_verifier, 0);
+                       NDR_CHECK(ndr_pull_samr_Password(ndr, NDR_SCALARS, r->lm_verifier));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_lm_verifier_0, 0);
+               }
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ void ndr_print_STRUCT_winbind_auth_change_password_crypt_req(struct ndr_print *ndr, const char *name, const struct winbind_auth_change_password_crypt_req *r)
+{
+       ndr_print_struct(ndr, name, "winbind_auth_change_password_crypt_req");
+       ndr->depth++;
+       ndr_print_string(ndr, "account_name", r->account_name);
+       ndr_print_ptr(ndr, "domain_name", r->domain_name);
+       ndr->depth++;
+       if (r->domain_name) {
+               ndr_print_string(ndr, "domain_name", r->domain_name);
+       }
+       ndr->depth--;
+       ndr_print_samr_CryptPassword(ndr, "nt_password", &r->nt_password);
+       ndr_print_samr_Password(ndr, "nt_verifier", &r->nt_verifier);
+       ndr_print_ptr(ndr, "lm_password", r->lm_password);
+       ndr->depth++;
+       if (r->lm_password) {
+               ndr_print_samr_CryptPassword(ndr, "lm_password", r->lm_password);
+       }
+       ndr->depth--;
+       ndr_print_ptr(ndr, "lm_verifier", r->lm_verifier);
+       ndr->depth++;
+       if (r->lm_verifier) {
+               ndr_print_samr_Password(ndr, "lm_verifier", r->lm_verifier);
+       }
+       ndr->depth--;
+       ndr->depth--;
+}
+
 static enum ndr_err_code ndr_push_winbind_auth_req(struct ndr_push *ndr, int ndr_flags, const union winbind_auth_req *r)
 {
        if (ndr_flags & NDR_SCALARS) {
@@ -950,6 +1077,10 @@ static enum ndr_err_code ndr_push_winbind_auth_req(struct ndr_push *ndr, int ndr
                                NDR_CHECK(ndr_push_STRUCT_winbind_auth_change_password_plain_req(ndr, NDR_SCALARS, &r->change_password_plain));
                        break; }
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT: {
+                               NDR_CHECK(ndr_push_STRUCT_winbind_auth_change_password_crypt_req(ndr, NDR_SCALARS, &r->change_password_crypt));
+                       break; }
+
                        default: {
                        break; }
 
@@ -974,6 +1105,10 @@ static enum ndr_err_code ndr_push_winbind_auth_req(struct ndr_push *ndr, int ndr
                                NDR_CHECK(ndr_push_STRUCT_winbind_auth_change_password_plain_req(ndr, NDR_BUFFERS, &r->change_password_plain));
                        break;
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+                               NDR_CHECK(ndr_push_STRUCT_winbind_auth_change_password_crypt_req(ndr, NDR_BUFFERS, &r->change_password_crypt));
+                       break;
+
                        default:
                        break;
 
@@ -1009,6 +1144,10 @@ static enum ndr_err_code ndr_pull_winbind_auth_req(struct ndr_pull *ndr, int ndr
                                NDR_CHECK(ndr_pull_STRUCT_winbind_auth_change_password_plain_req(ndr, NDR_SCALARS, &r->change_password_plain));
                        break; }
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT: {
+                               NDR_CHECK(ndr_pull_STRUCT_winbind_auth_change_password_crypt_req(ndr, NDR_SCALARS, &r->change_password_crypt));
+                       break; }
+
                        default: {
                        break; }
 
@@ -1032,6 +1171,10 @@ static enum ndr_err_code ndr_pull_winbind_auth_req(struct ndr_pull *ndr, int ndr
                                NDR_CHECK(ndr_pull_STRUCT_winbind_auth_change_password_plain_req(ndr, NDR_BUFFERS, &r->change_password_plain));
                        break;
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+                               NDR_CHECK(ndr_pull_STRUCT_winbind_auth_change_password_crypt_req(ndr, NDR_BUFFERS, &r->change_password_crypt));
+                       break;
+
                        default:
                        break;
 
@@ -1062,6 +1205,10 @@ _PUBLIC_ void ndr_print_winbind_auth_req(struct ndr_print *ndr, const char *name
                        ndr_print_STRUCT_winbind_auth_change_password_plain_req(ndr, "change_password_plain", &r->change_password_plain);
                break;
 
+               case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+                       ndr_print_STRUCT_winbind_auth_change_password_crypt_req(ndr, "change_password_crypt", &r->change_password_crypt);
+               break;
+
                default:
                break;
 
@@ -1088,6 +1235,9 @@ static enum ndr_err_code ndr_push_winbind_auth_rep(struct ndr_push *ndr, int ndr
                        case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN: {
                        break; }
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT: {
+                       break; }
+
                        default: {
                        break; }
 
@@ -1110,6 +1260,9 @@ static enum ndr_err_code ndr_push_winbind_auth_rep(struct ndr_push *ndr, int ndr
                        case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN:
                        break;
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+                       break;
+
                        default:
                        break;
 
@@ -1143,6 +1296,9 @@ static enum ndr_err_code ndr_pull_winbind_auth_rep(struct ndr_pull *ndr, int ndr
                        case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN: {
                        break; }
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT: {
+                       break; }
+
                        default: {
                        break; }
 
@@ -1164,6 +1320,9 @@ static enum ndr_err_code ndr_pull_winbind_auth_rep(struct ndr_pull *ndr, int ndr
                        case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN:
                        break;
 
+                       case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+                       break;
+
                        default:
                        break;
 
@@ -1192,6 +1351,9 @@ _PUBLIC_ void ndr_print_winbind_auth_rep(struct ndr_print *ndr, const char *name
                case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_PLAIN:
                break;
 
+               case WINBIND_AUTH_LEVEL_CHANGE_PASSWORD_CRYPT:
+               break;
+
                default:
                break;
 
@@ -4038,47 +4200,6 @@ _PUBLIC_ void ndr_print_winbind_auth(struct ndr_print *ndr, const char *name, in
        ndr->depth--;
 }
 
-static enum ndr_err_code ndr_push_winbind_pam_chng_paswd_auth_crap(struct ndr_push *ndr, int flags, const struct winbind_pam_chng_paswd_auth_crap *r)
-{
-       if (flags & NDR_IN) {
-       }
-       if (flags & NDR_OUT) {
-               NDR_CHECK(ndr_push_winbind_status(ndr, NDR_SCALARS, r->out.result));
-       }
-       return NDR_ERR_SUCCESS;
-}
-
-static enum ndr_err_code ndr_pull_winbind_pam_chng_paswd_auth_crap(struct ndr_pull *ndr, int flags, struct winbind_pam_chng_paswd_auth_crap *r)
-{
-       if (flags & NDR_IN) {
-       }
-       if (flags & NDR_OUT) {
-               NDR_CHECK(ndr_pull_winbind_status(ndr, NDR_SCALARS, &r->out.result));
-       }
-       return NDR_ERR_SUCCESS;
-}
-
-_PUBLIC_ void ndr_print_winbind_pam_chng_paswd_auth_crap(struct ndr_print *ndr, const char *name, int flags, const struct winbind_pam_chng_paswd_auth_crap *r)
-{
-       ndr_print_struct(ndr, name, "winbind_pam_chng_paswd_auth_crap");
-       ndr->depth++;
-       if (flags & NDR_SET_VALUES) {
-               ndr->flags |= LIBNDR_PRINT_SET_VALUES;
-       }
-       if (flags & NDR_IN) {
-               ndr_print_struct(ndr, "in", "winbind_pam_chng_paswd_auth_crap");
-               ndr->depth++;
-               ndr->depth--;
-       }
-       if (flags & NDR_OUT) {
-               ndr_print_struct(ndr, "out", "winbind_pam_chng_paswd_auth_crap");
-               ndr->depth++;
-               ndr_print_winbind_status(ndr, "result", r->out.result);
-               ndr->depth--;
-       }
-       ndr->depth--;
-}
-
 static enum ndr_err_code ndr_push_winbind_list_users(struct ndr_push *ndr, int flags, const struct winbind_list_users *r)
 {
        if (flags & NDR_IN) {
@@ -5360,14 +5481,6 @@ static const struct ndr_interface_call winbind_protocol_calls[] = {
                (ndr_print_function_t) ndr_print_winbind_auth,
                false,
        },
-       {
-               "winbind_pam_chng_paswd_auth_crap",
-               sizeof(struct winbind_pam_chng_paswd_auth_crap),
-               (ndr_push_flags_fn_t) ndr_push_winbind_pam_chng_paswd_auth_crap,
-               (ndr_pull_flags_fn_t) ndr_pull_winbind_pam_chng_paswd_auth_crap,
-               (ndr_print_function_t) ndr_print_winbind_pam_chng_paswd_auth_crap,
-               false,
-       },
        {
                "winbind_list_users",
                sizeof(struct winbind_list_users),
@@ -5549,7 +5662,7 @@ const struct ndr_interface_table ndr_table_winbind_protocol = {
                NDR_WINBIND_PROTOCOL_VERSION
        },
        .helpstring     = NDR_WINBIND_PROTOCOL_HELPSTRING,
-       .num_calls      = 34,
+       .num_calls      = 33,
        .calls          = winbind_protocol_calls,
        .endpoints      = &winbind_protocol_endpoints,
        .authservices   = &winbind_protocol_authservices