FileDocCategorySizeDatePackage
MessageProp.javaAPI DocJava SE 6 API6345Tue Jun 10 00:27:18 BST 2008org.ietf.jgss

MessageProp

public class MessageProp extends Object
This is a utility class used within the per-message GSSContext methods to convey per-message properties.

When used with the GSSContext interface's wrap and getMIC methods, an instance of this class is used to indicate the desired Quality-of-Protection (QOP) and to request if confidentiality services are to be applied to caller supplied data (wrap only). To request default QOP, the value of 0 should be used for QOP.

When used with the unwrap and verifyMIC methods of the GSSContext interface, an instance of this class will be used to indicate the applied QOP and confidentiality services over the supplied message. In the case of verifyMIC, the confidentiality state will always be false. Upon return from these methods, this object will also contain any supplementary status values applicable to the processed token. The supplementary status values can indicate old tokens, out of sequence tokens, gap tokens or duplicate tokens.

see
GSSContext#wrap
see
GSSContext#unwrap
see
GSSContext#getMIC
see
GSSContext#verifyMIC
author
Mayank Upadhyay
version
1.10, 11/17/05
since
1.4

Fields Summary
private boolean
privacyState
private int
qop
private boolean
dupToken
private boolean
oldToken
private boolean
unseqToken
private boolean
gapToken
private int
minorStatus
private String
minorString
Constructors Summary
public MessageProp(boolean privState)
Constructor which sets the desired privacy state. The QOP value used is 0.

param
privState the privacy (i.e. confidentiality) state

        this(0, privState);
    
public MessageProp(int qop, boolean privState)
Constructor which sets the values for the qop and privacy state.

param
qop the QOP value
param
privState the privacy (i.e. confidentiality) state

        this.qop = qop;
        this.privacyState = privState;
        resetStatusValues();
    
Methods Summary
public intgetMinorStatus()
Retrieves the minor status code that the underlying mechanism might have set for this per-message operation.

return
the int minor status

        return minorStatus;
    
public java.lang.StringgetMinorString()
Retrieves a string explaining the minor status code.

return
a String corresponding to the minor status code. null will be returned when no minor status code has been set.

        return minorString;
    
public booleangetPrivacy()
Retrieves the privacy state.

return
true if the privacy (i.e., confidentiality) state is true, false otherwise.
see
#setPrivacy

    
        return (privacyState);
    
public intgetQOP()
Retrieves the QOP value.

return
an int representing the QOP value
see
#setQOP

        return qop;
    
public booleanisDuplicateToken()
Tests if this is a duplicate of an earlier token.

return
true if this is a duplicate, false otherwise.

        return dupToken;
    
public booleanisGapToken()
Tests if an expected token was not received, i.e., one or more predecessor tokens have not yet been successfully processed.

return
true if an expected per-message token was not received, false otherwise.

        return gapToken;
    
public booleanisOldToken()
Tests if this token's validity period has expired, i.e., the token is too old to be checked for duplication.

return
true if the token's validity period has expired, false otherwise.

        return oldToken;
    
public booleanisUnseqToken()
Tests if a later token had already been processed.

return
true if a later token had already been processed, false otherwise.

        return unseqToken;
    
private voidresetStatusValues()
Resets the supplementary status values to false.

        dupToken = false;
        oldToken = false;
        unseqToken = false;
        gapToken = false;
        minorStatus = 0;
        minorString = null;
    
public voidsetPrivacy(boolean privState)
Sets the privacy state.

param
privState true is the privacy (i.e., confidentiality) state is true, false otherwise.
see
#getPrivacy

    
        this.privacyState = privState;
    
public voidsetQOP(int qop)
Sets the QOP value.

param
qop the int value to set the QOP to
see
#getQOP

        this.qop = qop;
    
public voidsetSupplementaryStates(boolean duplicate, boolean old, boolean unseq, boolean gap, int minorStatus, java.lang.String minorString)
This method sets the state for the supplementary information flags and the minor status in MessageProp. It is not used by the application but by the GSS implementation to return this information to the caller of a per-message context method.

param
duplicate true if the token was a duplicate of an earlier token, false otherwise
param
old true if the token's validity period has expired, false otherwise
param
unseq true if a later token has already been processed, false otherwise
param
gap true if one or more predecessor tokens have not yet been successfully processed, false otherwise
param
minorStatus the int minor status code for the per-message operation
param
minorString the textual representation of the minorStatus value

       this.dupToken = duplicate;
       this.oldToken = old;
       this.unseqToken = unseq;
       this.gapToken = gap;
       this.minorStatus = minorStatus;
       this.minorString = minorString;