Path: blob/main/crypto/krb5/src/tests/gssapi/t_ciflags.c
34907 views
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */1/* tests/gssapi/t_ciflags.c - GSS_KRB5_CRED_NO_CI_FLAGS_X tests */2/*3* Copyright (C) 2015 by the Massachusetts Institute of Technology.4* All rights reserved.5*6* Redistribution and use in source and binary forms, with or without7* modification, are permitted provided that the following conditions8* are met:9*10* * Redistributions of source code must retain the above copyright11* notice, this list of conditions and the following disclaimer.12*13* * Redistributions in binary form must reproduce the above copyright14* notice, this list of conditions and the following disclaimer in15* the documentation and/or other materials provided with the16* distribution.17*18* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS19* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT20* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS21* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE22* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,23* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES24* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR25* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)26* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,27* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)28* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED29* OF THE POSSIBILITY OF SUCH DAMAGE.30*/3132#include <stdio.h>33#include <stdlib.h>34#include <assert.h>3536#include "common.h"3738static void39flagtest(gss_OID mech, gss_cred_id_t icred, gss_name_t tname,40OM_uint32 inflags, OM_uint32 expflags)41{42gss_ctx_id_t ictx, actx;43OM_uint32 major, minor, flags;4445establish_contexts(mech, icred, GSS_C_NO_CREDENTIAL, tname, inflags, &ictx,46&actx, NULL, NULL, NULL);4748major = gss_inquire_context(&minor, actx, NULL, NULL, NULL, NULL, &flags,49NULL, NULL);50check_gsserr("gss_inquire_context", major, minor);51assert(flags == expflags);5253(void)gss_delete_sec_context(&minor, &ictx, NULL);54(void)gss_delete_sec_context(&minor, &actx, NULL);55}5657int58main(int argc, char *argv[])59{60OM_uint32 minor, major;61gss_cred_id_t icred;62gss_name_t tname;63gss_buffer_desc empty_buffer = GSS_C_EMPTY_BUFFER;6465if (argc != 2) {66fprintf(stderr, "Usage: %s targetname\n", argv[0]);67return 1;68}69tname = import_name(argv[1]);7071/* With no flags, the initiator asserts conf, integ, trans */72flagtest(&mech_krb5, GSS_C_NO_CREDENTIAL, tname, 0,73GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);74flagtest(&mech_spnego, GSS_C_NO_CREDENTIAL, tname, 0,75GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);7677/* The initiator also asserts most flags specified by the caller. */78flagtest(&mech_krb5, GSS_C_NO_CREDENTIAL, tname, GSS_C_SEQUENCE_FLAG,79GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG |80GSS_C_SEQUENCE_FLAG);81flagtest(&mech_spnego, GSS_C_NO_CREDENTIAL, tname, GSS_C_SEQUENCE_FLAG,82GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG |83GSS_C_SEQUENCE_FLAG);8485/* Get a normal initiator cred and re-test with no flags. */86major = gss_acquire_cred(&minor, GSS_C_NO_NAME, GSS_C_INDEFINITE,87GSS_C_NO_OID_SET, GSS_C_INITIATE, &icred, NULL,88NULL);89check_gsserr("gss_acquire_cred", major, minor);90flagtest(&mech_krb5, icred, tname, 0,91GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);92flagtest(&mech_spnego, icred, tname, 0,93GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);9495/* Suppress confidentiality and integrity flags on the initiator cred and96* check that they are suppressed, but can still be asserted explicitly. */97major = gss_set_cred_option(&minor, &icred,98(gss_OID)GSS_KRB5_CRED_NO_CI_FLAGS_X,99&empty_buffer);100check_gsserr("gss_set_cred_option", major, minor);101flagtest(&mech_krb5, icred, tname, 0, GSS_C_TRANS_FLAG);102flagtest(&mech_krb5, icred, tname, GSS_C_CONF_FLAG,103GSS_C_CONF_FLAG | GSS_C_TRANS_FLAG);104flagtest(&mech_krb5, icred, tname, GSS_C_INTEG_FLAG,105GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);106flagtest(&mech_krb5, icred, tname, GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG,107GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);108flagtest(&mech_spnego, icred, tname, 0, GSS_C_TRANS_FLAG);109flagtest(&mech_spnego, icred, tname, GSS_C_INTEG_FLAG,110GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);111flagtest(&mech_spnego, icred, tname, GSS_C_CONF_FLAG,112GSS_C_CONF_FLAG | GSS_C_TRANS_FLAG);113flagtest(&mech_spnego, icred, tname, GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG,114GSS_C_CONF_FLAG | GSS_C_INTEG_FLAG | GSS_C_TRANS_FLAG);115116(void)gss_release_name(&minor, &tname);117(void)gss_release_cred(&minor, &icred);118return 0;119}120121122