/**
* 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.management;
import com.liferay.portal.kernel.cluster.ClusterNode;
import com.liferay.portal.kernel.cluster.ClusterNodeResponse;
import com.liferay.portal.kernel.cluster.ClusterNodeResponses;
import com.liferay.portal.kernel.cluster.FutureClusterResponses;
import com.liferay.portal.kernel.exception.LoggedExceptionInInitializerError;
import com.liferay.portal.kernel.model.ClusterGroup;
import com.liferay.portal.kernel.security.pacl.permission.PortalRuntimePermission;
import com.liferay.portal.kernel.service.ClusterGroupLocalServiceUtil;
import com.liferay.portal.kernel.util.MethodHandler;
import java.lang.reflect.Method;
/**
* @author Shuyang Zhou
* @author Raymond Augé
*/
public class PortalManagerUtil {
public static MethodHandler createManageActionMethodHandler(
ManageAction<?> manageAction) {
return new MethodHandler(_MANAGE_METHOD, manageAction);
}
public static PortalManager getPortalManager() {
PortalRuntimePermission.checkGetBeanProperty(PortalManagerUtil.class);
return _portalManager;
}
public static FutureClusterResponses manage(
ClusterGroup clusterGroup, ManageAction<?> manageAction)
throws ManageActionException {
ManageAction<FutureClusterResponses> manageActionWrapper =
new ClusterManageActionWrapper(clusterGroup, manageAction);
return getPortalManager().manage(manageActionWrapper);
}
public static <T> T manage(ManageAction<T> manageAction)
throws ManageActionException {
return getPortalManager().manage(manageAction);
}
public static void manageAsync(
ClusterNode clusterNode, ManageAction<?> manageAction)
throws Exception {
ClusterGroup clusterGroup =
ClusterGroupLocalServiceUtil.createClusterGroup(0);
clusterGroup.setClusterNodeIds(clusterNode.getClusterNodeId());
manage(clusterGroup, manageAction);
}
public static <T> T manageSync(
ClusterNode clusterNode, ManageAction<T> manageAction)
throws Exception {
ClusterGroup clusterGroup =
ClusterGroupLocalServiceUtil.createClusterGroup(0);
clusterGroup.setClusterNodeIds(clusterNode.getClusterNodeId());
FutureClusterResponses futureClusterResponses = manage(
clusterGroup, manageAction);
ClusterNodeResponses clusterNodeResponses =
futureClusterResponses.get();
ClusterNodeResponse clusterNodeResponse =
clusterNodeResponses.getClusterResponse(
clusterNode.getClusterNodeId());
return (T)clusterNodeResponse.getResult();
}
public void setPortalManager(PortalManager portalManager) {
PortalRuntimePermission.checkSetBeanProperty(getClass());
_portalManager = portalManager;
}
private static final Method _MANAGE_METHOD;
private static PortalManager _portalManager;
static {
try {
_MANAGE_METHOD = PortalManagerUtil.class.getDeclaredMethod(
"manage", ManageAction.class);
}
catch (Exception e) {
throw new LoggedExceptionInInitializerError(e);
}
}
}