/** * Copyright (c) 2000-present Liferay, Inc. All rights reserved. * * This library is free software; you can redistribute it and/or modify it under * the terms of the GNU Lesser General Public License as published by the Free * Software Foundation; either version 2.1 of the License, or (at your option) * any later version. * * This library 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 Lesser General Public License for more * details. */ package com.liferay.portal.kernel.cluster; import com.liferay.portal.kernel.security.pacl.permission.PortalRuntimePermission; import com.liferay.portal.kernel.util.ServiceProxyFactory; import java.util.List; /** * @author Tina Tian * @author Raymond Augé */ public class ClusterExecutorUtil { public static void addClusterEventListener( ClusterEventListener clusterEventListener) { _getClusterExecutor().addClusterEventListener(clusterEventListener); } public static FutureClusterResponses execute( ClusterRequest clusterRequest) { return _getClusterExecutor().execute(clusterRequest); } /** * @deprecated As of 7.0.0, replaced by {@link #_getClusterExecutor()} */ @Deprecated public static ClusterExecutor getClusterExecutor() { return _getClusterExecutor(); } public static List<ClusterNode> getClusterNodes() { return _getClusterExecutor().getClusterNodes(); } public static ClusterNode getLocalClusterNode() { return _getClusterExecutor().getLocalClusterNode(); } public static boolean isClusterNodeAlive(String clusterNodeId) { return _getClusterExecutor().isClusterNodeAlive(clusterNodeId); } public static boolean isEnabled() { return _getClusterExecutor().isEnabled(); } public static void removeClusterEventListener( ClusterEventListener clusterEventListener) { _getClusterExecutor().removeClusterEventListener(clusterEventListener); } private static ClusterExecutor _getClusterExecutor() { PortalRuntimePermission.checkGetBeanProperty(ClusterExecutorUtil.class); return _clusterExecutor; } private static volatile ClusterExecutor _clusterExecutor = ServiceProxyFactory.newServiceTrackedInstance( ClusterExecutor.class, ClusterExecutorUtil.class, "_clusterExecutor", false); }