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; | 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.ByteArrayInputStream; | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.io.FileInputStream; | import java.io.FileInputStream; | ||||||
| @ -60,6 +37,32 @@ import java.util.ArrayList; | |||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | 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 { | public class HttpsDirectTemplateDownloader extends DirectTemplateDownloaderImpl { | ||||||
| 
 | 
 | ||||||
|     protected CloseableHttpClient httpsClient; |     protected CloseableHttpClient httpsClient; | ||||||
| @ -183,8 +186,7 @@ public class HttpsDirectTemplateDownloader extends DirectTemplateDownloaderImpl | |||||||
|                 SSLContext context = getSSLContext(); |                 SSLContext context = getSSLContext(); | ||||||
|                 urlConnection.setSSLSocketFactory(context.getSocketFactory()); |                 urlConnection.setSSLSocketFactory(context.getSocketFactory()); | ||||||
|                 urlConnection.connect(); |                 urlConnection.connect(); | ||||||
|                 boolean isCompressed = !url.endsWith("qcow2"); |                 return QCOW2Utils.getVirtualSize(urlObj.openStream(), UriUtils.isUrlForCompressedFile(url)); | ||||||
|                 return QCOW2Utils.getVirtualSize(urlObj.openStream(), isCompressed); |  | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 throw new CloudRuntimeException(String.format("Cannot obtain qcow2 virtual size due to: %s", e.getMessage()), 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; |         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) { |     public static final Set<String> buildExtensionSet(boolean metalink, String... baseExtensions) { | ||||||
|         final ImmutableSet.Builder<String> builder = ImmutableSet.builder(); |         final ImmutableSet.Builder<String> builder = ImmutableSet.builder(); | ||||||
| 
 | 
 | ||||||
|         for (String baseExtension : baseExtensions) { |         for (String baseExtension : baseExtensions) { | ||||||
|             builder.add("." + baseExtension); |             builder.add("." + baseExtension); | ||||||
|             for (String format : COMMPRESSION_FORMATS) { |             for (String format : COMPRESSION_FORMATS) { | ||||||
|                 builder.add("." + baseExtension + "." + format); |                 builder.add("." + baseExtension + "." + format); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -647,4 +647,8 @@ public class UriUtils { | |||||||
|             throw new CloudRuntimeException(url + " is not a valid uri for RBD"); |             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 org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.cloud.utils.NumbersUtil; | import com.cloud.utils.NumbersUtil; | ||||||
|  | import com.cloud.utils.UriUtils; | ||||||
| 
 | 
 | ||||||
| public final class QCOW2Utils { | public final class QCOW2Utils { | ||||||
|     public static final Logger LOGGER = Logger.getLogger(QCOW2Utils.class.getName()); |     public static final Logger LOGGER = Logger.getLogger(QCOW2Utils.class.getName()); | ||||||
| @ -114,7 +115,7 @@ public final class QCOW2Utils { | |||||||
|     public static long getVirtualSize(String urlStr) { |     public static long getVirtualSize(String urlStr) { | ||||||
|         try { |         try { | ||||||
|             URL url = new URL(urlStr); |             URL url = new URL(urlStr); | ||||||
|             return getVirtualSizeFromInputStream(url.openStream()); |             return getVirtualSize(url.openStream(), UriUtils.isUrlForCompressedFile(urlStr)); | ||||||
|         } catch (MalformedURLException e) { |         } catch (MalformedURLException e) { | ||||||
|             LOGGER.warn("Failed to validate for qcow2, malformed URL: " + urlStr + ", error: " + e.getMessage()); |             LOGGER.warn("Failed to validate for qcow2, malformed URL: " + urlStr + ", error: " + e.getMessage()); | ||||||
|             throw new IllegalArgumentException("Invalid URL: " + urlStr); |             throw new IllegalArgumentException("Invalid URL: " + urlStr); | ||||||
|  | |||||||
| @ -101,7 +101,7 @@ public class ImageStoreUtil { | |||||||
| 
 | 
 | ||||||
|     public static boolean isCompressedExtension(String path) { |     public static boolean isCompressedExtension(String path) { | ||||||
|         final String lowerCasePath = path.toLowerCase(); |         final String lowerCasePath = path.toLowerCase(); | ||||||
|         return UriUtils.COMMPRESSION_FORMATS |         return UriUtils.COMPRESSION_FORMATS | ||||||
|                        .stream() |                        .stream() | ||||||
|                        .map(extension -> "." + extension) |                        .map(extension -> "." + extension) | ||||||
|                        .anyMatch(lowerCasePath::endsWith); |                        .anyMatch(lowerCasePath::endsWith); | ||||||
|  | |||||||
| @ -19,13 +19,13 @@ | |||||||
| 
 | 
 | ||||||
| package com.cloud.utils; | package com.cloud.utils; | ||||||
| 
 | 
 | ||||||
| import org.junit.Assert; |  | ||||||
| import org.junit.Test; |  | ||||||
| 
 |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
|  | import org.junit.Assert; | ||||||
|  | import org.junit.Test; | ||||||
|  | 
 | ||||||
| public class UriUtilsTest { | public class UriUtilsTest { | ||||||
|     @Test |     @Test | ||||||
|     public void encodeURIComponent() { |     public void encodeURIComponent() { | ||||||
| @ -265,4 +265,12 @@ public class UriUtilsTest { | |||||||
|         testGetUriInfoInternal(url11, host); |         testGetUriInfoInternal(url11, host); | ||||||
|         testGetUriInfoInternal(url12, 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