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

io.vertx.kotlin.core.VertxOptions.kt Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright 2019 Red Hat, Inc.
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Apache License v2.0 which accompanies this distribution.
 *
 * The Eclipse Public License is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * The Apache License v2.0 is available at
 * http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */
package io.vertx.kotlin.core

import io.vertx.core.VertxOptions
import io.vertx.core.dns.AddressResolverOptions
import io.vertx.core.eventbus.EventBusOptions
import io.vertx.core.file.FileSystemOptions
import io.vertx.core.metrics.MetricsOptions
import io.vertx.core.tracing.TracingOptions
import java.util.concurrent.TimeUnit

/**
 * A function providing a DSL for building [io.vertx.core.VertxOptions] objects.
 *
 * Instances of this class are used to configure [io.vertx.core.Vertx] instances.
 *
 * @param addressResolverOptions  Sets the address resolver configuration to configure resolving DNS servers, cache TTL, etc...
 * @param blockedThreadCheckInterval  Sets the value of blocked thread check period, in [io.vertx.core.VertxOptions]. 

The default value of [io.vertx.core.VertxOptions] is * @param blockedThreadCheckIntervalUnit Set the time unit of blockedThreadCheckInterval. * @param clusterManager Programmatically set the cluster manager to be used when clustering.

Only valid if clustered = true.

Normally Vert.x will look on the classpath for a cluster manager, but if you want to set one programmatically you can use this method. * @param disableTCCL Configures whether Vert.x sets the [io.vertx.core.Context] classloader as the thread context classloader on actions executed on that [io.vertx.core.Context]. When a [io.vertx.core.Context] is created the current thread classloader is captured and associated with this classloader. Likewise when a Verticle is created, the Verticle's [io.vertx.core.Context] classloader is set to the current thread classloader unless this classloader is overriden by [io.vertx.core.DeploymentOptions]. This setting overrides the (legacy) system property vertx.disableTCCL and provides control at the Vertx instance level. * @param eventBusOptions Sets the event bus configuration to configure the host, port, ssl... * @param eventLoopPoolSize Set the number of event loop threads to be used by the Vert.x instance. * @param fileSystemOptions Set the file system options * @param haEnabled Set whether HA will be enabled on the Vert.x instance. * @param haGroup Set the HA group to be used when HA is enabled. * @param internalBlockingPoolSize Set the value of internal blocking pool size * @param maxEventLoopExecuteTime Sets the value of max event loop execute time, in [io.vertx.core.VertxOptions].

The default value of [io.vertx.core.VertxOptions]is * @param maxEventLoopExecuteTimeUnit Set the time unit of maxEventLoopExecuteTime. * @param maxWorkerExecuteTime Sets the value of max worker execute time, in [io.vertx.core.VertxOptions].

The default value of [io.vertx.core.VertxOptions] is * @param maxWorkerExecuteTimeUnit Set the time unit of maxWorkerExecuteTime. * @param metricsOptions Set the metrics options * @param preferNativeTransport Set wether to prefer the native transport to the JDK transport. * @param quorumSize Set the quorum size to be used when HA is enabled. * @param tracingOptions Set the tracing options * @param useDaemonThread Mark the vertx thread as daemon thread or user thread.

For keeping the old behavior, the default value is false instead of null. * @param warningExceptionTime Set the threshold value above this, the blocked warning contains a stack trace. in [io.vertx.core.VertxOptions]. The default value of [io.vertx.core.VertxOptions] is * @param warningExceptionTimeUnit Set the time unit of warningExceptionTime. * @param workerPoolSize Set the maximum number of worker threads to be used by the Vert.x instance. * *

* NOTE: This function has been automatically generated from the [io.vertx.core.VertxOptions original] using Vert.x codegen. */ fun vertxOptionsOf( addressResolverOptions: io.vertx.core.dns.AddressResolverOptions? = null, blockedThreadCheckInterval: Long? = null, blockedThreadCheckIntervalUnit: TimeUnit? = null, clusterManager: io.vertx.core.spi.cluster.ClusterManager? = null, disableTCCL: Boolean? = null, eventBusOptions: io.vertx.core.eventbus.EventBusOptions? = null, eventLoopPoolSize: Int? = null, fileSystemOptions: io.vertx.core.file.FileSystemOptions? = null, haEnabled: Boolean? = null, haGroup: String? = null, internalBlockingPoolSize: Int? = null, maxEventLoopExecuteTime: Long? = null, maxEventLoopExecuteTimeUnit: TimeUnit? = null, maxWorkerExecuteTime: Long? = null, maxWorkerExecuteTimeUnit: TimeUnit? = null, metricsOptions: io.vertx.core.metrics.MetricsOptions? = null, preferNativeTransport: Boolean? = null, quorumSize: Int? = null, tracingOptions: io.vertx.core.tracing.TracingOptions? = null, useDaemonThread: Boolean? = null, warningExceptionTime: Long? = null, warningExceptionTimeUnit: TimeUnit? = null, workerPoolSize: Int? = null): VertxOptions = io.vertx.core.VertxOptions().apply { if (addressResolverOptions != null) { this.setAddressResolverOptions(addressResolverOptions) } if (blockedThreadCheckInterval != null) { this.setBlockedThreadCheckInterval(blockedThreadCheckInterval) } if (blockedThreadCheckIntervalUnit != null) { this.setBlockedThreadCheckIntervalUnit(blockedThreadCheckIntervalUnit) } if (clusterManager != null) { this.setClusterManager(clusterManager) } if (disableTCCL != null) { this.setDisableTCCL(disableTCCL) } if (eventBusOptions != null) { this.setEventBusOptions(eventBusOptions) } if (eventLoopPoolSize != null) { this.setEventLoopPoolSize(eventLoopPoolSize) } if (fileSystemOptions != null) { this.setFileSystemOptions(fileSystemOptions) } if (haEnabled != null) { this.setHAEnabled(haEnabled) } if (haGroup != null) { this.setHAGroup(haGroup) } if (internalBlockingPoolSize != null) { this.setInternalBlockingPoolSize(internalBlockingPoolSize) } if (maxEventLoopExecuteTime != null) { this.setMaxEventLoopExecuteTime(maxEventLoopExecuteTime) } if (maxEventLoopExecuteTimeUnit != null) { this.setMaxEventLoopExecuteTimeUnit(maxEventLoopExecuteTimeUnit) } if (maxWorkerExecuteTime != null) { this.setMaxWorkerExecuteTime(maxWorkerExecuteTime) } if (maxWorkerExecuteTimeUnit != null) { this.setMaxWorkerExecuteTimeUnit(maxWorkerExecuteTimeUnit) } if (metricsOptions != null) { this.setMetricsOptions(metricsOptions) } if (preferNativeTransport != null) { this.setPreferNativeTransport(preferNativeTransport) } if (quorumSize != null) { this.setQuorumSize(quorumSize) } if (tracingOptions != null) { this.setTracingOptions(tracingOptions) } if (useDaemonThread != null) { this.setUseDaemonThread(useDaemonThread) } if (warningExceptionTime != null) { this.setWarningExceptionTime(warningExceptionTime) } if (warningExceptionTimeUnit != null) { this.setWarningExceptionTimeUnit(warningExceptionTimeUnit) } if (workerPoolSize != null) { this.setWorkerPoolSize(workerPoolSize) } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy