blob: 7f7ac92cb38ef21c18c8b82228e69ff8c6dc0b2c [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*/
package org.apache.kerby.kerberos.kerb.client.preauth;
import org.apache.kerby.KOptions;
import org.apache.kerby.kerberos.kerb.KrbException;
import org.apache.kerby.kerberos.kerb.client.KrbContext;
import org.apache.kerby.kerberos.kerb.client.request.KdcRequest;
import org.apache.kerby.kerberos.kerb.preauth.PaFlags;
import org.apache.kerby.kerberos.kerb.preauth.PluginRequestContext;
import org.apache.kerby.kerberos.kerb.preauth.PreauthPluginMeta;
import org.apache.kerby.kerberos.kerb.type.base.EncryptionType;
import org.apache.kerby.kerberos.kerb.type.pa.PaData;
import org.apache.kerby.kerberos.kerb.type.pa.PaDataEntry;
import org.apache.kerby.kerberos.kerb.type.pa.PaDataType;
import java.util.List;
/**
* Client side preauth plugin module
*/
public interface KrbPreauth extends PreauthPluginMeta {
/**
* Initializing preauth plugin context
* @param krbContext The krb context
*/
void init(KrbContext krbContext);
/**
* Initializing request context
* @param kdcRequest The kdc request
* @return PluginRequestContext
*/
PluginRequestContext initRequestContext(KdcRequest kdcRequest);
/**
* Prepare questions to prompt to you asking for credential
* @param kdcRequest The kdc request
* @param requestContext The request context
* @throws KrbException e
*/
void prepareQuestions(KdcRequest kdcRequest,
PluginRequestContext requestContext) throws KrbException;
/**
* Get supported encryption types
* @param kdcRequest The kdc request
* @param requestContext The request context
* @return The encryption type list
*/
List<EncryptionType> getEncTypes(KdcRequest kdcRequest,
PluginRequestContext requestContext);
/**
* Set krb options passed from user
* @param kdcRequest The kdc request
* @param requestContext The request context
* @param preauthOptions The preauth options
*/
void setPreauthOptions(KdcRequest kdcRequest,
PluginRequestContext requestContext,
KOptions preauthOptions);
/**
* Attempt to try any initial padata derived from user options
* @param kdcRequest The kdc request
* @param requestContext The request context
* @param outPadata The outPadata
* @throws KrbException e
*/
void tryFirst(KdcRequest kdcRequest,
PluginRequestContext requestContext,
PaData outPadata) throws KrbException;
/**
* Process server returned paData and return back any result paData
* @param kdcRequest The kdc request
* @param requestContext The request context
* @param inPadata The inPadata
* @param outPadata The outPadata
* @return true indicating padata is added
* @throws KrbException e
*/
boolean process(KdcRequest kdcRequest,
PluginRequestContext requestContext,
PaDataEntry inPadata,
PaData outPadata) throws KrbException;
/**
* When another request to server in the 4 pass, any paData to provide?
* @param kdcRequest The kdc request
* @param requestContext The request context
* @param preauthType The preauth type
* @param errPadata The error padata
* @param outPadata The outPadata
* @return true indicating padata is added
*/
boolean tryAgain(KdcRequest kdcRequest,
PluginRequestContext requestContext,
PaDataType preauthType,
PaData errPadata,
PaData outPadata);
/**
* Return PA_REAL if pa_type is a real preauthentication type or PA_INFO if it is
* an informational type.
* @param paType The pa_type
* @return PaFlags
*/
PaFlags getFlags(PaDataType paType);
/**
* When exiting...
*/
void destroy();
}