lcmc.cluster.service.storage.FileSystemService.java Source code

Java tutorial

Introduction

Here is the source code for lcmc.cluster.service.storage.FileSystemService.java

Source

/*
 * This file is part of LCMC written by Rasto Levrinc.
 *
 * Copyright (C) 2014, Rastislav Levrinc.
 *
 * The LCMC is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as published
 * by the Free Software Foundation; either version 2, or (at your option)
 * any later version.
 *
 * The LCMC is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with LCMC; see the file COPYING.  If not, write to
 * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
 */

package lcmc.cluster.service.storage;

import com.google.common.base.Optional;
import com.google.common.eventbus.Subscribe;
import lcmc.ClusterEventBus;
import lcmc.HwEventBus;
import lcmc.cluster.domain.Cluster;
import lcmc.common.domain.util.Tools;
import lcmc.event.CommonFileSystemsChangedEvent;
import lcmc.event.FileSystemsChangedEvent;
import lcmc.event.HwFileSystemsChangedEvent;
import lcmc.host.domain.Host;

import javax.inject.Inject;
import javax.inject.Named;
import javax.inject.Singleton;
import java.util.Collection;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;
import java.util.concurrent.ConcurrentHashMap;

@Named
@Singleton
public class FileSystemService {
    @Inject
    private HwEventBus hwEventBus;
    @Inject
    private ClusterEventBus clusterEventBus;
    private Map<Host, Set<String>> fileSystemsByHost = new ConcurrentHashMap<Host, Set<String>>();
    private Map<Cluster, Set<String>> commonFileSystemsByCluster = new ConcurrentHashMap<Cluster, Set<String>>();

    public void init() {
        hwEventBus.register(this);
    }

    @Subscribe
    public void onFileSystemsChanged(final HwFileSystemsChangedEvent event) {
        fileSystemsByHost.put(event.getHost(), event.getFileSystems());
        clusterEventBus.post(new FileSystemsChangedEvent(event.getHost(), event.getFileSystems()));
        updateCommonFileSystems(Optional.fromNullable(event.getHost().getCluster()));
    }

    public Set<String> getCommonFileSystems(final Cluster cluster) {
        final Set<String> fileSystems = commonFileSystemsByCluster.get(cluster);
        if (fileSystems == null) {
            return new TreeSet<String>();
        }
        return fileSystems;
    }

    public Set<String> getFileSystems(final Host host) {
        return fileSystemsByHost.get(host);
    }

    private Set<String> getCommonFileSystems(final Collection<Host> hosts) {
        Optional<Set<String>> fileSystemsIntersection = Optional.absent();

        for (final Host host : hosts) {
            final Set<String> fileSystems = fileSystemsByHost.get(host);
            fileSystemsIntersection = Tools.getIntersection(Optional.fromNullable(fileSystems),
                    fileSystemsIntersection);
        }
        return fileSystemsIntersection.or(new TreeSet<String>());
    }

    private void updateCommonFileSystems(final Optional<Cluster> cluster) {
        if (!cluster.isPresent()) {
            return;
        }
        final Set<String> commonFileSystems = getCommonFileSystems(cluster.get().getHosts());
        final Set<String> oldCommonFileSystems = commonFileSystemsByCluster.get(cluster.get());
        commonFileSystemsByCluster.put(cluster.get(), commonFileSystems);
        if (oldCommonFileSystems == null || oldCommonFileSystems.isEmpty()
                || !Tools.equalCollections(commonFileSystems, oldCommonFileSystems)) {
            clusterEventBus.post(new CommonFileSystemsChangedEvent(cluster.get(), commonFileSystems));
        }
    }
}