org.jnosql.diana.memcached.key.MemcachedBucketManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of memcached-driver Show documentation
Show all versions of memcached-driver Show documentation
The Eclipse JNoSQL communication layer, Diana, implementation to Memcached
The newest version!
/*
* Copyright (c) 2019 Otávio Santana and others
* 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.jnosql.diana.memcached.key;
import net.spy.memcached.MemcachedClient;
import org.jnosql.diana.api.Value;
import org.jnosql.diana.api.key.BucketManager;
import org.jnosql.diana.api.key.KeyValueEntity;
import java.time.Duration;
import java.util.Optional;
import java.util.stream.Collectors;
import static java.util.Objects.requireNonNull;
import static java.util.Optional.ofNullable;
import static java.util.stream.StreamSupport.stream;
final class MemcachedBucketManager implements BucketManager {
private static final int NO_EXP = 0;
private final MemcachedClient client;
private final String bucketName;
MemcachedBucketManager(MemcachedClient client, String bucketName) {
this.client = client;
this.bucketName = bucketName;
}
@Override
public void put(KeyValueEntity entity) {
requireNonNull(entity, "entity is required");
put(entity.getKey(), entity.get());
}
@Override
public void put(K key, V value) {
requireNonNull(key, "key is required");
requireNonNull(value, "value is required");
set(key, value, NO_EXP);
}
@Override
public void put(KeyValueEntity entity, Duration ttl) {
requireNonNull(entity, "entity is required");
requireNonNull(ttl, "ttl is required");
set(entity.getKey(), entity.get(), (int) ttl.getSeconds());
}
@Override
public void put(Iterable> entities) {
requireNonNull(entities, "entities is required");
entities.forEach(this::put);
}
@Override
public void put(Iterable> entities, Duration ttl) {
requireNonNull(entities, "entities is required");
requireNonNull(ttl, "ttl is required");
entities.forEach(e -> this.put(e, ttl));
}
@Override
public Optional get(K key) {
requireNonNull(key, "key is required");
return ofNullable(client.get(getKey(key))).map(Value::of);
}
@Override
public Iterable get(Iterable keys) {
requireNonNull(keys, "keys is required");
return stream(keys.spliterator(), false)
.map(this::get)
.filter(o -> o.isPresent())
.map(Optional::get)
.collect(Collectors.toList());
}
@Override
public void remove(K key) {
requireNonNull(key, "key is required");
client.delete(getKey(key));
}
@Override
public void remove(Iterable keys) {
requireNonNull(keys, "keys is required");
stream(keys.spliterator(), false).forEach(this::remove);
}
@Override
public void close() {
}
private String getKey(K key) {
return bucketName + ':' + key.toString();
}
private void set(Object key, Object value, int exp) {
client.set(getKey(key), exp, value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy