com.devicehive.dao.riak.ConfigurationDaoRiakImpl.java Source code

Java tutorial

Introduction

Here is the source code for com.devicehive.dao.riak.ConfigurationDaoRiakImpl.java

Source

package com.devicehive.dao.riak;

/*
 * #%L
 * DeviceHive Dao Riak Implementation
 * %%
 * Copyright (C) 2016 DataArt
 * %%
 * 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.
 * #L%
 */
import com.basho.riak.client.api.commands.kv.DeleteValue;
import com.basho.riak.client.api.commands.kv.FetchValue;
import com.basho.riak.client.api.commands.kv.StoreValue;
import com.basho.riak.client.core.query.Location;
import com.basho.riak.client.core.query.Namespace;
import com.devicehive.dao.ConfigurationDao;
import com.devicehive.dao.riak.model.RiakConfiguration;
import com.devicehive.exceptions.HivePersistenceLayerException;
import com.devicehive.vo.ConfigurationVO;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Repository;

import java.util.Optional;
import java.util.concurrent.ExecutionException;

@Repository
public class ConfigurationDaoRiakImpl extends RiakGenericDao implements ConfigurationDao {

    private static final Logger LOGGER = LoggerFactory.getLogger(ConfigurationDaoRiakImpl.class);

    private static final Namespace CONFIG_NS = new Namespace("configuration");

    @Override
    public Optional<ConfigurationVO> getByName(String id) {
        //TODO configurable quorum?
        try {
            Location objectKey = new Location(CONFIG_NS, id);
            FetchValue fetch = new FetchValue.Builder(objectKey)
                    .withOption(quorum.getReadQuorumOption(), quorum.getReadQuorum()).build();
            FetchValue.Response response = client.execute(fetch);
            RiakConfiguration configuration = getOrNull(response, RiakConfiguration.class);
            return Optional.ofNullable(RiakConfiguration.convert(configuration));
        } catch (ExecutionException | InterruptedException e) {
            LOGGER.error("Exception accessing Riak Storage.", e);
            throw new HivePersistenceLayerException("Cannot fetch configuration by name.", e);
        }
    }

    @Override
    public int delete(String name) {
        try {
            Location objectKey = new Location(CONFIG_NS, name);
            DeleteValue delete = new DeleteValue.Builder(objectKey).build();
            client.execute(delete);
        } catch (ExecutionException | InterruptedException e) {
            LOGGER.error("Exception accessing Riak Storage.", e);
            throw new HivePersistenceLayerException("Cannot delete configuration by name.", e);
        }
        return 1;
    }

    @Override
    public void persist(ConfigurationVO configuration) {
        try {
            Location objectKey = new Location(CONFIG_NS, configuration.getName());
            StoreValue storeOp = new StoreValue.Builder(RiakConfiguration.convert(configuration))
                    .withLocation(objectKey).withOption(quorum.getWriteQuorumOption(), quorum.getWriteQuorum())
                    .build();
            client.execute(storeOp);
        } catch (ExecutionException | InterruptedException e) {
            LOGGER.error("Exception accessing Riak Storage.", e);
            throw new HivePersistenceLayerException("Cannot store configuration.", e);
        }
    }

    @Override
    public ConfigurationVO merge(ConfigurationVO existing) {
        persist(existing);
        return existing;
    }
}