1 /*
   2  * Copyright (c) 2010, 2011, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  */
  23 
  24 /*
  25  * @test
  26  * @bug 6960894
  27  * @summary Better AS-REQ creation and processing
  28  * @run main/othervm NewSalt
  29  * @run main/othervm -Dnopreauth NewSalt
  30  * @run main/othervm -Donlyonepreauth NewSalt
  31  */
  32 
  33 import sun.security.jgss.GSSUtil;
  34 import sun.security.krb5.Config;
  35 
  36 public class NewSalt {
  37 
  38     public static void main(String[] args)
  39             throws Exception {
  40 
  41         // Create and start the KDC
  42         KDC kdc = new OneKDC(null);
  43         if (System.getProperty("onlyonepreauth") != null) {
  44             KDC.saveConfig(OneKDC.KRB5_CONF, kdc,
  45                     "default_tgs_enctypes=des3-cbc-sha1");
  46             Config.refresh();
  47             kdc.setOption(KDC.Option.ONLY_ONE_PREAUTH, true);
  48         }
  49         if (System.getProperty("nopreauth") != null) {
  50             kdc.setOption(KDC.Option.PREAUTH_REQUIRED, false);
  51         }
  52 
  53         // Use a different case of name. KDC will return correct salt
  54         Context c1 = Context.fromUserPass(OneKDC.USER.toUpperCase(),
  55                 OneKDC.PASS, true);
  56         Context c2 = Context.fromUserPass(OneKDC.USER2.toUpperCase(),
  57                 OneKDC.PASS2, true);
  58 
  59         c1.startAsClient(OneKDC.USER2, GSSUtil.GSS_KRB5_MECH_OID);
  60         c2.startAsServer(GSSUtil.GSS_KRB5_MECH_OID);
  61 
  62         Context.handshake(c1, c2);
  63     }
  64 }