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

com.netflix.msl.msg.ServerReceiveMessageContext Maven / Gradle / Ivy

There is a newer version: 1.2226.0
Show newest version
/**
 * Copyright (c) 2017 Netflix, Inc.  All rights reserved.
 *
 * Licensed 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 com.netflix.msl.msg;

import java.io.IOException;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import com.netflix.msl.MslKeyExchangeException;
import com.netflix.msl.crypto.ICryptoContext;
import com.netflix.msl.keyx.KeyRequestData;
import com.netflix.msl.tokens.MslUser;
import com.netflix.msl.userauth.UserAuthenticationData;

/**
 * 

A trusted services network message context used to receive client * messages suitable for use with * {@link MslControl#receive(com.netflix.msl.util.MslContext, MessageContext, java.io.InputStream, java.io.OutputStream, int)}. * Since this message context is only used for receiving messages, it cannot be * used to send application data back to the client and does not require * encryption or integrity protection.

* *

The application may wish to override * {@link #updateServiceTokens(MessageServiceTokenBuilder, boolean)} to * modify any service tokens sent in handshake responses.

* * @author Wesley Miaw */ public class ServerReceiveMessageContext extends PublicMessageContext { /** *

Create a new receive message context.

* * @param cryptoContexts service token crypto contexts. May be * {@code null}. * @param dbgCtx optional message debug context. May be {@code null}. */ public ServerReceiveMessageContext(final Map cryptoContexts, final MessageDebugContext dbgCtx) { this.cryptoContexts = (cryptoContexts != null) ? new HashMap(cryptoContexts) : new HashMap(); this.dbgCtx = dbgCtx; } @Override public Map getCryptoContexts() { return Collections.unmodifiableMap(cryptoContexts); } @Override public String getRemoteEntityIdentity() { return null; } @Override public boolean isRequestingTokens() { return false; } @Override public String getUserId() { return null; } @Override public UserAuthenticationData getUserAuthData(final ReauthCode reauthCode, final boolean renewable, final boolean required) { return null; } @Override public MslUser getUser() { return null; } @Override public Set getKeyRequestData() throws MslKeyExchangeException { return Collections.emptySet(); } @Override public void updateServiceTokens(final MessageServiceTokenBuilder builder, final boolean handshake) { } @Override public void write(final MessageOutputStream output) throws IOException { } @Override public MessageDebugContext getDebugContext() { return dbgCtx; } /** Service token crypto contexts. */ protected final Map cryptoContexts; /** Message debug context. */ protected final MessageDebugContext dbgCtx; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy