mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	kvm: fix direct download template size (#8093)
Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com>
This commit is contained in:
		
							parent
							
								
									0b3438bfbe
								
							
						
					
					
						commit
						ba24a18f27
					
				| @ -19,29 +19,6 @@ | ||||
| 
 | ||||
| package org.apache.cloudstack.direct.download; | ||||
| 
 | ||||
| import com.cloud.utils.Pair; | ||||
| import com.cloud.utils.exception.CloudRuntimeException; | ||||
| import com.cloud.utils.script.Script; | ||||
| import com.cloud.utils.storage.QCOW2Utils; | ||||
| import org.apache.cloudstack.utils.security.SSLUtils; | ||||
| import org.apache.commons.httpclient.HttpStatus; | ||||
| import org.apache.commons.io.IOUtils; | ||||
| import org.apache.http.Header; | ||||
| import org.apache.http.HttpEntity; | ||||
| import org.apache.http.client.methods.CloseableHttpResponse; | ||||
| import org.apache.commons.collections.MapUtils; | ||||
| import org.apache.http.client.config.RequestConfig; | ||||
| import org.apache.http.client.methods.HttpGet; | ||||
| import org.apache.http.client.methods.HttpHead; | ||||
| import org.apache.http.client.methods.HttpUriRequest; | ||||
| import org.apache.http.conn.ssl.SSLConnectionSocketFactory; | ||||
| import org.apache.http.impl.client.CloseableHttpClient; | ||||
| import org.apache.http.impl.client.HttpClients; | ||||
| import org.apache.http.util.EntityUtils; | ||||
| 
 | ||||
| import javax.net.ssl.HttpsURLConnection; | ||||
| import javax.net.ssl.SSLContext; | ||||
| import javax.net.ssl.TrustManager; | ||||
| import java.io.ByteArrayInputStream; | ||||
| import java.io.File; | ||||
| import java.io.FileInputStream; | ||||
| @ -60,6 +37,32 @@ import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| 
 | ||||
| import javax.net.ssl.HttpsURLConnection; | ||||
| import javax.net.ssl.SSLContext; | ||||
| import javax.net.ssl.TrustManager; | ||||
| 
 | ||||
| import org.apache.cloudstack.utils.security.SSLUtils; | ||||
| import org.apache.commons.collections.MapUtils; | ||||
| import org.apache.commons.httpclient.HttpStatus; | ||||
| import org.apache.commons.io.IOUtils; | ||||
| import org.apache.http.Header; | ||||
| import org.apache.http.HttpEntity; | ||||
| import org.apache.http.client.config.RequestConfig; | ||||
| import org.apache.http.client.methods.CloseableHttpResponse; | ||||
| import org.apache.http.client.methods.HttpGet; | ||||
| import org.apache.http.client.methods.HttpHead; | ||||
| import org.apache.http.client.methods.HttpUriRequest; | ||||
| import org.apache.http.conn.ssl.SSLConnectionSocketFactory; | ||||
| import org.apache.http.impl.client.CloseableHttpClient; | ||||
| import org.apache.http.impl.client.HttpClients; | ||||
| import org.apache.http.util.EntityUtils; | ||||
| 
 | ||||
| import com.cloud.utils.Pair; | ||||
| import com.cloud.utils.UriUtils; | ||||
| import com.cloud.utils.exception.CloudRuntimeException; | ||||
| import com.cloud.utils.script.Script; | ||||
| import com.cloud.utils.storage.QCOW2Utils; | ||||
| 
 | ||||
| public class HttpsDirectTemplateDownloader extends DirectTemplateDownloaderImpl { | ||||
| 
 | ||||
|     protected CloseableHttpClient httpsClient; | ||||
| @ -183,8 +186,7 @@ public class HttpsDirectTemplateDownloader extends DirectTemplateDownloaderImpl | ||||
|                 SSLContext context = getSSLContext(); | ||||
|                 urlConnection.setSSLSocketFactory(context.getSocketFactory()); | ||||
|                 urlConnection.connect(); | ||||
|                 boolean isCompressed = !url.endsWith("qcow2"); | ||||
|                 return QCOW2Utils.getVirtualSize(urlObj.openStream(), isCompressed); | ||||
|                 return QCOW2Utils.getVirtualSize(urlObj.openStream(), UriUtils.isUrlForCompressedFile(url)); | ||||
|             } catch (IOException e) { | ||||
|                 throw new CloudRuntimeException(String.format("Cannot obtain qcow2 virtual size due to: %s", e.getMessage()), e); | ||||
|             } | ||||
|  | ||||
| @ -408,14 +408,14 @@ public class UriUtils { | ||||
|         return urls; | ||||
|     } | ||||
| 
 | ||||
|     public static final Set<String> COMMPRESSION_FORMATS = ImmutableSet.of("zip", "bz2", "gz"); | ||||
|     public static final Set<String> COMPRESSION_FORMATS = ImmutableSet.of("zip", "bz2", "gz"); | ||||
| 
 | ||||
|     public static final Set<String> buildExtensionSet(boolean metalink, String... baseExtensions) { | ||||
|         final ImmutableSet.Builder<String> builder = ImmutableSet.builder(); | ||||
| 
 | ||||
|         for (String baseExtension : baseExtensions) { | ||||
|             builder.add("." + baseExtension); | ||||
|             for (String format : COMMPRESSION_FORMATS) { | ||||
|             for (String format : COMPRESSION_FORMATS) { | ||||
|                 builder.add("." + baseExtension + "." + format); | ||||
|             } | ||||
|         } | ||||
| @ -647,4 +647,8 @@ public class UriUtils { | ||||
|             throw new CloudRuntimeException(url + " is not a valid uri for RBD"); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     public static boolean isUrlForCompressedFile(String url) { | ||||
|         return UriUtils.COMPRESSION_FORMATS.stream().anyMatch(f -> url.toLowerCase().endsWith(f)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -32,6 +32,7 @@ import org.apache.commons.compress.compressors.CompressorStreamFactory; | ||||
| import org.apache.log4j.Logger; | ||||
| 
 | ||||
| import com.cloud.utils.NumbersUtil; | ||||
| import com.cloud.utils.UriUtils; | ||||
| 
 | ||||
| public final class QCOW2Utils { | ||||
|     public static final Logger LOGGER = Logger.getLogger(QCOW2Utils.class.getName()); | ||||
| @ -114,7 +115,7 @@ public final class QCOW2Utils { | ||||
|     public static long getVirtualSize(String urlStr) { | ||||
|         try { | ||||
|             URL url = new URL(urlStr); | ||||
|             return getVirtualSizeFromInputStream(url.openStream()); | ||||
|             return getVirtualSize(url.openStream(), UriUtils.isUrlForCompressedFile(urlStr)); | ||||
|         } catch (MalformedURLException e) { | ||||
|             LOGGER.warn("Failed to validate for qcow2, malformed URL: " + urlStr + ", error: " + e.getMessage()); | ||||
|             throw new IllegalArgumentException("Invalid URL: " + urlStr); | ||||
|  | ||||
| @ -101,7 +101,7 @@ public class ImageStoreUtil { | ||||
| 
 | ||||
|     public static boolean isCompressedExtension(String path) { | ||||
|         final String lowerCasePath = path.toLowerCase(); | ||||
|         return UriUtils.COMMPRESSION_FORMATS | ||||
|         return UriUtils.COMPRESSION_FORMATS | ||||
|                        .stream() | ||||
|                        .map(extension -> "." + extension) | ||||
|                        .anyMatch(lowerCasePath::endsWith); | ||||
|  | ||||
| @ -19,13 +19,13 @@ | ||||
| 
 | ||||
| package com.cloud.utils; | ||||
| 
 | ||||
| import org.junit.Assert; | ||||
| import org.junit.Test; | ||||
| 
 | ||||
| import java.util.Arrays; | ||||
| import java.util.Collections; | ||||
| import java.util.List; | ||||
| 
 | ||||
| import org.junit.Assert; | ||||
| import org.junit.Test; | ||||
| 
 | ||||
| public class UriUtilsTest { | ||||
|     @Test | ||||
|     public void encodeURIComponent() { | ||||
| @ -265,4 +265,12 @@ public class UriUtilsTest { | ||||
|         testGetUriInfoInternal(url11, host); | ||||
|         testGetUriInfoInternal(url12, host); | ||||
|     } | ||||
| 
 | ||||
|     @Test | ||||
|     public void testIsUrlForCompressedFile() { | ||||
|         Assert.assertTrue(UriUtils.isUrlForCompressedFile("https://abc.com/xyz.bz2")); | ||||
|         Assert.assertTrue(UriUtils.isUrlForCompressedFile("http://abc.com/xyz.zip")); | ||||
|         Assert.assertTrue(UriUtils.isUrlForCompressedFile("https://abc.com/xyz.gz")); | ||||
|         Assert.assertFalse(UriUtils.isUrlForCompressedFile("http://abc.com/xyz.qcow2")); | ||||
|     } | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user