Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.eclipse.jnosql.databases.cassandra.communication.DefaultCassandraColumnManager Maven / Gradle / Ivy
/*
* Copyright (c) 2022 Contributors to the Eclipse Foundation
* 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
* and 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.
*
* Contributors:
*
* Otavio Santana
*/
package org.eclipse.jnosql.databases.cassandra.communication;
import com.datastax.oss.driver.api.core.ConsistencyLevel;
import com.datastax.oss.driver.api.core.CqlSession;
import com.datastax.oss.driver.api.core.cql.BoundStatement;
import com.datastax.oss.driver.api.core.cql.PreparedStatement;
import com.datastax.oss.driver.api.core.cql.ResultSet;
import com.datastax.oss.driver.api.core.cql.SimpleStatement;
import com.datastax.oss.driver.api.core.type.codec.TypeCodec;
import com.datastax.oss.driver.api.core.type.codec.registry.CodecRegistry;
import com.datastax.oss.driver.api.querybuilder.QueryBuilder;
import com.datastax.oss.driver.api.querybuilder.delete.Delete;
import com.datastax.oss.driver.api.querybuilder.insert.Insert;
import org.eclipse.jnosql.communication.semistructured.CommunicationEntity;
import org.eclipse.jnosql.communication.semistructured.DeleteQuery;
import org.eclipse.jnosql.communication.semistructured.SelectQuery;
import java.time.Duration;
import java.util.Map;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import static java.util.Objects.requireNonNull;
class DefaultCassandraColumnManager implements CassandraColumnManager {
private final CqlSession session;
private final String keyspace;
DefaultCassandraColumnManager(CqlSession session, String keyspace) {
this.session = session;
this.keyspace = keyspace;
}
@Override
public String name() {
return keyspace;
}
@Override
public CommunicationEntity insert(CommunicationEntity entity) {
requireNonNull(entity, "entity is required");
final Insert insert = QueryUtils.insert(entity, keyspace, session, null);
session.execute(insert.build());
return entity;
}
@Override
public CommunicationEntity insert(CommunicationEntity entity, Duration duration) {
requireNonNull(entity, "entity is required");
requireNonNull(duration, "duration is required");
final Insert insert = QueryUtils.insert(entity, keyspace, session, duration);
session.execute(insert.build());
return entity;
}
@Override
public CommunicationEntity update(CommunicationEntity entity) {
return insert(entity);
}
@Override
public Iterable update(Iterable entities) {
return insert(entities);
}
@Override
public Iterable insert(Iterable entities) {
requireNonNull(entities, "entities is required");
return StreamSupport.stream(entities.spliterator(), false)
.map(this::insert)
.collect(Collectors.toList());
}
@Override
public Iterable insert(Iterable entities, Duration duration) {
requireNonNull(entities, "entities is required");
requireNonNull(duration, "entities is duration");
return StreamSupport.stream(entities.spliterator(), false)
.map(d -> insert(d, duration))
.collect(Collectors.toList());
}
@Override
public CommunicationEntity save(CommunicationEntity entity, ConsistencyLevel level) {
requireNonNull(entity, "entities is required");
requireNonNull(level, "level is required");
final Insert insert = QueryUtils.insert(entity, keyspace, session, null);
session.execute(insert.build().setConsistencyLevel(level));
return entity;
}
@Override
public CommunicationEntity save(CommunicationEntity entity, Duration ttl, ConsistencyLevel level) {
requireNonNull(entity, "entity is required");
requireNonNull(level, "level is required");
requireNonNull(ttl, "ttl is required");
final Insert insert = QueryUtils.insert(entity, keyspace, session, ttl);
session.execute(insert.build().setConsistencyLevel(level));
return entity;
}
@Override
public Iterable save(Iterable entities, ConsistencyLevel level) {
requireNonNull(entities, "entities is required");
requireNonNull(level, "level is required");
return StreamSupport.stream(entities.spliterator(), false).map(c -> this.save(c, level))
.collect(Collectors.toList());
}
@Override
public Iterable save(Iterable entities, Duration ttl, ConsistencyLevel level) {
requireNonNull(entities, "entities is required");
requireNonNull(level, "level is required");
requireNonNull(ttl, "ttl is required");
return StreamSupport.stream(entities.spliterator(), false).map(c -> this.save(c, ttl, level))
.collect(Collectors.toList());
}
@Override
public Stream select(SelectQuery query) {
requireNonNull(query, "query is required");
QueryExecutor executor = QueryExecutor.of(query);
return executor.execute(keyspace, query, this);
}
@Override
public Stream select(SelectQuery query, ConsistencyLevel level) throws NullPointerException {
requireNonNull(query, "query is required");
QueryExecutor executor = QueryExecutor.of(query);
return executor.execute(keyspace, query, level, this);
}
@Override
public long count(String columnFamily) {
requireNonNull(columnFamily, "columnFamily is required");
final ResultSet execute = session.execute(QueryBuilder.selectFrom(keyspace, columnFamily).countAll().build());
return execute.one().getLong(0);
}
@Override
public void close() {
session.close();
}
@Override
public void delete(DeleteQuery query, ConsistencyLevel level) {
requireNonNull(query, "query is required");
requireNonNull(level, "level is required");
final Delete delete = DeleteQueryConverter.delete(query, keyspace);
final SimpleStatement build = delete.build();
final SimpleStatement simpleStatement = build.setConsistencyLevel(level);
session.execute(simpleStatement);
}
@Override
public void delete(DeleteQuery query) {
requireNonNull(query, "query is required");
final Delete delete = DeleteQueryConverter.delete(query, keyspace);
session.execute(delete.build());
}
@Override
public Stream cql(String query) {
requireNonNull(query, "query is required");
final ResultSet resultSet = session.execute(query);
return resultSet.all().stream().map(CassandraConverter::toDocumentEntity);
}
@Override
public Stream cql(String query, Map values) {
requireNonNull(query, "query is required");
requireNonNull(values, "values is required");
final PreparedStatement prepare = session.prepare(query);
BoundStatement statement = prepare.bind();
for (Map.Entry entry : values.entrySet()) {
final TypeCodec codec = CodecRegistry.DEFAULT.codecFor((Class) entry.getValue().getClass());
statement = statement.set(entry.getKey(), entry.getValue(), codec);
}
final ResultSet resultSet = session.execute(statement);
return resultSet.all().stream().map(CassandraConverter::toDocumentEntity);
}
@Override
public Stream execute(SimpleStatement statement) {
requireNonNull(statement, "statement is required");
final ResultSet resultSet = session.execute(statement);
return resultSet.all().stream().map(CassandraConverter::toDocumentEntity);
}
@Override
public CassandraPreparedStatement nativeQueryPrepare(String query) {
requireNonNull(query, "query is required");
final PreparedStatement prepare = session.prepare(query);
return new CassandraPreparedStatement(prepare, session);
}
CqlSession getSession() {
return session;
}
@Override
public String toString() {
return "DefaultCassandraColumnManager{" +
"session=" + session +
", keyspace='" + keyspace + '\'' +
'}';
}
}