Skip to content

Commit

Permalink
Add detection and decompression of gzip info
Browse files Browse the repository at this point in the history
This change uses the presence of a Descriptor UUID, collected at
service-discovery time, to determine if the contents of streamed data
are gzipped. If they are, then it will decompress the file and
present it to the user.
  • Loading branch information
iankchristie committed Jan 13, 2017
1 parent fa38299 commit 6bf6a1c
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -228,7 +228,16 @@ private File getHtmlFile() {
return new File(websiteDir, "website.html");
}

private File getTempFile() {
File websiteDir = new File(activity.getFilesDir(), "Websites");
websiteDir.mkdir();
return new File(websiteDir, "temp.html");
}

private void openInChrome(File file) {
if(Utils.isGzippedFile(file)) {
file = Utils.gunzip(file, getTempFile());
}
Intent intent = new Intent(Intent.ACTION_VIEW);
Uri contentUri = new FileProvider()
.getUriForFile(activity, "org.physical_web.fileprovider", file);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@
import org.json.JSONException;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
Expand All @@ -56,6 +60,7 @@
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.zip.GZIPInputStream;



Expand Down Expand Up @@ -95,6 +100,7 @@ class Utils {
private static final String SEPARATOR = "\0";
private static Set<String> mFavoriteUrls = new HashSet<>();
private static Set<String> mBlockedUrls = new HashSet<>();
private static final int GZIP_SIGNATURE_LENGTH = 2;

// Compares PwPairs by first considering if it has been favorited
// and then considering distance
Expand Down Expand Up @@ -1119,4 +1125,62 @@ public PwsResultBuilder setPwsTripTimeMillis(PwsResult pwsResult, long timeMilli
return this;
}
}

/**
* Determines if a file is gzipped by examining the signature of
* the file, which is the first two bytes.
* @param file to be determined if is gzipped.
* @return true If the contents of the file are gzipped otherwise false.
*/
public static boolean isGzippedFile(File file) {
InputStream input;

try {
input = new FileInputStream(file);
} catch(FileNotFoundException e) {
return false;
}

byte[] signature = new byte[GZIP_SIGNATURE_LENGTH];

try {
input.read(signature);
} catch(IOException e) {
return false;
}

return ((signature[0] == (byte) (GZIPInputStream.GZIP_MAGIC))
&& (signature[1] == (byte) (GZIPInputStream.GZIP_MAGIC >> 8)));
}


/**
* Out-of-place Gunzips from src to dest.
* @param src file containing gzipped information.
* @param dest file to place decompressed information.
* @return File that has decompressed information.
*/
public static File gunzip(File src, File dest) {

byte[] buffer = new byte[1024];

try{

GZIPInputStream gzis = new GZIPInputStream(new FileInputStream(src));

FileOutputStream out = new FileOutputStream(dest);

int len;
while ((len = gzis.read(buffer)) > 0) {
out.write(buffer, 0, len);
}

gzis.close();
out.close();

} catch(IOException ex){
ex.printStackTrace();
}
return dest;
}
}

0 comments on commit 6bf6a1c

Please sign in to comment.