mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Modify DownloadCommand to pass DataTO.
This commit is contained in:
		
							parent
							
								
									87fafb7287
								
							
						
					
					
						commit
						c60c373a38
					
				
							
								
								
									
										39
									
								
								api/src/com/cloud/agent/api/storage/PasswordAuth.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								api/src/com/cloud/agent/api/storage/PasswordAuth.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | |||||||
|  | // Licensed to the Apache Software Foundation (ASF) under one | ||||||
|  | // or more contributor license agreements.  See the NOTICE file | ||||||
|  | // distributed with this work for additional information | ||||||
|  | // regarding copyright ownership.  The ASF licenses this file | ||||||
|  | // to you under the Apache License, Version 2.0 (the | ||||||
|  | // "License"); you may not use this file except in compliance | ||||||
|  | // with the License.  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //   http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | // Unless required by applicable law or agreed to in writing, | ||||||
|  | // software distributed under the License is distributed on an | ||||||
|  | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||||||
|  | // KIND, either express or implied.  See the License for the | ||||||
|  | // specific language governing permissions and limitations | ||||||
|  | // under the License. | ||||||
|  | package com.cloud.agent.api.storage; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Password authentication | ||||||
|  |  */ | ||||||
|  | public class PasswordAuth { | ||||||
|  | 
 | ||||||
|  |     String userName; | ||||||
|  |     String password; | ||||||
|  |     public PasswordAuth() { | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  |     public PasswordAuth(String user, String password) { | ||||||
|  |         this.userName = user; | ||||||
|  |         this.password = password; | ||||||
|  |     } | ||||||
|  |     public String getUserName() { | ||||||
|  |         return userName; | ||||||
|  |     } | ||||||
|  |     public String getPassword() { | ||||||
|  |         return password; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										72
									
								
								api/src/com/cloud/agent/api/storage/Proxy.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								api/src/com/cloud/agent/api/storage/Proxy.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,72 @@ | |||||||
|  | // Licensed to the Apache Software Foundation (ASF) under one | ||||||
|  | // or more contributor license agreements.  See the NOTICE file | ||||||
|  | // distributed with this work for additional information | ||||||
|  | // regarding copyright ownership.  The ASF licenses this file | ||||||
|  | // to you under the Apache License, Version 2.0 (the | ||||||
|  | // "License"); you may not use this file except in compliance | ||||||
|  | // with the License.  You may obtain a copy of the License at | ||||||
|  | // | ||||||
|  | //   http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | // | ||||||
|  | // Unless required by applicable law or agreed to in writing, | ||||||
|  | // software distributed under the License is distributed on an | ||||||
|  | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||||||
|  | // KIND, either express or implied.  See the License for the | ||||||
|  | // specific language governing permissions and limitations | ||||||
|  | // under the License. | ||||||
|  | package com.cloud.agent.api.storage; | ||||||
|  | 
 | ||||||
|  | import java.net.URI; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Download Proxy | ||||||
|  |  */ | ||||||
|  | public class Proxy { | ||||||
|  |     private String _host; | ||||||
|  |     private int _port; | ||||||
|  |     private String _userName; | ||||||
|  |     private String _password; | ||||||
|  | 
 | ||||||
|  |     public Proxy() { | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public Proxy(String host, int port, String userName, String password) { | ||||||
|  |         this._host = host; | ||||||
|  |         this._port = port; | ||||||
|  |         this._userName = userName; | ||||||
|  |         this._password = password; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public Proxy(URI uri) { | ||||||
|  |         this._host = uri.getHost(); | ||||||
|  |         this._port = uri.getPort() == -1 ? 3128 : uri.getPort(); | ||||||
|  |         String userInfo = uri.getUserInfo(); | ||||||
|  |         if (userInfo != null) { | ||||||
|  |             String[] tokens = userInfo.split(":"); | ||||||
|  |             if (tokens.length == 1) { | ||||||
|  |                 this._userName = userInfo; | ||||||
|  |                 this._password = ""; | ||||||
|  |             } else if (tokens.length == 2) { | ||||||
|  |                 this._userName = tokens[0]; | ||||||
|  |                 this._password = tokens[1]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getHost() { | ||||||
|  |         return _host; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int getPort() { | ||||||
|  |         return _port; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getUserName() { | ||||||
|  |         return _userName; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getPassword() { | ||||||
|  |         return _password; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -18,7 +18,6 @@ package com.cloud.agent.api.storage; | |||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.api.InternalIdentity; | import org.apache.cloudstack.api.InternalIdentity; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.PasswordAuth; |  | ||||||
| import com.cloud.agent.api.to.TemplateTO; | import com.cloud.agent.api.to.TemplateTO; | ||||||
| import com.cloud.storage.Upload.Type; | import com.cloud.storage.Upload.Type; | ||||||
| import com.cloud.template.VirtualMachineTemplate; | import com.cloud.template.VirtualMachineTemplate; | ||||||
|  | |||||||
| @ -27,6 +27,8 @@ import java.util.Random; | |||||||
| 
 | 
 | ||||||
| import javax.naming.ConfigurationException; | import javax.naming.ConfigurationException; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| @ -48,8 +50,6 @@ import com.cloud.agent.api.StartupStorageCommand; | |||||||
| import com.cloud.agent.api.storage.CreateEntityDownloadURLCommand; | import com.cloud.agent.api.storage.CreateEntityDownloadURLCommand; | ||||||
| import com.cloud.agent.api.storage.DeleteEntityDownloadURLCommand; | import com.cloud.agent.api.storage.DeleteEntityDownloadURLCommand; | ||||||
| import com.cloud.agent.api.storage.DeleteTemplateCommand; | import com.cloud.agent.api.storage.DeleteTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.UploadCommand; | import com.cloud.agent.api.storage.UploadCommand; | ||||||
| import com.cloud.agent.api.storage.ssCommand; | import com.cloud.agent.api.storage.ssCommand; | ||||||
| import com.cloud.host.Host; | import com.cloud.host.Host; | ||||||
|  | |||||||
| @ -11,13 +11,13 @@ import java.net.URISyntaxException; | |||||||
| import java.net.URL; | import java.net.URL; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadSystemTemplateCommand; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| 
 | 
 | ||||||
| import com.amazonaws.services.s3.model.S3ObjectSummary; | import com.amazonaws.services.s3.model.S3ObjectSummary; | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| import com.cloud.agent.api.Command; | import com.cloud.agent.api.Command; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadSystemTemplateCommand; |  | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
|  | |||||||
| @ -21,6 +21,8 @@ import java.util.Map; | |||||||
| 
 | 
 | ||||||
| import javax.naming.ConfigurationException; | import javax.naming.ConfigurationException; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| @ -35,8 +37,6 @@ import com.cloud.agent.api.ReadyCommand; | |||||||
| import com.cloud.agent.api.SecStorageSetupCommand; | import com.cloud.agent.api.SecStorageSetupCommand; | ||||||
| import com.cloud.agent.api.StartupCommand; | import com.cloud.agent.api.StartupCommand; | ||||||
| import com.cloud.agent.api.StartupStorageCommand; | import com.cloud.agent.api.StartupStorageCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.ListTemplateAnswer; | import com.cloud.agent.api.storage.ListTemplateAnswer; | ||||||
| import com.cloud.agent.api.storage.ListTemplateCommand; | import com.cloud.agent.api.storage.ListTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.ssCommand; | import com.cloud.agent.api.storage.ssCommand; | ||||||
|  | |||||||
| @ -50,6 +50,9 @@ import org.apache.cloudstack.engine.subsystem.api.storage.DataObjectType; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | ||||||
| import org.apache.cloudstack.storage.command.CopyCmdAnswer; | import org.apache.cloudstack.storage.command.CopyCmdAnswer; | ||||||
| import org.apache.cloudstack.storage.command.CopyCommand; | import org.apache.cloudstack.storage.command.CopyCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
| import org.apache.cloudstack.storage.to.TemplateObjectTO; | import org.apache.cloudstack.storage.to.TemplateObjectTO; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| @ -87,15 +90,12 @@ import com.cloud.agent.api.storage.DeleteEntityDownloadURLCommand; | |||||||
| import com.cloud.agent.api.storage.DeleteTemplateCommand; | import com.cloud.agent.api.storage.DeleteTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.DeleteVolumeCommand; | import com.cloud.agent.api.storage.DeleteVolumeCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.ListTemplateAnswer; | import com.cloud.agent.api.storage.ListTemplateAnswer; | ||||||
| import com.cloud.agent.api.storage.ListTemplateCommand; | import com.cloud.agent.api.storage.ListTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.ListVolumeAnswer; | import com.cloud.agent.api.storage.ListVolumeAnswer; | ||||||
| import com.cloud.agent.api.storage.ListVolumeCommand; | import com.cloud.agent.api.storage.ListVolumeCommand; | ||||||
| import com.cloud.agent.api.storage.UploadCommand; | import com.cloud.agent.api.storage.UploadCommand; | ||||||
| import com.cloud.agent.api.storage.ssCommand; | import com.cloud.agent.api.storage.ssCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
|  | |||||||
| @ -18,10 +18,11 @@ package com.cloud.storage.template; | |||||||
| 
 | 
 | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
|  | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; |  | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
| import com.cloud.storage.VMTemplateHostVO; | import com.cloud.storage.VMTemplateHostVO; | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
|  | |||||||
| @ -47,6 +47,10 @@ import java.util.concurrent.Executors; | |||||||
| import javax.ejb.Local; | import javax.ejb.Local; | ||||||
| import javax.naming.ConfigurationException; | import javax.naming.ConfigurationException; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
| import org.apache.commons.httpclient.Credentials; | import org.apache.commons.httpclient.Credentials; | ||||||
| import org.apache.commons.httpclient.HttpClient; | import org.apache.commons.httpclient.HttpClient; | ||||||
| import org.apache.commons.httpclient.MultiThreadedHttpConnectionManager; | import org.apache.commons.httpclient.MultiThreadedHttpConnectionManager; | ||||||
| @ -56,11 +60,7 @@ import org.apache.log4j.Logger; | |||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; |  | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
| import com.cloud.exception.InternalErrorException; | import com.cloud.exception.InternalErrorException; | ||||||
| @ -649,29 +649,8 @@ public class DownloadManagerImpl extends ManagerBase implements DownloadManager | |||||||
|             return new DownloadAnswer("Invalid Name", VMTemplateStorageResourceAssoc.Status.DOWNLOAD_ERROR); |             return new DownloadAnswer("Invalid Name", VMTemplateStorageResourceAssoc.Status.DOWNLOAD_ERROR); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         String installPathPrefix = null; |         String installPathPrefix = cmd.getInstallPath(); | ||||||
|         DataStoreTO dstore = cmd.getDataStore(); |         DataStoreTO dstore = cmd.getDataStore(); | ||||||
|         if (dstore instanceof S3TO) { |  | ||||||
|             if (resourceType == ResourceType.TEMPLATE) { |  | ||||||
|                 // convention is no / in the end for install path based on |  | ||||||
|                 // S3Utils implementation. |  | ||||||
|                 // template key is |  | ||||||
|                 // TEMPLATE_ROOT_DIR/account_id/template_id/template_name, by |  | ||||||
|                 // adding template_name in the key, I can avoid generating a |  | ||||||
|                 // template.properties file |  | ||||||
|                 // for listTemplateCommand. |  | ||||||
|                 installPathPrefix = join(asList(_templateDir, cmd.getAccountId(), cmd.getId(), cmd.getName()), S3Utils.SEPARATOR); |  | ||||||
|             } else { |  | ||||||
|                 installPathPrefix = join(asList(_volumeDir, cmd.getAccountId(), cmd.getId()), S3Utils.SEPARATOR); |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             if (ResourceType.TEMPLATE == resourceType) { |  | ||||||
|                 installPathPrefix = resource.getRootDir(cmd) + File.separator + _templateDir; |  | ||||||
|             } else { |  | ||||||
|                 installPathPrefix = resource.getRootDir(cmd) + File.separator + _volumeDir; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         String user = null; |         String user = null; | ||||||
|         String password = null; |         String password = null; | ||||||
|         if (cmd.getAuth() != null) { |         if (cmd.getAuth() != null) { | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ import java.net.URISyntaxException; | |||||||
| import java.net.UnknownHostException; | import java.net.UnknownHostException; | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
| import org.apache.commons.httpclient.ChunkedInputStream; | import org.apache.commons.httpclient.ChunkedInputStream; | ||||||
| import org.apache.commons.httpclient.Credentials; | import org.apache.commons.httpclient.Credentials; | ||||||
| import org.apache.commons.httpclient.Header; | import org.apache.commons.httpclient.Header; | ||||||
| @ -45,8 +46,7 @@ import org.apache.commons.httpclient.methods.GetMethod; | |||||||
| import org.apache.commons.httpclient.params.HttpMethodParams; | import org.apache.commons.httpclient.params.HttpMethodParams; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.storage.StorageLayer; | import com.cloud.storage.StorageLayer; | ||||||
| import com.cloud.utils.exception.CloudRuntimeException; | import com.cloud.utils.exception.CloudRuntimeException; | ||||||
| import com.cloud.utils.Pair; | import com.cloud.utils.Pair; | ||||||
| @ -79,7 +79,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 	private ResourceType resourceType = ResourceType.TEMPLATE; | 	private ResourceType resourceType = ResourceType.TEMPLATE; | ||||||
| 	private final HttpMethodRetryHandler myretryhandler; | 	private final HttpMethodRetryHandler myretryhandler; | ||||||
| 
 | 
 | ||||||
| 	 | 
 | ||||||
| 
 | 
 | ||||||
| 	public HttpTemplateDownloader (StorageLayer storageLayer, String downloadUrl, String toDir, DownloadCompleteCallback callback, long maxTemplateSizeInBytes, String user, String password, Proxy proxy, ResourceType resourceType) { | 	public HttpTemplateDownloader (StorageLayer storageLayer, String downloadUrl, String toDir, DownloadCompleteCallback callback, long maxTemplateSizeInBytes, String user, String password, Proxy proxy, ResourceType resourceType) { | ||||||
| 		this._storage = storageLayer; | 		this._storage = storageLayer; | ||||||
| @ -88,7 +88,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 		this.status = TemplateDownloader.Status.NOT_STARTED; | 		this.status = TemplateDownloader.Status.NOT_STARTED; | ||||||
| 		this.resourceType = resourceType; | 		this.resourceType = resourceType; | ||||||
| 		this.MAX_TEMPLATE_SIZE_IN_BYTES = maxTemplateSizeInBytes; | 		this.MAX_TEMPLATE_SIZE_IN_BYTES = maxTemplateSizeInBytes; | ||||||
| 		 | 
 | ||||||
| 		this.totalBytes = 0; | 		this.totalBytes = 0; | ||||||
| 		this.client = new HttpClient(s_httpClientManager); | 		this.client = new HttpClient(s_httpClientManager); | ||||||
| 
 | 
 | ||||||
| @ -114,7 +114,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 		        return false; | 		        return false; | ||||||
| 		    } | 		    } | ||||||
| 		}; | 		}; | ||||||
| 		 | 
 | ||||||
| 		try { | 		try { | ||||||
| 			this.request = new GetMethod(downloadUrl); | 			this.request = new GetMethod(downloadUrl); | ||||||
| 			this.request.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, myretryhandler); | 			this.request.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, myretryhandler); | ||||||
| @ -122,14 +122,14 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 			//this.request.setFollowRedirects(false); | 			//this.request.setFollowRedirects(false); | ||||||
| 
 | 
 | ||||||
| 			File f = File.createTempFile("dnld", "tmp_", new File(toDir)); | 			File f = File.createTempFile("dnld", "tmp_", new File(toDir)); | ||||||
| 			 | 
 | ||||||
| 			if (_storage != null) { | 			if (_storage != null) { | ||||||
| 				_storage.setWorldReadableAndWriteable(f); | 				_storage.setWorldReadableAndWriteable(f); | ||||||
| 			} | 			} | ||||||
| 			 | 
 | ||||||
| 			toFile = f.getAbsolutePath(); | 			toFile = f.getAbsolutePath(); | ||||||
| 			Pair<String, Integer> hostAndPort = validateUrl(downloadUrl); | 			Pair<String, Integer> hostAndPort = validateUrl(downloadUrl); | ||||||
| 			 | 
 | ||||||
| 			if (proxy != null) { | 			if (proxy != null) { | ||||||
| 				client.getHostConfiguration().setProxy(proxy.getHost(), proxy.getPort()); | 				client.getHostConfiguration().setProxy(proxy.getHost(), proxy.getPort()); | ||||||
| 				if (proxy.getUserName() != null) { | 				if (proxy.getUserName() != null) { | ||||||
| @ -144,7 +144,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 				s_logger.info("Added username=" + user + ", password=" + password + "for host " + hostAndPort.first() + ":" + hostAndPort.second()); | 				s_logger.info("Added username=" + user + ", password=" + password + "for host " + hostAndPort.first() + ":" + hostAndPort.second()); | ||||||
| 			} else { | 			} else { | ||||||
| 				s_logger.info("No credentials configured for host=" + hostAndPort.first() + ":" + hostAndPort.second()); | 				s_logger.info("No credentials configured for host=" + hostAndPort.first() + ":" + hostAndPort.second()); | ||||||
| 			}  | 			} | ||||||
| 		} catch (IllegalArgumentException iae) { | 		} catch (IllegalArgumentException iae) { | ||||||
| 			errorString = iae.getMessage(); | 			errorString = iae.getMessage(); | ||||||
| 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | ||||||
| @ -157,7 +157,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 		    s_logger.warn("throwable caught ", th); | 		    s_logger.warn("throwable caught ", th); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	 | 
 | ||||||
| 
 | 
 | ||||||
| 	private  Pair<String, Integer> validateUrl(String url) throws IllegalArgumentException { | 	private  Pair<String, Integer> validateUrl(String url) throws IllegalArgumentException { | ||||||
| 		try { | 		try { | ||||||
| @ -169,13 +169,13 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 			if (!(port == 80 || port == 443 || port == -1)) { | 			if (!(port == 80 || port == 443 || port == -1)) { | ||||||
| 				throw new IllegalArgumentException("Only ports 80 and 443 are allowed"); | 				throw new IllegalArgumentException("Only ports 80 and 443 are allowed"); | ||||||
| 			} | 			} | ||||||
| 			 | 
 | ||||||
| 			if (port == -1 && uri.getScheme().equalsIgnoreCase("https")) { | 			if (port == -1 && uri.getScheme().equalsIgnoreCase("https")) { | ||||||
| 				port = 443; | 				port = 443; | ||||||
| 			} else if (port == -1 && uri.getScheme().equalsIgnoreCase("http")) { | 			} else if (port == -1 && uri.getScheme().equalsIgnoreCase("http")) { | ||||||
| 				port = 80; | 				port = 80; | ||||||
| 			} | 			} | ||||||
| 			 | 
 | ||||||
| 			String host = uri.getHost(); | 			String host = uri.getHost(); | ||||||
| 			try { | 			try { | ||||||
| 				InetAddress hostAddr = InetAddress.getByName(host); | 				InetAddress hostAddr = InetAddress.getByName(host); | ||||||
| @ -197,7 +197,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 			throw new IllegalArgumentException(use.getMessage()); | 			throw new IllegalArgumentException(use.getMessage()); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	 | 
 | ||||||
| 	@Override | 	@Override | ||||||
| 	public long download(boolean resume, DownloadCompleteCallback callback) { | 	public long download(boolean resume, DownloadCompleteCallback callback) { | ||||||
| 		switch (status) { | 		switch (status) { | ||||||
| @ -211,17 +211,17 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
|         int bytes=0; |         int bytes=0; | ||||||
| 		File file = new File(toFile); | 		File file = new File(toFile); | ||||||
| 		try { | 		try { | ||||||
| 			 | 
 | ||||||
| 			long localFileSize = 0; | 			long localFileSize = 0; | ||||||
| 			if (file.exists() && resume) { | 			if (file.exists() && resume) { | ||||||
| 				localFileSize = file.length(); | 				localFileSize = file.length(); | ||||||
| 				s_logger.info("Resuming download to file (current size)=" + localFileSize); | 				s_logger.info("Resuming download to file (current size)=" + localFileSize); | ||||||
| 			} | 			} | ||||||
| 			 | 
 | ||||||
|             Date start = new Date(); |             Date start = new Date(); | ||||||
| 
 | 
 | ||||||
| 			int responseCode=0; | 			int responseCode=0; | ||||||
| 			 | 
 | ||||||
| 			if (localFileSize > 0 ) { | 			if (localFileSize > 0 ) { | ||||||
| 				// require partial content support for resume | 				// require partial content support for resume | ||||||
| 				request.addRequestHeader("Range", "bytes=" + localFileSize + "-"); | 				request.addRequestHeader("Range", "bytes=" + localFileSize + "-"); | ||||||
| @ -235,7 +235,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 				errorString = " HTTP Server returned " + responseCode + " (expected 200 OK) "; | 				errorString = " HTTP Server returned " + responseCode + " (expected 200 OK) "; | ||||||
|                 return 0; //FIXME: retry? |                 return 0; //FIXME: retry? | ||||||
|             } |             } | ||||||
| 			 | 
 | ||||||
|             Header contentLengthHeader = request.getResponseHeader("Content-Length"); |             Header contentLengthHeader = request.getResponseHeader("Content-Length"); | ||||||
|             boolean chunked = false; |             boolean chunked = false; | ||||||
|             long remoteSize2 = 0; |             long remoteSize2 = 0; | ||||||
| @ -255,26 +255,26 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
|             if (remoteSize == 0) { |             if (remoteSize == 0) { | ||||||
|             	remoteSize = remoteSize2; |             	remoteSize = remoteSize2; | ||||||
|             } |             } | ||||||
|              | 
 | ||||||
|             if (remoteSize > MAX_TEMPLATE_SIZE_IN_BYTES) { |             if (remoteSize > MAX_TEMPLATE_SIZE_IN_BYTES) { | ||||||
|             	s_logger.info("Remote size is too large: " + remoteSize + " , max=" + MAX_TEMPLATE_SIZE_IN_BYTES); |             	s_logger.info("Remote size is too large: " + remoteSize + " , max=" + MAX_TEMPLATE_SIZE_IN_BYTES); | ||||||
|             	status = Status.UNRECOVERABLE_ERROR; |             	status = Status.UNRECOVERABLE_ERROR; | ||||||
|             	errorString = "Download file size is too large"; |             	errorString = "Download file size is too large"; | ||||||
|             	return 0; |             	return 0; | ||||||
|             } |             } | ||||||
|              | 
 | ||||||
|             if (remoteSize == 0) { |             if (remoteSize == 0) { | ||||||
|             	remoteSize = MAX_TEMPLATE_SIZE_IN_BYTES; |             	remoteSize = MAX_TEMPLATE_SIZE_IN_BYTES; | ||||||
|             } |             } | ||||||
|              | 
 | ||||||
|             InputStream in = !chunked?new BufferedInputStream(request.getResponseBodyAsStream()) |             InputStream in = !chunked?new BufferedInputStream(request.getResponseBodyAsStream()) | ||||||
|             						: new ChunkedInputStream(request.getResponseBodyAsStream()); |             						: new ChunkedInputStream(request.getResponseBodyAsStream()); | ||||||
|              | 
 | ||||||
|             RandomAccessFile out = new RandomAccessFile(file, "rwd"); |             RandomAccessFile out = new RandomAccessFile(file, "rwd"); | ||||||
|             out.seek(localFileSize); |             out.seek(localFileSize); | ||||||
| 
 | 
 | ||||||
|             s_logger.info("Starting download from " + getDownloadUrl() + " to " + toFile + " remoteSize=" + remoteSize + " , max size=" + MAX_TEMPLATE_SIZE_IN_BYTES); |             s_logger.info("Starting download from " + getDownloadUrl() + " to " + toFile + " remoteSize=" + remoteSize + " , max size=" + MAX_TEMPLATE_SIZE_IN_BYTES); | ||||||
|              | 
 | ||||||
|             byte[] block = new byte[CHUNK_SIZE]; |             byte[] block = new byte[CHUNK_SIZE]; | ||||||
|             long offset=0; |             long offset=0; | ||||||
|             boolean done=false; |             boolean done=false; | ||||||
| @ -298,7 +298,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
|             errorString = "Downloaded " + totalBytes + " bytes " + downloaded; |             errorString = "Downloaded " + totalBytes + " bytes " + downloaded; | ||||||
|             downloadTime += finish.getTime() - start.getTime(); |             downloadTime += finish.getTime() - start.getTime(); | ||||||
|             out.close(); |             out.close(); | ||||||
|              | 
 | ||||||
|             return totalBytes; |             return totalBytes; | ||||||
| 		}catch (HttpException hte) { | 		}catch (HttpException hte) { | ||||||
| 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | ||||||
| @ -336,8 +336,8 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 	public long getDownloadTime() { | 	public long getDownloadTime() { | ||||||
| 		return downloadTime; | 		return downloadTime; | ||||||
| 	} | 	} | ||||||
| 	 | 
 | ||||||
| 	 | 
 | ||||||
| 	public long getDownloadedBytes() { | 	public long getDownloadedBytes() { | ||||||
| 		return totalBytes; | 		return totalBytes; | ||||||
| 	} | 	} | ||||||
| @ -375,7 +375,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 		if (remoteSize == 0) { | 		if (remoteSize == 0) { | ||||||
| 			return 0; | 			return 0; | ||||||
| 		} | 		} | ||||||
| 		 | 
 | ||||||
| 		return (int)(100.0*totalBytes/remoteSize); | 		return (int)(100.0*totalBytes/remoteSize); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -388,7 +388,7 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 			errorString = "Failed to install: " + t.getMessage(); | 			errorString = "Failed to install: " + t.getMessage(); | ||||||
| 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | 			status = TemplateDownloader.Status.UNRECOVERABLE_ERROR; | ||||||
| 		} | 		} | ||||||
| 		 | 
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	@Override | 	@Override | ||||||
| @ -424,10 +424,10 @@ public class HttpTemplateDownloader implements TemplateDownloader { | |||||||
| 		return toDir; | 		return toDir; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	public long getMaxTemplateSizeInBytes() {  | 	public long getMaxTemplateSizeInBytes() { | ||||||
| 		return this.MAX_TEMPLATE_SIZE_IN_BYTES; | 		return this.MAX_TEMPLATE_SIZE_IN_BYTES; | ||||||
| 	} | 	} | ||||||
| 	 | 
 | ||||||
| 	public static void main(String[] args) { | 	public static void main(String[] args) { | ||||||
| 		String url ="http:// dev.mysql.com/get/Downloads/MySQL-5.0/mysql-noinstall-5.0.77-win32.zip/from/http://mirror.services.wisc.edu/mysql/"; | 		String url ="http:// dev.mysql.com/get/Downloads/MySQL-5.0/mysql-noinstall-5.0.77-win32.zip/from/http://mirror.services.wisc.edu/mysql/"; | ||||||
| 		try { | 		try { | ||||||
|  | |||||||
| @ -32,6 +32,7 @@ import java.net.URL; | |||||||
| import java.net.UnknownHostException; | import java.net.UnknownHostException; | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
| import org.apache.commons.httpclient.ChunkedInputStream; | import org.apache.commons.httpclient.ChunkedInputStream; | ||||||
| import org.apache.commons.httpclient.Credentials; | import org.apache.commons.httpclient.Credentials; | ||||||
| import org.apache.commons.httpclient.Header; | import org.apache.commons.httpclient.Header; | ||||||
| @ -52,8 +53,7 @@ import com.amazonaws.services.s3.model.ProgressEvent; | |||||||
| import com.amazonaws.services.s3.model.ProgressListener; | import com.amazonaws.services.s3.model.ProgressListener; | ||||||
| import com.amazonaws.services.s3.model.PutObjectRequest; | import com.amazonaws.services.s3.model.PutObjectRequest; | ||||||
| import com.amazonaws.services.s3.model.StorageClass; | import com.amazonaws.services.s3.model.StorageClass; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
| import com.cloud.utils.Pair; | import com.cloud.utils.Pair; | ||||||
| import com.cloud.utils.S3Utils; | import com.cloud.utils.S3Utils; | ||||||
|  | |||||||
| @ -24,9 +24,9 @@ import java.util.ArrayList; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| import java.util.Properties; | import java.util.Properties; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
| import com.cloud.storage.StorageLayer; | import com.cloud.storage.StorageLayer; | ||||||
| import com.cloud.storage.template.Processor.FormatInfo; | import com.cloud.storage.template.Processor.FormatInfo; | ||||||
|  | |||||||
| @ -20,6 +20,8 @@ import java.nio.ByteBuffer; | |||||||
| 
 | 
 | ||||||
| import junit.framework.TestCase; | import junit.framework.TestCase; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.to.TemplateObjectTO; | ||||||
| import org.apache.log4j.Level; | import org.apache.log4j.Level; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.junit.Assert; | import org.junit.Assert; | ||||||
| @ -30,7 +32,6 @@ import com.cloud.agent.api.GetHostStatsCommand; | |||||||
| import com.cloud.agent.api.SecStorageFirewallCfgCommand; | import com.cloud.agent.api.SecStorageFirewallCfgCommand; | ||||||
| import com.cloud.agent.api.UpdateHostPasswordCommand; | import com.cloud.agent.api.UpdateHostPasswordCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
| import com.cloud.exception.UnsupportedVersionException; | import com.cloud.exception.UnsupportedVersionException; | ||||||
| import com.cloud.hypervisor.Hypervisor.HypervisorType; | import com.cloud.hypervisor.Hypervisor.HypervisorType; | ||||||
| @ -132,7 +133,10 @@ public class RequestTest extends TestCase { | |||||||
|         s_logger.info("Testing Download answer"); |         s_logger.info("Testing Download answer"); | ||||||
|         VMTemplateVO template = new VMTemplateVO(1, "templatename", ImageFormat.QCOW2, true, true, true, TemplateType.USER, "url", true, 32, 1, "chksum", "displayText", true, 30, true, |         VMTemplateVO template = new VMTemplateVO(1, "templatename", ImageFormat.QCOW2, true, true, true, TemplateType.USER, "url", true, 32, 1, "chksum", "displayText", true, 30, true, | ||||||
|                 HypervisorType.KVM, null); |                 HypervisorType.KVM, null); | ||||||
|         DownloadCommand cmd = new DownloadCommand(new NfsTO("secUrl", DataStoreRole.Image), template, 30000000l); |         NfsTO nfs = new NfsTO("secUrl", DataStoreRole.Image); | ||||||
|  |         TemplateObjectTO to = new TemplateObjectTO(template); | ||||||
|  |         to.setImageDataStore(nfs); | ||||||
|  |         DownloadCommand cmd = new DownloadCommand(to, 30000000l); | ||||||
|         Request req = new Request(1, 1, cmd, true); |         Request req = new Request(1, 1, cmd, true); | ||||||
| 
 | 
 | ||||||
|         req.logD("Debug for Download"); |         req.logD("Debug for Download"); | ||||||
|  | |||||||
| @ -18,8 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package org.apache.cloudstack.engine.subsystem.api.storage; | package org.apache.cloudstack.engine.subsystem.api.storage; | ||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.disktype.DiskFormat; |  | ||||||
| 
 |  | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| 
 | 
 | ||||||
| public interface DataObject { | public interface DataObject { | ||||||
| @ -29,7 +27,7 @@ public interface DataObject { | |||||||
|     public DataStore getDataStore(); |     public DataStore getDataStore(); | ||||||
|     public Long getSize(); |     public Long getSize(); | ||||||
|     public DataObjectType getType(); |     public DataObjectType getType(); | ||||||
|     public DiskFormat getFormat(); |     //public DiskFormat getFormat(); | ||||||
|     public String getUuid(); |     public String getUuid(); | ||||||
|     public void processEvent(ObjectInDataStoreStateMachine.Event event); |     public void processEvent(ObjectInDataStoreStateMachine.Event event); | ||||||
|     public void processEvent(ObjectInDataStoreStateMachine.Event event, Answer answer); |     public void processEvent(ObjectInDataStoreStateMachine.Event event, Answer answer); | ||||||
|  | |||||||
| @ -18,7 +18,9 @@ | |||||||
|  */ |  */ | ||||||
| package org.apache.cloudstack.engine.subsystem.api.storage; | package org.apache.cloudstack.engine.subsystem.api.storage; | ||||||
| 
 | 
 | ||||||
| public interface TemplateInfo extends DataObject { | import com.cloud.template.VirtualMachineTemplate; | ||||||
|  | 
 | ||||||
|  | public interface TemplateInfo extends DataObject, VirtualMachineTemplate { | ||||||
|     public String getUniqueName(); |     public String getUniqueName(); | ||||||
|     public String getInstallPath(); |     public String getInstallPath(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -28,4 +28,5 @@ public interface VolumeInfo extends DataObject, Volume { | |||||||
| 	public HypervisorType getHypervisorType(); | 	public HypervisorType getHypervisorType(); | ||||||
| 	public Long getLastPoolId(); | 	public Long getLastPoolId(); | ||||||
| 	public String getAttachedVmName(); | 	public String getAttachedVmName(); | ||||||
|  |     public String getInstallPath(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -14,91 +14,27 @@ | |||||||
| // KIND, either express or implied.  See the License for the | // KIND, either express or implied.  See the License for the | ||||||
| // specific language governing permissions and limitations | // specific language governing permissions and limitations | ||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.api.storage; | package org.apache.cloudstack.storage.command; | ||||||
| 
 |  | ||||||
| import java.net.URI; |  | ||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.api.InternalIdentity; | import org.apache.cloudstack.api.InternalIdentity; | ||||||
|  | import org.apache.cloudstack.storage.to.TemplateObjectTO; | ||||||
|  | import org.apache.cloudstack.storage.to.VolumeObjectTO; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.agent.api.storage.AbstractDownloadCommand; | ||||||
|  | import com.cloud.agent.api.storage.PasswordAuth; | ||||||
|  | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
| import com.cloud.storage.Volume; | import com.cloud.storage.Volume; | ||||||
| import com.cloud.template.VirtualMachineTemplate; |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| public class DownloadCommand extends AbstractDownloadCommand implements InternalIdentity { | public class DownloadCommand extends AbstractDownloadCommand implements InternalIdentity { | ||||||
| 	public static class PasswordAuth { |  | ||||||
| 		String userName; |  | ||||||
| 		String password; |  | ||||||
| 		public PasswordAuth() { |  | ||||||
| 
 |  | ||||||
| 		} |  | ||||||
| 		public PasswordAuth(String user, String password) { |  | ||||||
| 			this.userName = user; |  | ||||||
| 			this.password = password; |  | ||||||
| 		} |  | ||||||
| 		public String getUserName() { |  | ||||||
| 			return userName; |  | ||||||
| 		} |  | ||||||
| 		public String getPassword() { |  | ||||||
| 			return password; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
|     public static enum ResourceType { |     public static enum ResourceType { | ||||||
|         VOLUME, TEMPLATE |         VOLUME, TEMPLATE | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 	public static class Proxy { |  | ||||||
| 		private String _host; |  | ||||||
| 		private int _port; |  | ||||||
| 		private String _userName; |  | ||||||
| 		private String _password; |  | ||||||
| 
 |  | ||||||
| 		public Proxy() { |  | ||||||
| 
 |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public Proxy(String host, int port, String userName, String password) { |  | ||||||
| 			this._host = host; |  | ||||||
| 			this._port = port; |  | ||||||
| 			this._userName = userName; |  | ||||||
| 			this._password = password; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public Proxy(URI uri) { |  | ||||||
| 			this._host = uri.getHost(); |  | ||||||
| 			this._port = uri.getPort() == -1 ? 3128 : uri.getPort(); |  | ||||||
| 			String userInfo = uri.getUserInfo(); |  | ||||||
| 			if (userInfo != null) { |  | ||||||
| 				String[] tokens = userInfo.split(":"); |  | ||||||
| 				if (tokens.length == 1) { |  | ||||||
| 					this._userName = userInfo; |  | ||||||
| 					this._password = ""; |  | ||||||
| 				} else if (tokens.length == 2) { |  | ||||||
| 					this._userName = tokens[0]; |  | ||||||
| 					this._password = tokens[1]; |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public String getHost() { |  | ||||||
| 			return _host; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public int getPort() { |  | ||||||
| 			return _port; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public String getUserName() { |  | ||||||
| 			return _userName; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		public String getPassword() { |  | ||||||
| 			return _password; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	private boolean hvm; | 	private boolean hvm; | ||||||
| 	private String description; | 	private String description; | ||||||
| 	private String checksum; | 	private String checksum; | ||||||
| @ -107,6 +43,7 @@ public class DownloadCommand extends AbstractDownloadCommand implements Internal | |||||||
| 	private Long maxDownloadSizeInBytes = null; | 	private Long maxDownloadSizeInBytes = null; | ||||||
| 	private long id; | 	private long id; | ||||||
| 	private ResourceType resourceType = ResourceType.TEMPLATE; | 	private ResourceType resourceType = ResourceType.TEMPLATE; | ||||||
|  | 	private String installPath; | ||||||
| 	private DataStoreTO _store; | 	private DataStoreTO _store; | ||||||
| 
 | 
 | ||||||
| 	protected DownloadCommand() { | 	protected DownloadCommand() { | ||||||
| @ -123,46 +60,39 @@ public class DownloadCommand extends AbstractDownloadCommand implements Internal | |||||||
| 	    this.setSecUrl(that.getSecUrl()); | 	    this.setSecUrl(that.getSecUrl()); | ||||||
| 	    this.maxDownloadSizeInBytes = that.getMaxDownloadSizeInBytes(); | 	    this.maxDownloadSizeInBytes = that.getMaxDownloadSizeInBytes(); | ||||||
| 	    this.resourceType = that.resourceType; | 	    this.resourceType = that.resourceType; | ||||||
|  | 	    this.installPath = that.installPath; | ||||||
|  | 	    this._store = that._store; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	public DownloadCommand(DataStoreTO store, VirtualMachineTemplate template, Long maxDownloadSizeInBytes) { | 	public DownloadCommand(TemplateObjectTO template, Long maxDownloadSizeInBytes) { | ||||||
| 	    super(template.getUniqueName(), template.getUrl(), template.getFormat(), template.getAccountId()); | 	    super(template.getName(), template.getOrigUrl(), template.getFormat(), template.getAccountId()); | ||||||
| 	    this._store = store; | 	    this._store = template.getDataStore(); | ||||||
|  | 	    this.installPath = template.getPath(); | ||||||
| 	    this.hvm = template.isRequiresHvm(); | 	    this.hvm = template.isRequiresHvm(); | ||||||
| 	    this.checksum = template.getChecksum(); | 	    this.checksum = template.getChecksum(); | ||||||
| 	    this.id = template.getId(); | 	    this.id = template.getId(); | ||||||
| 	    this.description = template.getDisplayText(); | 	    this.description = template.getDescription(); | ||||||
|         if (store instanceof NfsTO) { |         if (_store instanceof NfsTO) { | ||||||
|             this.setSecUrl(((NfsTO) store).getUrl()); |             this.setSecUrl(((NfsTO) _store).getUrl()); | ||||||
|         } |         } | ||||||
| 	    this.maxDownloadSizeInBytes = maxDownloadSizeInBytes; | 	    this.maxDownloadSizeInBytes = maxDownloadSizeInBytes; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	public DownloadCommand(DataStoreTO store, Volume volume, Long maxDownloadSizeInBytes, String checkSum, String url, ImageFormat format) { | 	public DownloadCommand(TemplateObjectTO template, String user, String passwd, Long maxDownloadSizeInBytes) { | ||||||
| 	    super(volume.getName(), url, format, volume.getAccountId()); | 	    this(template, maxDownloadSizeInBytes); | ||||||
| 	    //this.hvm = volume.isRequiresHvm(); |  | ||||||
| 	    this.checksum = checkSum; |  | ||||||
| 	    this.id = volume.getId(); |  | ||||||
| 	    this._store = store; |  | ||||||
| 	    this.maxDownloadSizeInBytes = maxDownloadSizeInBytes; |  | ||||||
| 	    this.resourceType = ResourceType.VOLUME; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	public DownloadCommand(DataStoreTO store, String url, VirtualMachineTemplate template, String user, String passwd, Long maxDownloadSizeInBytes) { |  | ||||||
| 	    super(template.getUniqueName(), url, template.getFormat(), template.getAccountId()); |  | ||||||
|         this._store = store; |  | ||||||
| 	    this.hvm = template.isRequiresHvm(); |  | ||||||
|         this.checksum = template.getChecksum(); |  | ||||||
|         this.id = template.getId(); |  | ||||||
|         this.description = template.getDisplayText(); |  | ||||||
|         if (store instanceof NfsTO) { |  | ||||||
|             this.setSecUrl(((NfsTO) store).getUrl()); |  | ||||||
|         } |  | ||||||
|         this.maxDownloadSizeInBytes = maxDownloadSizeInBytes; |  | ||||||
| 		auth = new PasswordAuth(user, passwd); | 		auth = new PasswordAuth(user, passwd); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	public long getId() { |     public DownloadCommand(VolumeObjectTO volume, Long maxDownloadSizeInBytes, String checkSum, String url, ImageFormat format) { | ||||||
|  |         super(volume.getName(), url, format, volume.getAccountId()); | ||||||
|  |         this.checksum = checkSum; | ||||||
|  |         this.id = volume.getVolumeId(); | ||||||
|  |         this._store = volume.getDataStore(); | ||||||
|  |         this.maxDownloadSizeInBytes = maxDownloadSizeInBytes; | ||||||
|  |         this.resourceType = ResourceType.VOLUME; | ||||||
|  |     } | ||||||
|  | 	@Override | ||||||
|  |     public long getId() { | ||||||
| 	    return id; | 	    return id; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -237,6 +167,16 @@ public class DownloadCommand extends AbstractDownloadCommand implements Internal | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |     public String getInstallPath() { | ||||||
|  |         return installPath; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public void setInstallPath(String installPath) { | ||||||
|  |         this.installPath = installPath; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -14,7 +14,8 @@ | |||||||
| // KIND, either express or implied.  See the License for the | // KIND, either express or implied.  See the License for the | ||||||
| // specific language governing permissions and limitations | // specific language governing permissions and limitations | ||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.api.storage; | package org.apache.cloudstack.storage.command; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -14,32 +14,18 @@ | |||||||
| // KIND, either express or implied.  See the License for the | // KIND, either express or implied.  See the License for the | ||||||
| // specific language governing permissions and limitations | // specific language governing permissions and limitations | ||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.api.storage; | package org.apache.cloudstack.storage.command; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Command; | import com.cloud.agent.api.Command; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; | import com.cloud.agent.api.storage.PasswordAuth; | ||||||
|  | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.template.VirtualMachineTemplate; | import com.cloud.template.VirtualMachineTemplate; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| public class DownloadSystemTemplateCommand extends Command { | public class DownloadSystemTemplateCommand extends Command { | ||||||
| 	public static class PasswordAuth { |  | ||||||
| 		String userName; |  | ||||||
| 		String password; |  | ||||||
| 		public PasswordAuth() { |  | ||||||
| 
 |  | ||||||
| 		} |  | ||||||
| 		public PasswordAuth(String user, String password) { |  | ||||||
| 			this.userName = user; |  | ||||||
| 			this.password = password; |  | ||||||
| 		} |  | ||||||
| 		public String getUserName() { |  | ||||||
| 			return userName; |  | ||||||
| 		} |  | ||||||
| 		public String getPassword() { |  | ||||||
| 			return password; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	private PasswordAuth auth; | 	private PasswordAuth auth; | ||||||
| @ -23,40 +23,86 @@ import org.apache.cloudstack.engine.subsystem.api.storage.disktype.DiskFormat; | |||||||
| import org.apache.cloudstack.storage.image.datastore.ImageStoreInfo; | import org.apache.cloudstack.storage.image.datastore.ImageStoreInfo; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
|  | import com.cloud.storage.Storage.ImageFormat; | ||||||
|  | import com.cloud.template.VirtualMachineTemplate; | ||||||
| 
 | 
 | ||||||
| public class TemplateObjectTO implements DataTO { | public class TemplateObjectTO implements DataTO { | ||||||
|     private  String path; |     private  String path; | ||||||
|     private String origUrl; |     private String origUrl; | ||||||
|     private  String uuid; |     private  String uuid; | ||||||
|     private  DiskFormat diskType; |     private long id; | ||||||
|  |     private ImageFormat format; | ||||||
|  |     private long accountId; | ||||||
|  |     private String checksum; | ||||||
|  |     private boolean hvm; | ||||||
|  |     private String displayText; | ||||||
|     private  DataStoreTO imageDataStore; |     private  DataStoreTO imageDataStore; | ||||||
|     private  String name; |     private  String name; | ||||||
| 
 | 
 | ||||||
|     public TemplateObjectTO() { |     public TemplateObjectTO() { | ||||||
|          | 
 | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public TemplateObjectTO(VirtualMachineTemplate template){ | ||||||
|  |         this.uuid = template.getUuid(); | ||||||
|  |         this.id = template.getId(); | ||||||
|  |         this.origUrl = template.getUrl(); | ||||||
|  |         this.displayText = template.getDisplayText(); | ||||||
|  |         this.checksum = template.getChecksum(); | ||||||
|  |         this.hvm = template.isRequiresHvm(); | ||||||
|  |         this.accountId = template.getAccountId(); | ||||||
|  |         this.name = template.getUniqueName(); | ||||||
|  |         this.format = template.getFormat(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public TemplateObjectTO(TemplateInfo template) { |     public TemplateObjectTO(TemplateInfo template) { | ||||||
|         this.path = template.getInstallPath(); |         this.path = template.getInstallPath(); | ||||||
|         this.uuid = template.getUuid(); |         this.uuid = template.getUuid(); | ||||||
|         this.origUrl = template.getUri(); |         this.id = template.getId(); | ||||||
|         //this.diskType = template.getDiskType(); |         this.origUrl = template.getUrl(); | ||||||
|         this.imageDataStore = template.getDataStore().getTO(); |         this.displayText = template.getDisplayText(); | ||||||
|  |         this.checksum = template.getChecksum(); | ||||||
|  |         this.hvm = template.isRequiresHvm(); | ||||||
|  |         this.accountId = template.getAccountId(); | ||||||
|         this.name = template.getUniqueName(); |         this.name = template.getUniqueName(); | ||||||
|  |         this.format = template.getFormat(); | ||||||
|  |         this.imageDataStore = template.getDataStore().getTO(); | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String getPath() { |     public String getPath() { | ||||||
|         return this.path; |         return this.path; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public String getUuid() { |     public String getUuid() { | ||||||
|         return this.uuid; |         return this.uuid; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public DiskFormat getDiskType() { |     public long getId() { | ||||||
|         return this.diskType; |         return id; | ||||||
|  |     } | ||||||
|  |     public ImageFormat getFormat() { | ||||||
|  |         return format; | ||||||
|  |     } | ||||||
|  |     public long getAccountId() { | ||||||
|  |         return accountId; | ||||||
|  |     } | ||||||
|  |     public String getChecksum() { | ||||||
|  |         return checksum; | ||||||
|  |     } | ||||||
|  |     public boolean isRequiresHvm() { | ||||||
|  |         return hvm; | ||||||
|  |     } | ||||||
|  |     public void setRequiresHvm(boolean hvm){ | ||||||
|  |         this.hvm = hvm; | ||||||
|  |     } | ||||||
|  |     public String getDescription() { | ||||||
|  |         return displayText; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setDescription(String desc){ | ||||||
|  |         this.displayText = desc; | ||||||
|     } |     } | ||||||
|      |  | ||||||
|     public DataStoreTO getImageDataStore() { |     public DataStoreTO getImageDataStore() { | ||||||
|         return this.imageDataStore; |         return this.imageDataStore; | ||||||
|     } |     } | ||||||
| @ -92,4 +138,18 @@ public class TemplateObjectTO implements DataTO { | |||||||
| 	public void setOrigUrl(String origUrl) { | 	public void setOrigUrl(String origUrl) { | ||||||
| 		this.origUrl = origUrl; | 		this.origUrl = origUrl; | ||||||
| 	} | 	} | ||||||
|  |     public void setFormat(ImageFormat format) { | ||||||
|  |         this.format = format; | ||||||
|  |     } | ||||||
|  |     public void setAccountId(long accountId) { | ||||||
|  |         this.accountId = accountId; | ||||||
|  |     } | ||||||
|  |     public void setChecksum(String checksum) { | ||||||
|  |         this.checksum = checksum; | ||||||
|  |     } | ||||||
|  |     public void setImageDataStore(DataStoreTO imageDataStore) { | ||||||
|  |         this.imageDataStore = imageDataStore; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -33,16 +33,16 @@ public class VolumeObjectTO implements DataTO { | |||||||
|     private long size; |     private long size; | ||||||
|     private String path; |     private String path; | ||||||
|     private Long volumeId; |     private Long volumeId; | ||||||
|      |     private long accountId; | ||||||
|  | 
 | ||||||
|     public VolumeObjectTO() { |     public VolumeObjectTO() { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public VolumeObjectTO(VolumeInfo volume) { |     public VolumeObjectTO(VolumeInfo volume) { | ||||||
|         this.uuid = volume.getUuid(); |         this.uuid = volume.getUuid(); | ||||||
|         this.path = volume.getUri(); |         this.path = volume.getUri(); | ||||||
|         //this.volumeType = volume.getType(); |         this.accountId = volume.getAccountId(); | ||||||
|         //this.diskType = volume.getDiskType(); |  | ||||||
|         if (volume.getDataStore() != null) { |         if (volume.getDataStore() != null) { | ||||||
|             this.dataStore = volume.getDataStore().getTO(); |             this.dataStore = volume.getDataStore().getTO(); | ||||||
|         } else { |         } else { | ||||||
| @ -52,39 +52,39 @@ public class VolumeObjectTO implements DataTO { | |||||||
|         this.size = volume.getSize(); |         this.size = volume.getSize(); | ||||||
|         this.setVolumeId(volume.getId()); |         this.setVolumeId(volume.getId()); | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public String getUuid() { |     public String getUuid() { | ||||||
|         return this.uuid; |         return this.uuid; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public String getPath() { |     public String getPath() { | ||||||
|         return this.path; |         return this.path; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public VolumeType getVolumeType() { |     public VolumeType getVolumeType() { | ||||||
|         return this.volumeType; |         return this.volumeType; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public DiskFormat getDiskType() { |     public DiskFormat getDiskType() { | ||||||
|         return this.diskType; |         return this.diskType; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public DataStoreTO getDataStore() { |     public DataStoreTO getDataStore() { | ||||||
|         return this.dataStore; |         return this.dataStore; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public void setDataStore(PrimaryDataStoreTO dataStore) { |     public void setDataStore(PrimaryDataStoreTO dataStore) { | ||||||
|         this.dataStore = dataStore; |         this.dataStore = dataStore; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public String getName() { |     public String getName() { | ||||||
|         return this.name; |         return this.name; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public long getSize() { |     public long getSize() { | ||||||
|         return this.size; |         return this.size; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     public DataObjectType getObjectType() { |     public DataObjectType getObjectType() { | ||||||
|         return DataObjectType.VOLUME; |         return DataObjectType.VOLUME; | ||||||
|     } |     } | ||||||
| @ -113,4 +113,13 @@ public class VolumeObjectTO implements DataTO { | |||||||
|         this.volumeId = volumeId; |         this.volumeId = volumeId; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public long getAccountId() { | ||||||
|  |         return accountId; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setAccountId(long accountId) { | ||||||
|  |         this.accountId = accountId; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -187,13 +187,13 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|     @Override |     @Override | ||||||
|     public void handleSysTemplateDownload(HypervisorType hostHyper, Long dcId) { |     public void handleSysTemplateDownload(HypervisorType hostHyper, Long dcId) { | ||||||
|         Set<VMTemplateVO> toBeDownloaded = new HashSet<VMTemplateVO>(); |         Set<VMTemplateVO> toBeDownloaded = new HashSet<VMTemplateVO>(); | ||||||
|         List<DataStore> ssHosts = this._storeMgr.getImageStoresByScope(new ZoneScope(dcId)); |         List<DataStore> stores = this._storeMgr.getImageStoresByScope(new ZoneScope(dcId)); | ||||||
|         if (ssHosts == null || ssHosts.isEmpty()){ |         if (stores == null || stores.isEmpty()){ | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /*Download all the templates in zone with the same hypervisortype*/ |         /*Download all the templates in zone with the same hypervisortype*/ | ||||||
|         for ( DataStore ssHost : ssHosts) { |         for ( DataStore store : stores) { | ||||||
|             List<VMTemplateVO> rtngTmplts = _templateDao.listAllSystemVMTemplates(); |             List<VMTemplateVO> rtngTmplts = _templateDao.listAllSystemVMTemplates(); | ||||||
|             List<VMTemplateVO> defaultBuiltin = _templateDao.listDefaultBuiltinTemplates(); |             List<VMTemplateVO> defaultBuiltin = _templateDao.listDefaultBuiltinTemplates(); | ||||||
| 
 | 
 | ||||||
| @ -211,10 +211,10 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             for (VMTemplateVO template: toBeDownloaded) { |             for (VMTemplateVO template: toBeDownloaded) { | ||||||
|                 TemplateDataStoreVO tmpltHost = _vmTemplateStoreDao.findByStoreTemplate(ssHost.getId(), template.getId()); |                 TemplateDataStoreVO tmpltHost = _vmTemplateStoreDao.findByStoreTemplate(store.getId(), template.getId()); | ||||||
|                 if (tmpltHost == null || tmpltHost.getState() != ObjectInDataStoreStateMachine.State.Ready) { |                 if (tmpltHost == null || tmpltHost.getState() != ObjectInDataStoreStateMachine.State.Ready) { | ||||||
|                 	DataObject tmpl = this._templateFactory.getTemplate(template.getId(), ssHost); |                     TemplateInfo tmplt = this._templateFactory.getTemplate(template.getId()); | ||||||
|                     _dlMonitor.downloadTemplateToStorage(tmpl, ssHost, null); |                     this.createTemplateAsync(tmplt, store, null); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -370,8 +370,8 @@ public class TemplateServiceImpl implements TemplateService { | |||||||
|                     } |                     } | ||||||
|                     s_logger.debug("Template " + tmplt.getName() + " needs to be downloaded to " + store.getName()); |                     s_logger.debug("Template " + tmplt.getName() + " needs to be downloaded to " + store.getName()); | ||||||
|                     //TODO: we should pass a callback here |                     //TODO: we should pass a callback here | ||||||
|                     DataObject tmpl = this._templateFactory.getTemplate(tmplt.getId(), store); |                     TemplateInfo tmpl = this._templateFactory.getTemplate(tmplt.getId()); | ||||||
|                     _dlMonitor.downloadTemplateToStorage(tmpl, store, null); |                     this.createTemplateAsync(tmpl, store, null); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -18,6 +18,9 @@ | |||||||
|  */ |  */ | ||||||
| package org.apache.cloudstack.storage.image.store; | package org.apache.cloudstack.storage.image.store; | ||||||
| 
 | 
 | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.Map; | ||||||
|  | 
 | ||||||
| import javax.inject.Inject; | import javax.inject.Inject; | ||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataObjectInStore; | import org.apache.cloudstack.engine.subsystem.api.storage.DataObjectInStore; | ||||||
| @ -28,7 +31,6 @@ import org.apache.cloudstack.engine.subsystem.api.storage.ObjectInDataStoreState | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.ObjectInDataStoreStateMachine.Event; | import org.apache.cloudstack.engine.subsystem.api.storage.ObjectInDataStoreStateMachine.Event; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.TemplateEvent; | import org.apache.cloudstack.engine.subsystem.api.storage.TemplateEvent; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.TemplateInfo; | import org.apache.cloudstack.engine.subsystem.api.storage.TemplateInfo; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.disktype.DiskFormat; |  | ||||||
| import org.apache.cloudstack.storage.command.CopyCmdAnswer; | import org.apache.cloudstack.storage.command.CopyCmdAnswer; | ||||||
| import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | ||||||
| import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreDao; | import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreDao; | ||||||
| @ -38,7 +40,10 @@ import org.apache.cloudstack.storage.to.TemplateObjectTO; | |||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
|  | import com.cloud.hypervisor.Hypervisor.HypervisorType; | ||||||
| import com.cloud.storage.DataStoreRole; | import com.cloud.storage.DataStoreRole; | ||||||
|  | import com.cloud.storage.Storage.ImageFormat; | ||||||
|  | import com.cloud.storage.Storage.TemplateType; | ||||||
| import com.cloud.storage.VMTemplateStoragePoolVO; | import com.cloud.storage.VMTemplateStoragePoolVO; | ||||||
| import com.cloud.storage.VMTemplateVO; | import com.cloud.storage.VMTemplateVO; | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| @ -108,9 +113,9 @@ public class TemplateObject implements TemplateInfo { | |||||||
|     @Override |     @Override | ||||||
|     public String getUri() { |     public String getUri() { | ||||||
|         VMTemplateVO image = imageDao.findById(this.imageVO.getId()); |         VMTemplateVO image = imageDao.findById(this.imageVO.getId()); | ||||||
|         | 
 | ||||||
|             return image.getUrl(); |             return image.getUrl(); | ||||||
|         | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
| @ -153,8 +158,8 @@ public class TemplateObject implements TemplateInfo { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public DiskFormat getFormat() { |     public ImageFormat getFormat() { | ||||||
|         return DiskFormat.valueOf(this.imageVO.getFormat().toString()); |         return this.imageVO.getFormat(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public boolean stateTransit(TemplateEvent e) throws NoTransitionException { |     public boolean stateTransit(TemplateEvent e) throws NoTransitionException { | ||||||
| @ -188,7 +193,7 @@ public class TemplateObject implements TemplateInfo { | |||||||
|         			templatePoolRef.setInstallPath(newTemplate.getPath()); |         			templatePoolRef.setInstallPath(newTemplate.getPath()); | ||||||
|         			templatePoolDao.update(templatePoolRef.getId(), templatePoolRef); |         			templatePoolDao.update(templatePoolRef.getId(), templatePoolRef); | ||||||
|         		} |         		} | ||||||
|         	} else if (this.getDataStore().getRole() == DataStoreRole.Image ||  |         	} else if (this.getDataStore().getRole() == DataStoreRole.Image || | ||||||
|         			this.getDataStore().getRole() == DataStoreRole.ImageCache) { |         			this.getDataStore().getRole() == DataStoreRole.ImageCache) { | ||||||
|         		if (answer instanceof CopyCmdAnswer) { |         		if (answer instanceof CopyCmdAnswer) { | ||||||
|         			CopyCmdAnswer cpyAnswer = (CopyCmdAnswer)answer; |         			CopyCmdAnswer cpyAnswer = (CopyCmdAnswer)answer; | ||||||
| @ -221,4 +226,115 @@ public class TemplateObject implements TemplateInfo { | |||||||
| 		 DataObjectInStore obj = ojbectInStoreMgr.findObject(this, this.dataStore); | 		 DataObjectInStore obj = ojbectInStoreMgr.findObject(this, this.dataStore); | ||||||
|          return obj.getInstallPath(); |          return obj.getInstallPath(); | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public long getAccountId() { | ||||||
|  |         return this.imageVO.getAccountId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isFeatured() { | ||||||
|  |         return this.imageVO.isFeatured(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isPublicTemplate() { | ||||||
|  |         return this.imageVO.isPublicTemplate(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isExtractable() { | ||||||
|  |         return this.imageVO.isExtractable(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getName() { | ||||||
|  |         return this.imageVO.getName(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isRequiresHvm() { | ||||||
|  |         return this.imageVO.isRequiresHvm(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getDisplayText() { | ||||||
|  |         return this.imageVO.getDisplayText(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean getEnablePassword() { | ||||||
|  |         return this.imageVO.getEnablePassword(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean getEnableSshKey() { | ||||||
|  |         return this.imageVO.getEnableSshKey(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isCrossZones() { | ||||||
|  |         return this.imageVO.isCrossZones(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Date getCreated() { | ||||||
|  |         return this.imageVO.getCreated(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public long getGuestOSId() { | ||||||
|  |         return this.imageVO.getGuestOSId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isBootable() { | ||||||
|  |         return this.imageVO.isBootable(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public TemplateType getTemplateType() { | ||||||
|  |         return this.imageVO.getTemplateType(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public HypervisorType getHypervisorType() { | ||||||
|  |         return this.imageVO.getHypervisorType(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public int getBits() { | ||||||
|  |         return this.imageVO.getBits(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getUrl() { | ||||||
|  |         return this.imageVO.getUrl(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getChecksum() { | ||||||
|  |         return this.imageVO.getChecksum(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Long getSourceTemplateId() { | ||||||
|  |         return this.imageVO.getSourceTemplateId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getTemplateTag() { | ||||||
|  |         return this.imageVO.getTemplateTag(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Map getDetails() { | ||||||
|  |         return this.imageVO.getDetails(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public long getDomainId() { | ||||||
|  |         return this.imageVO.getDomainId(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -30,7 +30,6 @@ import org.apache.cloudstack.engine.subsystem.api.storage.SnapshotDataFactory; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.SnapshotInfo; | import org.apache.cloudstack.engine.subsystem.api.storage.SnapshotInfo; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.VolumeDataFactory; | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeDataFactory; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.disktype.DiskFormat; |  | ||||||
| import org.apache.cloudstack.storage.command.CopyCmdAnswer; | import org.apache.cloudstack.storage.command.CopyCmdAnswer; | ||||||
| import org.apache.cloudstack.storage.command.CreateObjectAnswer; | import org.apache.cloudstack.storage.command.CreateObjectAnswer; | ||||||
| import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | ||||||
| @ -93,12 +92,12 @@ public class SnapshotObject implements SnapshotInfo { | |||||||
|     	if (snapStoreVO == null) { |     	if (snapStoreVO == null) { | ||||||
|     	    return null; |     	    return null; | ||||||
|     	} |     	} | ||||||
|     	 | 
 | ||||||
|     	long parentId = snapStoreVO.getParentSnapshotId(); |     	long parentId = snapStoreVO.getParentSnapshotId(); | ||||||
|     	if (parentId == 0) { |     	if (parentId == 0) { | ||||||
|     	    return null; |     	    return null; | ||||||
|     	} |     	} | ||||||
|     	 | 
 | ||||||
|     	return this.snapshotFactory.getSnapshot(parentId, store); |     	return this.snapshotFactory.getSnapshot(parentId, store); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -145,10 +144,6 @@ public class SnapshotObject implements SnapshotInfo { | |||||||
|     	return DataObjectType.SNAPSHOT; |     	return DataObjectType.SNAPSHOT; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |  | ||||||
|     public DiskFormat getFormat() { |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String getUuid() { |     public String getUuid() { | ||||||
| @ -247,7 +242,7 @@ public class SnapshotObject implements SnapshotInfo { | |||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void processEvent(ObjectInDataStoreStateMachine.Event event, Answer answer) { |     public void processEvent(ObjectInDataStoreStateMachine.Event event, Answer answer) { | ||||||
|     	SnapshotDataStoreVO snapshotStore = this.snapshotStoreDao.findByStoreSnapshot(this.getDataStore().getRole(),  |     	SnapshotDataStoreVO snapshotStore = this.snapshotStoreDao.findByStoreSnapshot(this.getDataStore().getRole(), | ||||||
|     		   this.getDataStore().getId(), this.getId()); |     		   this.getDataStore().getId(), this.getId()); | ||||||
|     	if (answer instanceof CreateObjectAnswer) { |     	if (answer instanceof CreateObjectAnswer) { | ||||||
|     		SnapshotObjectTO snapshotTO = (SnapshotObjectTO)((CreateObjectAnswer) answer).getData(); |     		SnapshotObjectTO snapshotTO = (SnapshotObjectTO)((CreateObjectAnswer) answer).getData(); | ||||||
| @ -274,7 +269,7 @@ public class SnapshotObject implements SnapshotInfo { | |||||||
| 	@Override | 	@Override | ||||||
| 	public void addPayload(Object data) { | 	public void addPayload(Object data) { | ||||||
| 		// TODO Auto-generated method stub | 		// TODO Auto-generated method stub | ||||||
| 		 | 
 | ||||||
| 	} | 	} | ||||||
|      | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -7,12 +7,12 @@ import java.util.concurrent.TimeUnit; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
| import org.apache.cloudstack.storage.command.CopyCommand; | import org.apache.cloudstack.storage.command.CopyCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.Listener; | import com.cloud.agent.Listener; | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| import com.cloud.agent.api.Command; | import com.cloud.agent.api.Command; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.resource.ServerResource; | import com.cloud.resource.ServerResource; | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc; | import com.cloud.storage.VMTemplateStorageResourceAssoc; | ||||||
| import com.cloud.storage.download.DownloadListener; | import com.cloud.storage.download.DownloadListener; | ||||||
|  | |||||||
| @ -26,7 +26,6 @@ import org.apache.cloudstack.engine.subsystem.api.storage.DataStore; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.ObjectInDataStoreStateMachine; | import org.apache.cloudstack.engine.subsystem.api.storage.ObjectInDataStoreStateMachine; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.disktype.DiskFormat; |  | ||||||
| import org.apache.cloudstack.storage.command.CopyCmdAnswer; | import org.apache.cloudstack.storage.command.CopyCmdAnswer; | ||||||
| import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | import org.apache.cloudstack.storage.datastore.ObjectInDataStoreManager; | ||||||
| import org.apache.cloudstack.storage.datastore.db.VolumeDataStoreDao; | import org.apache.cloudstack.storage.datastore.db.VolumeDataStoreDao; | ||||||
| @ -78,7 +77,8 @@ public class VolumeObject implements VolumeInfo { | |||||||
|         vo.configure(dataStore, volumeVO); |         vo.configure(dataStore, volumeVO); | ||||||
|         return vo; |         return vo; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|  |     @Override | ||||||
|     public String getAttachedVmName() { |     public String getAttachedVmName() { | ||||||
|         Long vmId = this.volumeVO.getInstanceId(); |         Long vmId = this.volumeVO.getInstanceId(); | ||||||
|         if (vmId != null) { |         if (vmId != null) { | ||||||
| @ -97,14 +97,15 @@ public class VolumeObject implements VolumeInfo { | |||||||
|         return volumeVO.getUuid(); |         return volumeVO.getUuid(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void setPath(String uuid) { |     public void setUuid(String uuid) { | ||||||
|         volumeVO.setPath(uuid); |         volumeVO.setUuid(uuid); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void setSize(Long size) { |     public void setSize(Long size) { | ||||||
|     	volumeVO.setSize(size); |     	volumeVO.setSize(size); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|     public Volume.State getState() { |     public Volume.State getState() { | ||||||
|         return volumeVO.getState(); |         return volumeVO.getState(); | ||||||
|     } |     } | ||||||
| @ -119,6 +120,12 @@ public class VolumeObject implements VolumeInfo { | |||||||
|         return volumeVO.getSize(); |         return volumeVO.getSize(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getInstallPath() { | ||||||
|  |          DataObjectInStore obj = ojbectInStoreMgr.findObject(this, this.dataStore); | ||||||
|  |          return obj.getInstallPath(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public long getVolumeId() { |     public long getVolumeId() { | ||||||
|         return volumeVO.getId(); |         return volumeVO.getId(); | ||||||
|     } |     } | ||||||
| @ -174,11 +181,6 @@ public class VolumeObject implements VolumeInfo { | |||||||
|         return DataObjectType.VOLUME; |         return DataObjectType.VOLUME; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |  | ||||||
|     public DiskFormat getFormat() { |  | ||||||
|         // TODO Auto-generated method stub |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void processEvent( |     public void processEvent( | ||||||
| @ -388,7 +390,7 @@ public class VolumeObject implements VolumeInfo { | |||||||
|                this.volumeStoreDao.update(volStore.getId(), volStore); |                this.volumeStoreDao.update(volStore.getId(), volStore); | ||||||
|            } |            } | ||||||
|        } |        } | ||||||
|         | 
 | ||||||
|        this.processEvent(event); |        this.processEvent(event); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -70,7 +70,6 @@ import com.cloud.storage.Volume.Type; | |||||||
| import com.cloud.storage.VolumeVO; | import com.cloud.storage.VolumeVO; | ||||||
| import com.cloud.storage.dao.VolumeDao; | import com.cloud.storage.dao.VolumeDao; | ||||||
| import com.cloud.storage.download.DownloadMonitor; | import com.cloud.storage.download.DownloadMonitor; | ||||||
| import com.cloud.storage.secondary.SecondaryStorageVmManager; |  | ||||||
| import com.cloud.storage.snapshot.SnapshotManager; | import com.cloud.storage.snapshot.SnapshotManager; | ||||||
| import com.cloud.storage.template.TemplateProp; | import com.cloud.storage.template.TemplateProp; | ||||||
| import com.cloud.user.AccountManager; | import com.cloud.user.AccountManager; | ||||||
| @ -643,9 +642,9 @@ public class VolumeServiceImpl implements VolumeService { | |||||||
| 
 | 
 | ||||||
|         AsyncCallFuture<VolumeApiResult> future = new AsyncCallFuture<VolumeApiResult>(); |         AsyncCallFuture<VolumeApiResult> future = new AsyncCallFuture<VolumeApiResult>(); | ||||||
|         DataObject volumeOnStore = store.create(volume); |         DataObject volumeOnStore = store.create(volume); | ||||||
|          | 
 | ||||||
|         volumeOnStore.processEvent(Event.CreateOnlyRequested); |         volumeOnStore.processEvent(Event.CreateOnlyRequested); | ||||||
|          | 
 | ||||||
|         CreateVolumeContext<VolumeApiResult> context = new CreateVolumeContext<VolumeApiResult>(null, volumeOnStore, future); |         CreateVolumeContext<VolumeApiResult> context = new CreateVolumeContext<VolumeApiResult>(null, volumeOnStore, future); | ||||||
|         AsyncCallbackDispatcher<VolumeServiceImpl, CreateCmdResult> caller = AsyncCallbackDispatcher.create(this); |         AsyncCallbackDispatcher<VolumeServiceImpl, CreateCmdResult> caller = AsyncCallbackDispatcher.create(this); | ||||||
|         caller.setCallback(caller.getTarget().registerVolumeCallback(null, null)) |         caller.setCallback(caller.getTarget().registerVolumeCallback(null, null)) | ||||||
| @ -657,7 +656,7 @@ public class VolumeServiceImpl implements VolumeService { | |||||||
| 
 | 
 | ||||||
|     protected Void registerVolumeCallback(AsyncCallbackDispatcher<VolumeServiceImpl, CreateCmdResult> callback, CreateVolumeContext<VolumeApiResult> context) { |     protected Void registerVolumeCallback(AsyncCallbackDispatcher<VolumeServiceImpl, CreateCmdResult> callback, CreateVolumeContext<VolumeApiResult> context) { | ||||||
|         CreateCmdResult result = callback.getResult(); |         CreateCmdResult result = callback.getResult(); | ||||||
|          | 
 | ||||||
|         VolumeObject vo = (VolumeObject)context.volume; |         VolumeObject vo = (VolumeObject)context.volume; | ||||||
|         if (result.isFailed()) { |         if (result.isFailed()) { | ||||||
|             vo.processEvent(Event.OperationFailed); |             vo.processEvent(Event.OperationFailed); | ||||||
| @ -813,7 +812,8 @@ public class VolumeServiceImpl implements VolumeService { | |||||||
|                 } |                 } | ||||||
|                 s_logger.debug("Volume " + volumeHost.getVolumeId() + " needs to be downloaded to " + store.getName()); |                 s_logger.debug("Volume " + volumeHost.getVolumeId() + " needs to be downloaded to " + store.getName()); | ||||||
|                 //TODO: pass a callback later |                 //TODO: pass a callback later | ||||||
|                 downloadMonitor.downloadVolumeToStorage(this.volFactory.getVolume(volumeHost.getVolumeId()), store,  volumeHost.getDownloadUrl(), volumeHost.getChecksum(), volumeHost.getFormat(), null); |                 VolumeInfo vol = this.volFactory.getVolume(volumeHost.getVolumeId()); | ||||||
|  |                 this.createVolumeAsync(vol, store); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -843,12 +843,12 @@ public class VolumeServiceImpl implements VolumeService { | |||||||
| 
 | 
 | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|     @Override |     @Override | ||||||
|     public SnapshotInfo takeSnapshot(VolumeInfo volume) { |     public SnapshotInfo takeSnapshot(VolumeInfo volume) { | ||||||
|     	VolumeObject vol = (VolumeObject)volume; |     	VolumeObject vol = (VolumeObject)volume; | ||||||
|     	vol.stateTransit(Volume.Event.SnapshotRequested); |     	vol.stateTransit(Volume.Event.SnapshotRequested); | ||||||
|     	 | 
 | ||||||
|     	SnapshotInfo snapshot = null; |     	SnapshotInfo snapshot = null; | ||||||
|     	try { |     	try { | ||||||
|     		snapshot = this.snapshotMgr.takeSnapshot(volume); |     		snapshot = this.snapshotMgr.takeSnapshot(volume); | ||||||
| @ -861,7 +861,7 @@ public class VolumeServiceImpl implements VolumeService { | |||||||
| 				vol.stateTransit(Volume.Event.OperationFailed); | 				vol.stateTransit(Volume.Event.OperationFailed); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | 
 | ||||||
|     	return snapshot; |     	return snapshot; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,6 +16,9 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.manager; | package com.cloud.agent.manager; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
|  | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| import com.cloud.agent.api.AttachIsoCommand; | import com.cloud.agent.api.AttachIsoCommand; | ||||||
| import com.cloud.agent.api.AttachVolumeAnswer; | import com.cloud.agent.api.AttachVolumeAnswer; | ||||||
| @ -41,8 +44,6 @@ import com.cloud.agent.api.storage.CreateAnswer; | |||||||
| import com.cloud.agent.api.storage.CreateCommand; | import com.cloud.agent.api.storage.CreateCommand; | ||||||
| import com.cloud.agent.api.storage.DeleteTemplateCommand; | import com.cloud.agent.api.storage.DeleteTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.DestroyCommand; | import com.cloud.agent.api.storage.DestroyCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.ListTemplateCommand; | import com.cloud.agent.api.storage.ListTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.ListVolumeCommand; | import com.cloud.agent.api.storage.ListVolumeCommand; | ||||||
| import com.cloud.agent.api.storage.PrimaryStorageDownloadAnswer; | import com.cloud.agent.api.storage.PrimaryStorageDownloadAnswer; | ||||||
|  | |||||||
| @ -48,8 +48,6 @@ import com.cloud.agent.api.storage.CreatePrivateTemplateAnswer; | |||||||
| import com.cloud.agent.api.storage.DeleteTemplateCommand; | import com.cloud.agent.api.storage.DeleteTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.DestroyCommand; | import com.cloud.agent.api.storage.DestroyCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.ListTemplateAnswer; | import com.cloud.agent.api.storage.ListTemplateAnswer; | ||||||
| import com.cloud.agent.api.storage.ListTemplateCommand; | import com.cloud.agent.api.storage.ListTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.ListVolumeAnswer; | import com.cloud.agent.api.storage.ListVolumeAnswer; | ||||||
| @ -81,6 +79,9 @@ import com.cloud.utils.db.Transaction; | |||||||
| import com.cloud.utils.exception.CloudRuntimeException; | import com.cloud.utils.exception.CloudRuntimeException; | ||||||
| import com.cloud.vm.DiskProfile; | import com.cloud.vm.DiskProfile; | ||||||
| import com.cloud.vm.VirtualMachine.State; | import com.cloud.vm.VirtualMachine.State; | ||||||
|  | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
|  | |||||||
| @ -34,6 +34,9 @@ import com.cloud.utils.db.DB; | |||||||
| import com.cloud.utils.db.Transaction; | import com.cloud.utils.db.Transaction; | ||||||
| import com.cloud.utils.exception.CloudRuntimeException; | import com.cloud.utils.exception.CloudRuntimeException; | ||||||
| import com.cloud.vm.VirtualMachine.State; | import com.cloud.vm.VirtualMachine.State; | ||||||
|  | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -34,6 +34,7 @@ import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreManager; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | ||||||
|  | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCallbackDispatcher; | import org.apache.cloudstack.framework.async.AsyncCallbackDispatcher; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
| import org.apache.cloudstack.framework.async.AsyncRpcConext; | import org.apache.cloudstack.framework.async.AsyncRpcConext; | ||||||
| @ -45,19 +46,15 @@ import org.apache.cloudstack.storage.image.ImageStoreDriver; | |||||||
| import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | ||||||
| import org.apache.cloudstack.storage.image.store.TemplateObject; | import org.apache.cloudstack.storage.image.store.TemplateObject; | ||||||
| import org.apache.cloudstack.storage.snapshot.SnapshotObject; | import org.apache.cloudstack.storage.snapshot.SnapshotObject; | ||||||
| import org.apache.cloudstack.storage.volume.VolumeObject; |  | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.AgentManager; | import com.cloud.agent.AgentManager; | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| import com.cloud.agent.api.DeleteSnapshotBackupCommand; |  | ||||||
| import com.cloud.agent.api.storage.DeleteTemplateCommand; | import com.cloud.agent.api.storage.DeleteTemplateCommand; | ||||||
| import com.cloud.agent.api.storage.DeleteVolumeCommand; | import com.cloud.agent.api.storage.DeleteVolumeCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.NfsTO; | import com.cloud.agent.api.to.NfsTO; | ||||||
| import com.cloud.agent.api.to.S3TO; |  | ||||||
| import com.cloud.agent.api.to.SwiftTO; |  | ||||||
| import com.cloud.event.EventTypes; | import com.cloud.event.EventTypes; | ||||||
| import com.cloud.event.UsageEventUtils; | import com.cloud.event.UsageEventUtils; | ||||||
| import com.cloud.host.dao.HostDao; | import com.cloud.host.dao.HostDao; | ||||||
| @ -166,13 +163,9 @@ public class CloudStackImageStoreDriverImpl implements ImageStoreDriver { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         if (data.getType() == DataObjectType.TEMPLATE) { |         if (data.getType() == DataObjectType.TEMPLATE) { | ||||||
|             TemplateObject tData = (TemplateObject)data; |             _downloadMonitor.downloadTemplateToStorage(data, caller); | ||||||
|             _downloadMonitor.downloadTemplateToStorage(tData, tData.getDataStore(), caller); |  | ||||||
|         } else if (data.getType() == DataObjectType.VOLUME) { |         } else if (data.getType() == DataObjectType.VOLUME) { | ||||||
|             VolumeObject volInfo = (VolumeObject)data; |             _downloadMonitor.downloadVolumeToStorage(data, caller); | ||||||
|             RegisterVolumePayload payload = (RegisterVolumePayload)volInfo.getpayload(); |  | ||||||
|             _downloadMonitor.downloadVolumeToStorage(volInfo, volInfo.getDataStore(), payload.getUrl(), |  | ||||||
|                     payload.getChecksum(), ImageFormat.valueOf(payload.getFormat().toUpperCase()), caller); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -36,6 +36,7 @@ import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreManager; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | import org.apache.cloudstack.engine.subsystem.api.storage.DataTO; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | ||||||
|  | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCallbackDispatcher; | import org.apache.cloudstack.framework.async.AsyncCallbackDispatcher; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
| import org.apache.cloudstack.framework.async.AsyncRpcConext; | import org.apache.cloudstack.framework.async.AsyncRpcConext; | ||||||
| @ -48,7 +49,6 @@ import org.apache.cloudstack.storage.image.ImageStoreDriver; | |||||||
| import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | ||||||
| import org.apache.cloudstack.storage.image.store.TemplateObject; | import org.apache.cloudstack.storage.image.store.TemplateObject; | ||||||
| import org.apache.cloudstack.storage.snapshot.SnapshotObject; | import org.apache.cloudstack.storage.snapshot.SnapshotObject; | ||||||
| import org.apache.cloudstack.storage.volume.VolumeObject; |  | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.AgentManager; | import com.cloud.agent.AgentManager; | ||||||
| @ -59,10 +59,8 @@ import com.cloud.agent.api.storage.DeleteVolumeCommand; | |||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.S3TO; | import com.cloud.agent.api.to.S3TO; | ||||||
| import com.cloud.agent.api.to.SwiftTO; |  | ||||||
| import com.cloud.event.EventTypes; | import com.cloud.event.EventTypes; | ||||||
| import com.cloud.event.UsageEventUtils; | import com.cloud.event.UsageEventUtils; | ||||||
| import com.cloud.host.HostVO; |  | ||||||
| import com.cloud.host.dao.HostDao; | import com.cloud.host.dao.HostDao; | ||||||
| import com.cloud.storage.RegisterVolumePayload; | import com.cloud.storage.RegisterVolumePayload; | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
| @ -71,13 +69,11 @@ import com.cloud.storage.SnapshotVO; | |||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc; | import com.cloud.storage.VMTemplateStorageResourceAssoc; | ||||||
| import com.cloud.storage.VMTemplateVO; | import com.cloud.storage.VMTemplateVO; | ||||||
| import com.cloud.storage.VMTemplateZoneVO; | import com.cloud.storage.VMTemplateZoneVO; | ||||||
| import com.cloud.storage.VolumeHostVO; |  | ||||||
| import com.cloud.storage.VolumeVO; | import com.cloud.storage.VolumeVO; | ||||||
| import com.cloud.storage.dao.SnapshotDao; | import com.cloud.storage.dao.SnapshotDao; | ||||||
| import com.cloud.storage.dao.VMTemplateDao; | import com.cloud.storage.dao.VMTemplateDao; | ||||||
| import com.cloud.storage.dao.VMTemplateZoneDao; | import com.cloud.storage.dao.VMTemplateZoneDao; | ||||||
| import com.cloud.storage.dao.VolumeDao; | import com.cloud.storage.dao.VolumeDao; | ||||||
| import com.cloud.storage.dao.VolumeHostDao; |  | ||||||
| import com.cloud.storage.download.DownloadMonitor; | import com.cloud.storage.download.DownloadMonitor; | ||||||
| import com.cloud.storage.s3.S3Manager; | import com.cloud.storage.s3.S3Manager; | ||||||
| import com.cloud.storage.secondary.SecondaryStorageVmManager; | import com.cloud.storage.secondary.SecondaryStorageVmManager; | ||||||
| @ -179,13 +175,9 @@ public class S3ImageStoreDriverImpl implements ImageStoreDriver { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         if (data.getType() == DataObjectType.TEMPLATE) { |         if (data.getType() == DataObjectType.TEMPLATE) { | ||||||
|             TemplateObject tData = (TemplateObject)data; |             _downloadMonitor.downloadTemplateToStorage(data, caller); | ||||||
|             _downloadMonitor.downloadTemplateToStorage(tData, tData.getDataStore(), caller); |  | ||||||
|         } else if (data.getType() == DataObjectType.VOLUME) { |         } else if (data.getType() == DataObjectType.VOLUME) { | ||||||
|             VolumeObject volInfo = (VolumeObject)data; |             _downloadMonitor.downloadVolumeToStorage(data, caller); | ||||||
|             RegisterVolumePayload payload = (RegisterVolumePayload)volInfo.getpayload(); |  | ||||||
|             _downloadMonitor.downloadVolumeToStorage(volInfo, volInfo.getDataStore(), payload.getUrl(), |  | ||||||
|                     payload.getChecksum(), ImageFormat.valueOf(payload.getFormat().toUpperCase()), caller); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -48,7 +48,6 @@ import org.apache.cloudstack.storage.image.ImageStoreDriver; | |||||||
| import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | import org.apache.cloudstack.storage.image.store.ImageStoreImpl; | ||||||
| import org.apache.cloudstack.storage.image.store.TemplateObject; | import org.apache.cloudstack.storage.image.store.TemplateObject; | ||||||
| import org.apache.cloudstack.storage.snapshot.SnapshotObject; | import org.apache.cloudstack.storage.snapshot.SnapshotObject; | ||||||
| import org.apache.cloudstack.storage.volume.VolumeObject; |  | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.AgentManager; | import com.cloud.agent.AgentManager; | ||||||
| @ -58,26 +57,21 @@ import com.cloud.agent.api.storage.DeleteTemplateCommand; | |||||||
| import com.cloud.agent.api.storage.DeleteVolumeCommand; | import com.cloud.agent.api.storage.DeleteVolumeCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.to.DataStoreTO; | import com.cloud.agent.api.to.DataStoreTO; | ||||||
| import com.cloud.agent.api.to.S3TO; |  | ||||||
| import com.cloud.agent.api.to.SwiftTO; | import com.cloud.agent.api.to.SwiftTO; | ||||||
| import com.cloud.event.EventTypes; | import com.cloud.event.EventTypes; | ||||||
| import com.cloud.event.UsageEventUtils; | import com.cloud.event.UsageEventUtils; | ||||||
| import com.cloud.host.HostVO; |  | ||||||
| import com.cloud.host.dao.HostDao; | import com.cloud.host.dao.HostDao; | ||||||
| import com.cloud.storage.RegisterVolumePayload; |  | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
| import com.cloud.storage.DataStoreRole; | import com.cloud.storage.DataStoreRole; | ||||||
| import com.cloud.storage.SnapshotVO; | import com.cloud.storage.SnapshotVO; | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc; | import com.cloud.storage.VMTemplateStorageResourceAssoc; | ||||||
| import com.cloud.storage.VMTemplateVO; | import com.cloud.storage.VMTemplateVO; | ||||||
| import com.cloud.storage.VMTemplateZoneVO; | import com.cloud.storage.VMTemplateZoneVO; | ||||||
| import com.cloud.storage.VolumeHostVO; |  | ||||||
| import com.cloud.storage.VolumeVO; | import com.cloud.storage.VolumeVO; | ||||||
| import com.cloud.storage.dao.SnapshotDao; | import com.cloud.storage.dao.SnapshotDao; | ||||||
| import com.cloud.storage.dao.VMTemplateDao; | import com.cloud.storage.dao.VMTemplateDao; | ||||||
| import com.cloud.storage.dao.VMTemplateZoneDao; | import com.cloud.storage.dao.VMTemplateZoneDao; | ||||||
| import com.cloud.storage.dao.VolumeDao; | import com.cloud.storage.dao.VolumeDao; | ||||||
| import com.cloud.storage.dao.VolumeHostDao; |  | ||||||
| import com.cloud.storage.download.DownloadMonitor; | import com.cloud.storage.download.DownloadMonitor; | ||||||
| import com.cloud.storage.s3.S3Manager; | import com.cloud.storage.s3.S3Manager; | ||||||
| import com.cloud.storage.secondary.SecondaryStorageVmManager; | import com.cloud.storage.secondary.SecondaryStorageVmManager; | ||||||
| @ -172,13 +166,9 @@ public class SwiftImageStoreDriverImpl implements ImageStoreDriver { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         if (data.getType() == DataObjectType.TEMPLATE) { |         if (data.getType() == DataObjectType.TEMPLATE) { | ||||||
|             TemplateObject tData = (TemplateObject)data; |             _downloadMonitor.downloadTemplateToStorage(data, caller); | ||||||
|             _downloadMonitor.downloadTemplateToStorage(tData, tData.getDataStore(), caller); |  | ||||||
|         } else if (data.getType() == DataObjectType.VOLUME) { |         } else if (data.getType() == DataObjectType.VOLUME) { | ||||||
|             VolumeObject volInfo = (VolumeObject)data; |             _downloadMonitor.downloadVolumeToStorage(data, caller); | ||||||
|             RegisterVolumePayload payload = (RegisterVolumePayload)volInfo.getpayload(); |  | ||||||
|             _downloadMonitor.downloadVolumeToStorage(volInfo, volInfo.getDataStore(), payload.getUrl(), |  | ||||||
|                     payload.getChecksum(), ImageFormat.valueOf(payload.getFormat().toUpperCase()), caller); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,8 +16,9 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
|  | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| 
 | 
 | ||||||
| public class DownloadAbandonedState extends DownloadInactiveState { | public class DownloadAbandonedState extends DownloadInactiveState { | ||||||
|  | |||||||
| @ -16,10 +16,10 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
| import org.apache.log4j.Level; | import org.apache.log4j.Level; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| 
 | 
 | ||||||
| public abstract class DownloadActiveState extends DownloadState { | public abstract class DownloadActiveState extends DownloadState { | ||||||
|  | |||||||
| @ -16,7 +16,8 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
|  | 
 | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| 
 | 
 | ||||||
| public class DownloadCompleteState extends DownloadInactiveState { | public class DownloadCompleteState extends DownloadInactiveState { | ||||||
|  | |||||||
| @ -16,10 +16,10 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
| import org.apache.log4j.Level; | import org.apache.log4j.Level; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| 
 | 
 | ||||||
| public class DownloadErrorState extends DownloadInactiveState { | public class DownloadErrorState extends DownloadInactiveState { | ||||||
|  | |||||||
| @ -34,6 +34,10 @@ import org.apache.cloudstack.engine.subsystem.api.storage.TemplateService; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.VolumeService; | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeService; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.ZoneScope; | import org.apache.cloudstack.engine.subsystem.api.storage.ZoneScope; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
| import org.apache.log4j.Level; | import org.apache.log4j.Level; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| @ -46,10 +50,6 @@ import com.cloud.agent.api.StartupCommand; | |||||||
| import com.cloud.agent.api.StartupRoutingCommand; | import com.cloud.agent.api.StartupRoutingCommand; | ||||||
| import com.cloud.agent.api.StartupSecondaryStorageCommand; | import com.cloud.agent.api.StartupSecondaryStorageCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.exception.AgentUnavailableException; | import com.cloud.exception.AgentUnavailableException; | ||||||
| import com.cloud.exception.ConnectionException; | import com.cloud.exception.ConnectionException; | ||||||
| import com.cloud.host.Host; | import com.cloud.host.Host; | ||||||
|  | |||||||
| @ -17,11 +17,9 @@ | |||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataObject; | import org.apache.cloudstack.engine.subsystem.api.storage.DataObject; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.DataStore; |  | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.storage.Storage.ImageFormat; |  | ||||||
| import com.cloud.utils.component.Manager; | import com.cloud.utils.component.Manager; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
| @ -31,8 +29,8 @@ import com.cloud.utils.component.Manager; | |||||||
| public interface DownloadMonitor extends Manager{ | public interface DownloadMonitor extends Manager{ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     public void downloadTemplateToStorage(DataObject template, DataStore store, AsyncCompletionCallback<DownloadAnswer> callback); |     public void downloadTemplateToStorage(DataObject template, AsyncCompletionCallback<DownloadAnswer> callback); | ||||||
| 
 | 
 | ||||||
| 	public void downloadVolumeToStorage(DataObject volume, DataStore store, String url, String checkSum, ImageFormat format, AsyncCompletionCallback<DownloadAnswer> callback); | 	public void downloadVolumeToStorage(DataObject volume, AsyncCompletionCallback<DownloadAnswer> callback); | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -33,7 +33,12 @@ import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreManager; | |||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPoint; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | import org.apache.cloudstack.engine.subsystem.api.storage.EndPointSelector; | ||||||
| import org.apache.cloudstack.engine.subsystem.api.storage.TemplateDataFactory; | import org.apache.cloudstack.engine.subsystem.api.storage.TemplateDataFactory; | ||||||
|  | import org.apache.cloudstack.engine.subsystem.api.storage.VolumeInfo; | ||||||
| import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | import org.apache.cloudstack.framework.async.AsyncCompletionCallback; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand.ResourceType; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
| import org.apache.cloudstack.storage.datastore.db.ImageStoreDao; | import org.apache.cloudstack.storage.datastore.db.ImageStoreDao; | ||||||
| import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreDao; | import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreDao; | ||||||
| import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreVO; | import org.apache.cloudstack.storage.datastore.db.TemplateDataStoreVO; | ||||||
| @ -43,22 +48,12 @@ import org.apache.log4j.Logger; | |||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.AgentManager; | import com.cloud.agent.AgentManager; | ||||||
| import com.cloud.agent.Listener; |  | ||||||
| import com.cloud.agent.api.Command; |  | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; | import com.cloud.agent.api.storage.Proxy; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.Proxy; |  | ||||||
| import com.cloud.agent.api.storage.DownloadCommand.ResourceType; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; |  | ||||||
| import com.cloud.agent.manager.Commands; |  | ||||||
| import com.cloud.alert.AlertManager; |  | ||||||
| import com.cloud.configuration.Config; | import com.cloud.configuration.Config; | ||||||
| import com.cloud.configuration.dao.ConfigurationDao; | import com.cloud.configuration.dao.ConfigurationDao; | ||||||
| import com.cloud.exception.AgentUnavailableException; | import com.cloud.storage.RegisterVolumePayload; | ||||||
| import com.cloud.host.HostVO; |  | ||||||
| import com.cloud.storage.Storage.ImageFormat; | import com.cloud.storage.Storage.ImageFormat; | ||||||
| import com.cloud.storage.StorageManager; |  | ||||||
| import com.cloud.storage.VMTemplateHostVO; | import com.cloud.storage.VMTemplateHostVO; | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc; | import com.cloud.storage.VMTemplateStorageResourceAssoc; | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| @ -68,20 +63,15 @@ import com.cloud.storage.VolumeHostVO; | |||||||
| import com.cloud.storage.dao.VMTemplateDao; | import com.cloud.storage.dao.VMTemplateDao; | ||||||
| import com.cloud.storage.dao.VolumeDao; | import com.cloud.storage.dao.VolumeDao; | ||||||
| import com.cloud.storage.secondary.SecondaryStorageVmManager; | import com.cloud.storage.secondary.SecondaryStorageVmManager; | ||||||
| import com.cloud.storage.swift.SwiftManager; |  | ||||||
| import com.cloud.storage.template.TemplateConstants; | import com.cloud.storage.template.TemplateConstants; | ||||||
| import com.cloud.template.TemplateManager; |  | ||||||
| import com.cloud.template.VirtualMachineTemplate; | import com.cloud.template.VirtualMachineTemplate; | ||||||
| import com.cloud.user.AccountManager; |  | ||||||
| import com.cloud.user.ResourceLimitService; |  | ||||||
| import com.cloud.utils.component.ComponentContext; | import com.cloud.utils.component.ComponentContext; | ||||||
| import com.cloud.utils.component.ManagerBase; | import com.cloud.utils.component.ManagerBase; | ||||||
| import com.cloud.utils.db.DB; |  | ||||||
| import com.cloud.utils.db.JoinBuilder; | import com.cloud.utils.db.JoinBuilder; | ||||||
| import com.cloud.utils.db.SearchBuilder; | import com.cloud.utils.db.SearchBuilder; | ||||||
| import com.cloud.utils.db.SearchCriteria; | import com.cloud.utils.db.SearchCriteria; | ||||||
| import com.cloud.vm.UserVmManager; | import org.apache.cloudstack.storage.to.VolumeObjectTO; | ||||||
| import com.cloud.vm.dao.UserVmDao; | import org.apache.cloudstack.storage.to.TemplateObjectTO; | ||||||
| 
 | 
 | ||||||
| @Component | @Component | ||||||
| @Local(value = { DownloadMonitor.class }) | @Local(value = { DownloadMonitor.class }) | ||||||
| @ -175,14 +165,13 @@ public class DownloadMonitorImpl extends ManagerBase implements DownloadMonitor | |||||||
|         return (downloadsInProgress.size() == 0); |         return (downloadsInProgress.size() == 0); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void initiateTemplateDownload(DataObject template, DataStore store, AsyncCompletionCallback<DownloadAnswer> callback) { |     private void initiateTemplateDownload(DataObject template, AsyncCompletionCallback<DownloadAnswer> callback) { | ||||||
|         boolean downloadJobExists = false; |         boolean downloadJobExists = false; | ||||||
|         TemplateDataStoreVO vmTemplateStore = null; |         TemplateDataStoreVO vmTemplateStore = null; | ||||||
|  |         DataStore store = template.getDataStore(); | ||||||
| 
 | 
 | ||||||
|         vmTemplateStore = _vmTemplateStoreDao.findByStoreTemplate(store.getId(), template.getId()); |         vmTemplateStore = _vmTemplateStoreDao.findByStoreTemplate(store.getId(), template.getId()); | ||||||
|         if (vmTemplateStore == null) { |         if (vmTemplateStore == null) { | ||||||
|             // This method can be invoked other places, for example, |  | ||||||
|             // handleTemplateSync, in that case, vmTemplateStore may be null |  | ||||||
|             vmTemplateStore = new TemplateDataStoreVO(store.getId(), template.getId(), new Date(), 0, |             vmTemplateStore = new TemplateDataStoreVO(store.getId(), template.getId(), new Date(), 0, | ||||||
|                     VMTemplateStorageResourceAssoc.Status.NOT_DOWNLOADED, null, null, "jobid0000", null, template.getUri()); |                     VMTemplateStorageResourceAssoc.Status.NOT_DOWNLOADED, null, null, "jobid0000", null, template.getUri()); | ||||||
|             _vmTemplateStoreDao.persist(vmTemplateStore); |             _vmTemplateStoreDao.persist(vmTemplateStore); | ||||||
| @ -194,7 +183,7 @@ public class DownloadMonitorImpl extends ManagerBase implements DownloadMonitor | |||||||
|         if (vmTemplateStore != null) { |         if (vmTemplateStore != null) { | ||||||
|             start(); |             start(); | ||||||
|             VirtualMachineTemplate tmpl = this._templateDao.findById(template.getId()); |             VirtualMachineTemplate tmpl = this._templateDao.findById(template.getId()); | ||||||
|             DownloadCommand dcmd = new DownloadCommand(store.getTO(), tmpl, maxTemplateSizeInBytes); |             DownloadCommand dcmd = new DownloadCommand((TemplateObjectTO)(template.getTO()), maxTemplateSizeInBytes); | ||||||
|             dcmd.setProxy(getHttpProxy()); |             dcmd.setProxy(getHttpProxy()); | ||||||
|             if (downloadJobExists) { |             if (downloadJobExists) { | ||||||
|                 dcmd = new DownloadProgressCommand(dcmd, vmTemplateStore.getJobId(), RequestType.GET_OR_RESTART); |                 dcmd = new DownloadProgressCommand(dcmd, vmTemplateStore.getJobId(), RequestType.GET_OR_RESTART); | ||||||
| @ -238,20 +227,26 @@ public class DownloadMonitorImpl extends ManagerBase implements DownloadMonitor | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void downloadTemplateToStorage(DataObject template, DataStore store, AsyncCompletionCallback<DownloadAnswer> callback) { |     public void downloadTemplateToStorage(DataObject template, AsyncCompletionCallback<DownloadAnswer> callback) { | ||||||
|         long templateId = template.getId(); |         long templateId = template.getId(); | ||||||
|  |         DataStore store = template.getDataStore(); | ||||||
|         if (isTemplateUpdateable(templateId, store.getId())) { |         if (isTemplateUpdateable(templateId, store.getId())) { | ||||||
|             if (template != null && template.getUri() != null) { |             if (template != null && template.getUri() != null) { | ||||||
|                 initiateTemplateDownload(template, store, callback); |                 initiateTemplateDownload(template, callback); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void downloadVolumeToStorage(DataObject volume, DataStore store, String url, String checkSum, ImageFormat format, |     public void downloadVolumeToStorage(DataObject volume, AsyncCompletionCallback<DownloadAnswer> callback) { | ||||||
|             AsyncCompletionCallback<DownloadAnswer> callback) { |  | ||||||
|         boolean downloadJobExists = false; |         boolean downloadJobExists = false; | ||||||
|         VolumeDataStoreVO volumeHost = null; |         VolumeDataStoreVO volumeHost = null; | ||||||
|  |         DataStore store = volume.getDataStore(); | ||||||
|  |         VolumeInfo volInfo = (VolumeInfo)volume; | ||||||
|  |         RegisterVolumePayload payload = (RegisterVolumePayload)volInfo.getpayload(); | ||||||
|  |         String url = payload.getUrl(); | ||||||
|  |         String checkSum = payload.getChecksum(); | ||||||
|  |         ImageFormat format = ImageFormat.valueOf(payload.getFormat()); | ||||||
| 
 | 
 | ||||||
|         volumeHost = _volumeStoreDao.findByStoreVolume(store.getId(), volume.getId()); |         volumeHost = _volumeStoreDao.findByStoreVolume(store.getId(), volume.getId()); | ||||||
|         if (volumeHost == null) { |         if (volumeHost == null) { | ||||||
| @ -266,7 +261,7 @@ public class DownloadMonitorImpl extends ManagerBase implements DownloadMonitor | |||||||
|         if (volumeHost != null) { |         if (volumeHost != null) { | ||||||
|             start(); |             start(); | ||||||
|             Volume vol = this._volumeDao.findById(volume.getId()); |             Volume vol = this._volumeDao.findById(volume.getId()); | ||||||
|             DownloadCommand dcmd = new DownloadCommand(store.getTO(), vol, maxVolumeSizeInBytes, checkSum, url, format); |             DownloadCommand dcmd = new DownloadCommand((VolumeObjectTO)(volume.getTO()), maxVolumeSizeInBytes, checkSum, url, format); | ||||||
|             dcmd.setProxy(getHttpProxy()); |             dcmd.setProxy(getHttpProxy()); | ||||||
|             if (downloadJobExists) { |             if (downloadJobExists) { | ||||||
|                 dcmd = new DownloadProgressCommand(dcmd, volumeHost.getJobId(), RequestType.GET_OR_RESTART); |                 dcmd = new DownloadProgressCommand(dcmd, volumeHost.getJobId(), RequestType.GET_OR_RESTART); | ||||||
|  | |||||||
| @ -16,7 +16,8 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.storage.download; | package com.cloud.storage.download; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand.RequestType; | import org.apache.cloudstack.storage.command.DownloadProgressCommand.RequestType; | ||||||
|  | 
 | ||||||
| import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | import com.cloud.storage.VMTemplateStorageResourceAssoc.Status; | ||||||
| 
 | 
 | ||||||
| public class NotDownloadedState extends DownloadActiveState { | public class NotDownloadedState extends DownloadActiveState { | ||||||
|  | |||||||
| @ -24,6 +24,8 @@ import java.util.Map; | |||||||
| import javax.inject.Inject; | import javax.inject.Inject; | ||||||
| import javax.naming.ConfigurationException; | import javax.naming.ConfigurationException; | ||||||
| 
 | 
 | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadCommand; | ||||||
|  | import org.apache.cloudstack.storage.command.DownloadProgressCommand; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.Answer; | import com.cloud.agent.api.Answer; | ||||||
| @ -39,8 +41,6 @@ import com.cloud.agent.api.ReadyCommand; | |||||||
| import com.cloud.agent.api.StartupCommand; | import com.cloud.agent.api.StartupCommand; | ||||||
| import com.cloud.agent.api.StartupStorageCommand; | import com.cloud.agent.api.StartupStorageCommand; | ||||||
| import com.cloud.agent.api.storage.DownloadAnswer; | import com.cloud.agent.api.storage.DownloadAnswer; | ||||||
| import com.cloud.agent.api.storage.DownloadCommand; |  | ||||||
| import com.cloud.agent.api.storage.DownloadProgressCommand; |  | ||||||
| import com.cloud.host.Host; | import com.cloud.host.Host; | ||||||
| import com.cloud.host.Host.Type; | import com.cloud.host.Host.Type; | ||||||
| import com.cloud.resource.ServerResource; | import com.cloud.resource.ServerResource; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user