Path: blob/main/crypto/heimdal/lib/kadm5/chpass_c.c
34889 views
/*1* Copyright (c) 1997-2000, 2005-2006 Kungliga Tekniska Högskolan2* (Royal Institute of Technology, Stockholm, Sweden).3* All rights reserved.4*5* Redistribution and use in source and binary forms, with or without6* modification, are permitted provided that the following conditions7* are met:8*9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11*12* 2. Redistributions in binary form must reproduce the above copyright13* notice, this list of conditions and the following disclaimer in the14* documentation and/or other materials provided with the distribution.15*16* 3. Neither the name of the Institute nor the names of its contributors17* may be used to endorse or promote products derived from this software18* without specific prior written permission.19*20* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE23* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF30* SUCH DAMAGE.31*/3233#include "kadm5_locl.h"3435RCSID("$Id$");3637kadm5_ret_t38kadm5_c_chpass_principal(void *server_handle,39krb5_principal princ,40const char *password)41{42kadm5_client_context *context = server_handle;43kadm5_ret_t ret;44krb5_storage *sp;45unsigned char buf[1024];46int32_t tmp;47krb5_data reply;4849ret = _kadm5_connect(server_handle);50if(ret)51return ret;5253sp = krb5_storage_from_mem(buf, sizeof(buf));54if (sp == NULL) {55krb5_clear_error_message(context->context);56return ENOMEM;57}58krb5_store_int32(sp, kadm_chpass);59krb5_store_principal(sp, princ);60krb5_store_string(sp, password);61ret = _kadm5_client_send(context, sp);62krb5_storage_free(sp);63if (ret)64return ret;65ret = _kadm5_client_recv(context, &reply);66if(ret)67return ret;68sp = krb5_storage_from_data (&reply);69if (sp == NULL) {70krb5_clear_error_message(context->context);71krb5_data_free (&reply);72return ENOMEM;73}74krb5_ret_int32(sp, &tmp);75krb5_clear_error_message(context->context);76krb5_storage_free(sp);77krb5_data_free (&reply);78return tmp;79}8081kadm5_ret_t82kadm5_c_chpass_principal_with_key(void *server_handle,83krb5_principal princ,84int n_key_data,85krb5_key_data *key_data)86{87kadm5_client_context *context = server_handle;88kadm5_ret_t ret;89krb5_storage *sp;90unsigned char buf[1024];91int32_t tmp;92krb5_data reply;93int i;9495ret = _kadm5_connect(server_handle);96if(ret)97return ret;9899sp = krb5_storage_from_mem(buf, sizeof(buf));100if (sp == NULL) {101krb5_clear_error_message(context->context);102return ENOMEM;103}104krb5_store_int32(sp, kadm_chpass_with_key);105krb5_store_principal(sp, princ);106krb5_store_int32(sp, n_key_data);107for (i = 0; i < n_key_data; ++i)108kadm5_store_key_data (sp, &key_data[i]);109ret = _kadm5_client_send(context, sp);110krb5_storage_free(sp);111if (ret)112return ret;113ret = _kadm5_client_recv(context, &reply);114if(ret)115return ret;116sp = krb5_storage_from_data (&reply);117if (sp == NULL) {118krb5_clear_error_message(context->context);119krb5_data_free (&reply);120return ENOMEM;121}122krb5_ret_int32(sp, &tmp);123krb5_clear_error_message(context->context);124krb5_storage_free(sp);125krb5_data_free (&reply);126return tmp;127}128129130