/* * Microsoft JDBC Driver for SQL Server * * Copyright(c) Microsoft Corporation All rights reserved. * * This program is made available under the terms of the MIT License. See the LICENSE file in the project root for more information. */ package com.microsoft.sqlserver.jdbc; import java.util.HashMap; import java.util.Map; import javax.security.auth.login.AppConfigurationEntry; import javax.security.auth.login.Configuration; /** * This class overrides JAAS Configuration and always provide a configuration is not defined for default configuration. */ public class JaasConfiguration extends Configuration { private final Configuration delegate; private AppConfigurationEntry[] defaultValue; private static AppConfigurationEntry[] generateDefaultConfiguration() { if (Util.isIBM()) { Map<String, String> confDetailsWithoutPassword = new HashMap<String, String>(); confDetailsWithoutPassword.put("useDefaultCcache", "true"); Map<String, String> confDetailsWithPassword = new HashMap<String, String>(); // We generated a two configurations fallback that is suitable for password and password-less authentication // See https://www.ibm.com/support/knowledgecenter/SSYKE2_8.0.0/com.ibm.java.security.component.80.doc/security-component/jgssDocs/jaas_login_user.html final String ibmLoginModule = "com.ibm.security.auth.module.Krb5LoginModule"; return new AppConfigurationEntry[] { new AppConfigurationEntry(ibmLoginModule, AppConfigurationEntry.LoginModuleControlFlag.SUFFICIENT, confDetailsWithoutPassword), new AppConfigurationEntry(ibmLoginModule, AppConfigurationEntry.LoginModuleControlFlag.SUFFICIENT, confDetailsWithPassword)}; } else { Map<String, String> confDetails = new HashMap<String, String>(); confDetails.put("useTicketCache", "true"); return new AppConfigurationEntry[] {new AppConfigurationEntry("com.sun.security.auth.module.Krb5LoginModule", AppConfigurationEntry.LoginModuleControlFlag.REQUIRED, confDetails)}; } } /** * Package protected constructor. * * @param delegate * a possibly null delegate */ JaasConfiguration(Configuration delegate) { this.delegate = delegate; this.defaultValue = generateDefaultConfiguration(); } @Override public AppConfigurationEntry[] getAppConfigurationEntry(String name) { AppConfigurationEntry[] conf = delegate == null ? null : delegate.getAppConfigurationEntry(name); // We return our configuration only if user requested default one // In case where user did request another JAAS Configuration name, we expect he knows what he is doing. if (conf == null && name.equals(SQLServerDriverStringProperty.JAAS_CONFIG_NAME.getDefaultValue())) { return defaultValue; } return conf; } }