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

io.hekate.network.NetworkServerHandlerConfig Maven / Gradle / Ivy

/*
 * Copyright 2022 The Hekate Project
 *
 * The Hekate Project 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 io.hekate.network;

import io.hekate.codec.CodecFactory;
import io.hekate.util.format.ToString;

/**
 * Configuration for {@link NetworkServerHandler}.
 *
 * @param  Base type of messages that can be processed by {@link NetworkServerHandler}.
 *
 * @see NetworkServerHandler
 */
public class NetworkServerHandlerConfig {
    private String protocol;

    private CodecFactory codecFactory;

    private NetworkServerHandler handler;

    private String loggerCategory;

    /**
     * Returns the protocol identifier (see {@link #setProtocol(String)}).
     *
     * @return Protocol identifier.
     */
    public String getProtocol() {
        return protocol;
    }

    /**
     * Sets the connector protocol identifier. Can contain only alpha-numeric characters and non-repeatable dots/hyphens.
     *
     * 

* Only clients that have the same {@link NetworkConnectorConfig#setProtocol(String) protocol identifier} will be processed by the * {@link #setHandler(NetworkServerHandler) configured} {@link NetworkServerHandler}. *

* *

* This parameter is mandatory and doesn't have a default value. *

* *

* Note: Protocol identifier must be unique across all registered {@link NetworkServerHandlerConfig}s within the {@link * NetworkServer}. *

* * @param protocol Protocol identifier (can contain only alpha-numeric characters and non-repeatable dots/hyphens). */ public void setProtocol(String protocol) { this.protocol = protocol; } /** * Fluent-style version of {@link #setProtocol(String)}. * * @param protocol Protocol identifier. * * @return This instance. */ public NetworkServerHandlerConfig withProtocol(String protocol) { setProtocol(protocol); return this; } /** * Returns the codec factory that should be used for messages serialization (see {@link #setCodecFactory(CodecFactory)}). * * @return Codec factory. */ public CodecFactory getCodecFactory() { return codecFactory; } /** * Sets the codec factory that should be used for messages serialization. * *

* Only messages that are supported by the specified {@link CodecFactory} can be sent/received by the configured {@link * NetworkServerHandler}. Note that the same factory must be configured on the * {@link NetworkConnectorConfig#setMessageCodec(CodecFactory) client side}. *

* *

* This parameter is mandatory and doesn't have a default value. *

* * @param codecFactory Codec factory. */ public void setCodecFactory(CodecFactory codecFactory) { this.codecFactory = codecFactory; } /** * Fluent-style version of {@link #setCodecFactory(CodecFactory)}. * * @param codecFactory Codec factory. * * @return This instance. */ public NetworkServerHandlerConfig withCodecFactory(CodecFactory codecFactory) { setCodecFactory(codecFactory); return this; } /** * Returns the handler (see {@link #setHandler(NetworkServerHandler)}. * * @return Handler. */ public NetworkServerHandler getHandler() { return handler; } /** * Sets the handler. * * @param handler Handler. */ public void setHandler(NetworkServerHandler handler) { this.handler = handler; } /** * Fluent-style version of {@link #setHandler(NetworkServerHandler)}. * * @param handler Handler. * * @return This instance. */ public NetworkServerHandlerConfig withHandler(NetworkServerHandler handler) { setHandler(handler); return this; } /** * Returns the logger category that should be used by {@link NetworkServerHandler} (see {@link #setLoggerCategory(String)}). * * @return Logger category. */ public String getLoggerCategory() { return loggerCategory; } /** * Sets the logger category that should be used by {@link NetworkServerHandler}. * * @param loggerCategory Logger category. */ public void setLoggerCategory(String loggerCategory) { this.loggerCategory = loggerCategory; } /** * Fluent-style version of {@link #setLoggerCategory(String)}. * * @param loggerCategory Logger category. * * @return This instance. */ public NetworkServerHandlerConfig withLoggerCategory(String loggerCategory) { setLoggerCategory(loggerCategory); return this; } @Override public String toString() { return ToString.format(this); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy