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

org.jnosql.diana.memcached.key.MemcachedBucketManager Maven / Gradle / Ivy

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