com.arangodb.internal.velocystream.VstCommunicationSync Maven / Gradle / Ivy
/*
* 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;
import javax.net.ssl.SSLContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.arangodb.ArangoDBException;
import com.arangodb.internal.ArangoDBConstants;
import com.arangodb.internal.CollectionCache;
import com.arangodb.internal.Host;
import com.arangodb.internal.net.ConnectionPool;
import com.arangodb.internal.net.DelHostHandler;
import com.arangodb.internal.net.HostHandler;
import com.arangodb.internal.velocystream.internal.AuthenticationRequest;
import com.arangodb.internal.velocystream.internal.ConnectionSync;
import com.arangodb.internal.velocystream.internal.Message;
import com.arangodb.internal.velocystream.internal.MessageStore;
import com.arangodb.util.ArangoSerialization;
import com.arangodb.velocypack.exception.VPackParserException;
import com.arangodb.velocystream.Request;
import com.arangodb.velocystream.Response;
/**
* @author Mark Vollmary
*
*/
public class VstCommunicationSync extends VstCommunication {
private static final Logger LOGGER = LoggerFactory.getLogger(VstCommunicationSync.class);
private final CollectionCache collectionCache;
public static class Builder {
private final HostHandler hostHandler;
private Integer timeout;
private Long connectionTtl;
private String user;
private String password;
private Boolean useSsl;
private SSLContext sslContext;
private Integer chunksize;
private Integer maxConnections;
public Builder(final HostHandler hostHandler) {
super();
this.hostHandler = hostHandler;
}
public Builder(final Builder builder) {
this(builder.hostHandler);
timeout(builder.timeout).user(builder.user).password(builder.password).useSsl(builder.useSsl)
.sslContext(builder.sslContext).chunksize(builder.chunksize).maxConnections(builder.maxConnections);
}
public Builder timeout(final Integer timeout) {
this.timeout = timeout;
return this;
}
public Builder user(final String user) {
this.user = user;
return this;
}
public Builder password(final String password) {
this.password = password;
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 chunksize(final Integer chunksize) {
this.chunksize = chunksize;
return this;
}
public Builder maxConnections(final Integer maxConnections) {
this.maxConnections = maxConnections;
return this;
}
public Builder connectionTtl(final Long connectionTtl) {
this.connectionTtl = connectionTtl;
return this;
}
public VstCommunication build(
final ArangoSerialization util,
final CollectionCache collectionCache) {
return new VstCommunicationSync(hostHandler, timeout, user, password, useSsl, sslContext, util,
collectionCache, chunksize, maxConnections, connectionTtl);
}
}
protected VstCommunicationSync(final HostHandler hostHandler, final Integer timeout, final String user,
final String password, final Boolean useSsl, final SSLContext sslContext, final ArangoSerialization util,
final CollectionCache collectionCache, final Integer chunksize, final Integer maxConnections, final Long ttl) {
super(timeout, user, password, useSsl, sslContext, util, chunksize, new ConnectionPool(
maxConnections != null ? Math.max(1, maxConnections) : ArangoDBConstants.MAX_CONNECTIONS_VST_DEFAULT) {
private final ConnectionSync.Builder builder = new ConnectionSync.Builder().timeout(timeout).ttl(ttl)
.useSsl(useSsl).sslContext(sslContext);
@Override
public ConnectionSync createConnection(final Host host) {
return builder.messageStore(new MessageStore()).hostHandler(new DelHostHandler(hostHandler, host))
.build();
}
});
this.collectionCache = collectionCache;
}
@Override
protected Response execute(final Request request, final ConnectionSync connection) throws ArangoDBException {
connect(connection);
try {
final Message requestMessage = createMessage(request);
final Message responseMessage = send(requestMessage, connection);
collectionCache.setDb(request.getDatabase());
final Response response = createResponse(responseMessage);
checkError(response);
return response;
} catch (final VPackParserException e) {
throw new ArangoDBException(e);
}
}
private Message send(final Message message, final ConnectionSync connection) throws ArangoDBException {
if (LOGGER.isDebugEnabled()) {
LOGGER.debug(String.format("Send Message (id=%s, head=%s, body=%s)", message.getId(), message.getHead(),
message.getBody() != null ? message.getBody() : "{}"));
}
return connection.write(message, buildChunks(message));
}
@Override
protected void authenticate(final ConnectionSync connection) {
final Response response = execute(
new AuthenticationRequest(user, password != null ? password : "", ArangoDBConstants.ENCRYPTION_PLAIN),
connection);
checkError(response);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy