/*
 * Copyright 2012-2020 the original author or authors.
 *
 * 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
 *
 *      https://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.springframework.boot.rsocket.server;

import java.net.InetAddress;

import org.springframework.boot.web.server.Ssl;
import org.springframework.boot.web.server.SslStoreProvider;
import org.springframework.util.unit.DataSize;

A configurable RSocketServerFactory.
Author:Brian Clozel
Since:2.2.0
/** * A configurable {@link RSocketServerFactory}. * * @author Brian Clozel * @since 2.2.0 */
public interface ConfigurableRSocketServerFactory {
Set the port that the server should listen on. If not specified port '9898' will be used.
Params:
  • port – the port to set
/** * Set the port that the server should listen on. If not specified port '9898' will be * used. * @param port the port to set */
void setPort(int port);
Specify the maximum transmission unit. Frames larger than the specified fragmentSize are fragmented.
Params:
  • fragmentSize – the fragment size
Since:2.4.0
/** * Specify the maximum transmission unit. Frames larger than the specified * {@code fragmentSize} are fragmented. * @param fragmentSize the fragment size * @since 2.4.0 */
void setFragmentSize(DataSize fragmentSize);
Set the specific network address that the server should bind to.
Params:
  • address – the address to set (defaults to null)
/** * Set the specific network address that the server should bind to. * @param address the address to set (defaults to {@code null}) */
void setAddress(InetAddress address);
Set the transport that the RSocket server should use.
Params:
  • transport – the transport protocol to use
/** * Set the transport that the RSocket server should use. * @param transport the transport protocol to use */
void setTransport(RSocketServer.Transport transport);
Sets the SSL configuration that will be applied to the server's default connector.
Params:
  • ssl – the SSL configuration
/** * Sets the SSL configuration that will be applied to the server's default connector. * @param ssl the SSL configuration */
void setSsl(Ssl ssl);
Sets a provider that will be used to obtain SSL stores.
Params:
  • sslStoreProvider – the SSL store provider
/** * Sets a provider that will be used to obtain SSL stores. * @param sslStoreProvider the SSL store provider */
void setSslStoreProvider(SslStoreProvider sslStoreProvider); }