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

com.arangodb.internal.velocystream.internal.VstConnectionSync Maven / Gradle / Ivy

There is a newer version: 7.15.0
Show newest version
/*
 * DISCLAIMER
 *
 * Copyright 2016 ArangoDB GmbH, Cologne, Germany
 *
 * 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.
 *
 * Copyright holder is ArangoDB GmbH, Cologne, Germany
 */

package com.arangodb.internal.velocystream.internal;

import com.arangodb.ArangoDBException;
import com.arangodb.internal.net.HostDescription;

import javax.net.ssl.SSLContext;
import java.util.Collection;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;

/**
 * @author Mark Vollmary
 *
 */
public class VstConnectionSync extends VstConnection {

	public static class Builder {

		private HostDescription host;
		private MessageStore messageStore;
		private Integer timeout;
		private Long ttl;
		private Boolean useSsl;
		private SSLContext sslContext;

		public Builder host(final HostDescription host) {
			this.host = host;
			return this;
		}

		public Builder messageStore(final MessageStore messageStore) {
			this.messageStore = messageStore;
			return this;
		}

		public Builder timeout(final Integer timeout) {
			this.timeout = timeout;
			return this;
		}

		public Builder useSsl(final Boolean useSsl) {
			this.useSsl = useSsl;
			return this;
		}

		public Builder sslContext(final SSLContext sslContext) {
			this.sslContext = sslContext;
			return this;
		}

		public Builder ttl(final Long ttl) {
			this.ttl = ttl;
			return this;
		}

		public VstConnectionSync build() {
			return new VstConnectionSync(host, timeout, ttl, useSsl, sslContext, messageStore);
		}
	}

	private VstConnectionSync(final HostDescription host, final Integer timeout, final Long ttl, final Boolean useSsl,
		final SSLContext sslContext, final MessageStore messageStore) {
		super(host, timeout, ttl, useSsl, sslContext, messageStore);
	}

	public Message write(final Message message, final Collection chunks) throws ArangoDBException {
		final FutureTask task = new FutureTask<>(() -> messageStore.get(message.getId()));
		messageStore.storeMessage(message.getId(), task);
		super.writeIntern(message, chunks);
		try {
			return timeout == null || timeout == 0L ? task.get() : task.get(timeout, TimeUnit.MILLISECONDS);
		} catch (final Exception e) {
			throw new ArangoDBException(e);
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy