All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.wss4j.common.derivedKey.ConversationConstants Maven / Gradle / Ivy

There is a newer version: 3.0.4
Show newest version
/**
 * 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.wss4j.common.derivedKey;

import javax.xml.namespace.QName;

import org.apache.wss4j.common.ext.WSSecurityException;

/**
 * Class ConversationConstants
 */
public final class ConversationConstants {

    public static final int VERSION_05_02 = 1;

    public static final int VERSION_05_12 = 2;

    public static final int DEFAULT_VERSION = VERSION_05_12;

    /**
     * WS-SecConv Feb 2005 version
     */
    public static final String WSC_NS_05_02 = "http://schemas.xmlsoap.org/ws/2005/02/sc";

    /**
     * WS-Sx version
     */
    public static final String WSC_NS_05_12 =
        "http://docs.oasis-open.org/ws-sx/ws-secureconversation/200512";

    /**
     * Token type of DerivedKeyToken
     */
    public static final String TOKEN_TYPE_DERIVED_KEY_TOKEN = "/dk";

    /**
     * Token type of SecurityContextToken
     */
    public static final String TOKEN_TYPE_SECURITY_CONTEXT_TOKEN = "/sct";

    /**
     * Field WSC_PREFIX
     */
    public static final String WSC_PREFIX = "wsc";

    /**
     * Field SECURITY_CONTEXT_TOKEN_LN
     */
    public static final String SECURITY_CONTEXT_TOKEN_LN =
            "SecurityContextToken";

    /**
     * Field IDENTIFIER_LN
     */
    public static final String IDENTIFIER_LN = "Identifier";

    /**
     * Field INSTANCE_LN
     */
    public static final String INSTANCE_LN = "Instance";

    /**
     * Field EXPIRES_LN
     */
    public static final String EXPIRES_LN = "Expires";

    /**
     * Field KEYS_LN
     */
    public static final String KEYS_LN = "Keys";

    /**
     * Field SECURITY_TOKEN_REFERENCE_LN
     */
    public static final String SECURITY_TOKEN_REFERENCE_LN =
            "SecurityTokenReference";

    /**
     * Field DERIVED_KEY_TOKEN_LN
     */
    public static final String DERIVED_KEY_TOKEN_LN = "DerivedKeyToken";

    /**
     * Field PROPERTIES_LN
     */
    public static final String PROPERTIES_LN = "Properties";

    /**
     * Field LENGTH_LN
     */
    public static final String LENGTH_LN = "Length";

    /**
     * Field GENERATION_LN
     */
    public static final String GENERATION_LN = "Generation";

    /**
     * Field OFFSET_LN
     */
    public static final String OFFSET_LN = "Offset";

    /**
     * Field LABEL_LN
     */
    public static final String LABEL_LN = "Label";

    /**
     * Field NONCE_LN
     */
    public static final String NONCE_LN = "Nonce";

    public static final int DIRECT_GENERATED = 1;
    public static final int STS_GENERATED = 2;
    public static final int STSREQUEST_TOKEN = 3;
    public static final int INTEROP_SCENE1 = 4;

    public static final String IDENTIFIER = "SCT_Identifier";

    public static final int DK_SIGN = 1;
    public static final int DK_ENCRYPT = 2;

    public static final String DEFAULT_LABEL = "WS-SecureConversation";

    public static final QName SECURITY_CTX_TOKEN_QNAME_05_02 =
        new QName(
            ConversationConstants.WSC_NS_05_02,
            ConversationConstants.SECURITY_CONTEXT_TOKEN_LN
        );

    public static final QName SECURITY_CTX_TOKEN_QNAME_05_12 =
        new QName(
            ConversationConstants.WSC_NS_05_12,
            ConversationConstants.SECURITY_CONTEXT_TOKEN_LN
        );

    public static final QName DERIVED_KEY_TOKEN_QNAME_05_02 =
        new QName(
            ConversationConstants.WSC_NS_05_02,
            ConversationConstants.DERIVED_KEY_TOKEN_LN
        );

    public static final QName DERIVED_KEY_TOKEN_QNAME_05_12 =
        new QName(
            ConversationConstants.WSC_NS_05_12,
            ConversationConstants.DERIVED_KEY_TOKEN_LN
        );

    /**
     * Key to hold the map of security context identifiers against the
     * service epr addresses (service scope) or wsa:Action values (operation
     * scope).
     */
    public static final String KEY_CONTEXT_MAP = "contextMap";

    private ConversationConstants() {
        // Complete
    }

    public interface DerivationAlgorithm {
        String P_SHA_1 =
            "http://schemas.xmlsoap.org/ws/2005/02/sc/dk/p_sha1";

        String P_SHA_1_2005_12 =
            "http://docs.oasis-open.org/ws-sx/ws-secureconversation/200512/dk/p_sha1";

        byte[] createKey(byte[] secret, byte[] seed, int offset, long length)
            throws WSSecurityException;
    }

    public static String getWSCNs(int version) {
        if (VERSION_05_02 == version) {
            return WSC_NS_05_02;
        } else {
            return WSC_NS_05_12;
        }
    }

    public static int getWSTVersion(String ns) {
        if (WSC_NS_05_02.equals(ns)) {
            return VERSION_05_02;
        } else {
            return VERSION_05_12;
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy