Project

General

Profile

1
package eu.dnetlib.functionality.modular.ui.workflows.values;
2

    
3
import com.google.common.base.Function;
4
import com.google.common.collect.Iterables;
5
import com.google.common.collect.Lists;
6
import eu.dnetlib.data.hadoop.rmi.HadoopService;
7
import eu.dnetlib.enabling.locators.UniqueServiceLocator;
8
import eu.dnetlib.msro.workflows.util.ValidNodeValuesFetcher;
9
import org.apache.commons.logging.Log;
10
import org.apache.commons.logging.LogFactory;
11

    
12
import javax.annotation.Resource;
13
import java.util.List;
14
import java.util.Map;
15

    
16
public class ListHadoopClusters extends ValidNodeValuesFetcher {
17

    
18
	/**
19
	 * logger.
20
	 */
21
	private static final Log log = LogFactory.getLog(ListHadoopClusters.class);
22

    
23
	private final Function<String, DnetParamValue> f = new Function<String, DnetParamValue>() {
24

    
25
		@Override
26
		public DnetParamValue apply(final String s) {
27
			return new DnetParamValue(s, s);
28
		}
29
	};
30

    
31
	@Resource
32
	private UniqueServiceLocator serviceLocator;
33

    
34
	@Override
35
	protected List<DnetParamValue> obtainValues(final Map<String, String> params) throws Exception {
36

    
37
		List<DnetParamValue> res = Lists.newArrayList(Iterables.transform(listClusters(), f));
38
		return res;
39
	}
40

    
41
	private List<String> listClusters() {
42
		try {
43
			return serviceLocator.getService(HadoopService.class).listClusters();
44
		} catch (Throwable e) {
45
			log.error(e);
46
			return Lists.newArrayList();
47
		}
48
	}
49
}
(5-5/5)