mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-10 17:11:56 +01:00
fix installing pbz/pbw files from content provides (eg. download manager)
This still does not fix pbw isntallation problems with FW 3.x since the content does not get copied to the pbw cache yet when content providers are involved
This commit is contained in:
parent
05a8436f7c
commit
9ebb320e10
@ -18,12 +18,10 @@ import java.io.InputStream;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.nio.ByteOrder;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Enumeration;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.zip.ZipEntry;
|
||||
import java.util.zip.ZipFile;
|
||||
import java.util.zip.ZipInputStream;
|
||||
|
||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDeviceApp;
|
||||
@ -32,6 +30,7 @@ import nodomain.freeyourgadget.gadgetbridge.service.devices.pebble.PebbleProtoco
|
||||
public class PBWReader {
|
||||
private static final Logger LOG = LoggerFactory.getLogger(PBWReader.class);
|
||||
private static final HashMap<String, Byte> appFileTypesMap;
|
||||
private static final HashMap<String, Byte> fwFileTypesMap;
|
||||
|
||||
static {
|
||||
appFileTypesMap = new HashMap<>();
|
||||
@ -40,8 +39,6 @@ public class PBWReader {
|
||||
appFileTypesMap.put("worker", PebbleProtocol.PUTBYTES_TYPE_WORKER);
|
||||
}
|
||||
|
||||
private static final HashMap<String, Byte> fwFileTypesMap;
|
||||
|
||||
static {
|
||||
fwFileTypesMap = new HashMap<>();
|
||||
fwFileTypesMap.put("firmware", PebbleProtocol.PUTBYTES_TYPE_FIRMWARE);
|
||||
@ -65,11 +62,17 @@ public class PBWReader {
|
||||
this.uri = uri;
|
||||
cr = context.getContentResolver();
|
||||
|
||||
if (uri.toString().endsWith(".pbl") && platform.equals("aplite")) {
|
||||
InputStream fin;
|
||||
STM32CRC stm32crc = new STM32CRC();
|
||||
try {
|
||||
fin = new BufferedInputStream(cr.openInputStream(uri));
|
||||
} catch (FileNotFoundException e) {
|
||||
e.printStackTrace();
|
||||
return;
|
||||
}
|
||||
|
||||
if (uri.toString().endsWith(".pbl") && platform.equals("aplite")) {
|
||||
STM32CRC stm32crc = new STM32CRC();
|
||||
try {
|
||||
byte[] buf = new byte[2000];
|
||||
while (fin.available() > 0) {
|
||||
int count = fin.read(buf);
|
||||
@ -95,43 +98,48 @@ public class PBWReader {
|
||||
}
|
||||
|
||||
String platformDir = "";
|
||||
|
||||
if (!uri.toString().endsWith(".pbz")) {
|
||||
platformDir = platform + "/";
|
||||
}
|
||||
|
||||
ZipFile zipFile;
|
||||
if (platform.equals("aplite")) {
|
||||
boolean hasApliteDir = false;
|
||||
InputStream afin;
|
||||
|
||||
try {
|
||||
zipFile = new ZipFile(uri.getPath());
|
||||
} catch (IOException e) {
|
||||
afin = new BufferedInputStream(cr.openInputStream(uri));
|
||||
} catch (FileNotFoundException e) {
|
||||
e.printStackTrace();
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
if (platform.equals("aplite")) {
|
||||
boolean hasApliteDir = false;
|
||||
Enumeration zentries = zipFile.entries();
|
||||
while (zentries.hasMoreElements()) {
|
||||
ZipEntry entry = (ZipEntry) zentries.nextElement();
|
||||
if (entry.getName().startsWith("aplite/")) {
|
||||
ZipInputStream zis = new ZipInputStream(afin);
|
||||
ZipEntry ze;
|
||||
try {
|
||||
while ((ze = zis.getNextEntry()) != null) {
|
||||
if (ze.getName().startsWith("aplite/")) {
|
||||
hasApliteDir = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
zis.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
if (!hasApliteDir) {
|
||||
platformDir = "";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ZipInputStream zis = new ZipInputStream(fin);
|
||||
ZipEntry ze;
|
||||
pebbleInstallables = new ArrayList<>();
|
||||
byte[] buffer = new byte[1024];
|
||||
int count;
|
||||
try {
|
||||
Enumeration zentries = zipFile.entries();
|
||||
while (zentries.hasMoreElements()) {
|
||||
ZipEntry ze = (ZipEntry) zentries.nextElement();
|
||||
InputStream zis = zipFile.getInputStream(ze);
|
||||
|
||||
while ((ze = zis.getNextEntry()) != null) {
|
||||
String fileName = ze.getName();
|
||||
if (fileName.equals(platformDir + "manifest.json")) {
|
||||
long bytes = ze.getSize();
|
||||
@ -226,8 +234,8 @@ public class PBWReader {
|
||||
LOG.info("got flags from pebble-app.bin: " + mFlags);
|
||||
// more follows but, not interesting for us
|
||||
}
|
||||
zis.close();
|
||||
}
|
||||
zis.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user