1
22
23
41
42 package com.liferay.portal.tools.deploy;
43
44 import com.liferay.portal.kernel.log.Log;
45 import com.liferay.portal.kernel.log.LogFactoryUtil;
46 import com.liferay.portal.kernel.util.PortalClassLoaderUtil;
47
48 import java.io.File;
49
50 import javax.enterprise.deploy.shared.ModuleType;
51 import javax.enterprise.deploy.shared.factories.DeploymentFactoryManager;
52 import javax.enterprise.deploy.spi.DeploymentManager;
53 import javax.enterprise.deploy.spi.TargetModuleID;
54 import javax.enterprise.deploy.spi.factories.DeploymentFactory;
55 import javax.enterprise.deploy.spi.status.ProgressObject;
56
57
64 public class DeploymentHandler {
65
66 public DeploymentHandler(
67 String dmId, String dmUser, String dmPassword, String dfClassName) {
68
69 try {
70 ClassLoader classLoader = PortalClassLoaderUtil.getClassLoader();
71
72 DeploymentFactoryManager deploymentFactoryManager =
73 DeploymentFactoryManager.getInstance();
74
75 DeploymentFactory deploymentFactory =
76 (DeploymentFactory)classLoader.loadClass(
77 dfClassName).newInstance();
78
79 deploymentFactoryManager.registerDeploymentFactory(
80 deploymentFactory);
81
82 _deploymentManager = deploymentFactoryManager.getDeploymentManager(
83 dmId, dmUser, dmPassword);
84 }
85 catch (Exception e) {
86 _log.error(e, e);
87 }
88 }
89
90 public DeploymentManager getDeploymentManager() {
91 return _deploymentManager;
92 }
93
94 public void deploy(File warDir, String warContext) throws Exception {
95 setStarted(false);
96
97 ProgressObject deployProgress = null;
98
99 TargetModuleID[] targetModuleIDs =
100 _deploymentManager.getAvailableModules(
101 ModuleType.WAR, _deploymentManager.getTargets());
102
103 for (TargetModuleID targetModuleID : targetModuleIDs) {
104 if (!targetModuleID.getModuleID().equals(warContext)) {
105 continue;
106 }
107
108 deployProgress = _deploymentManager.redeploy(
109 new TargetModuleID[] {targetModuleID}, warDir, null);
110
111 break;
112 }
113
114 if (deployProgress == null) {
115 deployProgress = _deploymentManager.distribute(
116 _deploymentManager.getTargets(), warDir, null);
117 }
118
119 deployProgress.addProgressListener(
120 new DeploymentProgressListener(this, warContext));
121
122 waitForStart(warContext);
123
124 if (_error) {
125 throw new Exception("Failed to deploy " + warDir);
126 }
127 }
128
129 public void releaseDeploymentManager() {
130 _deploymentManager.release();
131 }
132
133 public synchronized void setError(boolean error) {
134 _error = error;
135 }
136
137 public synchronized void setStarted(boolean started) {
138 _started = started;
139
140 notifyAll();
141 }
142
143 protected synchronized void waitForStart(String warContext)
144 throws Exception {
145
146 while (!_error && !_started) {
147 wait();
148 }
149
150 if (_error) {
151 return;
152 }
153
154 TargetModuleID[] targetModuleIDs =
155 _deploymentManager.getAvailableModules(
156 ModuleType.WAR, _deploymentManager.getTargets());
157
158 for (TargetModuleID targetModuleID : targetModuleIDs) {
159 if (!targetModuleID.getModuleID().equals(warContext)) {
160 continue;
161 }
162
163 _deploymentManager.start(new TargetModuleID[] {targetModuleID});
164
165 break;
166 }
167 }
168
169 private static Log _log = LogFactoryUtil.getLog(DeploymentHandler.class);
170
171 private DeploymentManager _deploymentManager;
172 private boolean _error;
173 private boolean _started;
174
175 }