@capgo/capacitor-updater 8.0.0 → 8.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CapgoCapacitorUpdater.podspec +7 -5
- package/Package.swift +37 -0
- package/README.md +1461 -231
- package/android/build.gradle +29 -12
- package/android/proguard-rules.pro +45 -0
- package/android/src/main/AndroidManifest.xml +0 -1
- package/android/src/main/java/ee/forgr/capacitor_updater/BundleInfo.java +223 -195
- package/android/src/main/java/ee/forgr/capacitor_updater/BundleStatus.java +23 -23
- package/android/src/main/java/ee/forgr/capacitor_updater/Callback.java +13 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/CapacitorUpdaterPlugin.java +2159 -1234
- package/android/src/main/java/ee/forgr/capacitor_updater/CapgoUpdater.java +1507 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/CryptoCipher.java +330 -121
- package/android/src/main/java/ee/forgr/capacitor_updater/DataManager.java +28 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/DelayCondition.java +43 -49
- package/android/src/main/java/ee/forgr/capacitor_updater/DelayUntilNext.java +4 -4
- package/android/src/main/java/ee/forgr/capacitor_updater/DelayUpdateUtils.java +260 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/DeviceIdHelper.java +221 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/DownloadService.java +808 -117
- package/android/src/main/java/ee/forgr/capacitor_updater/DownloadWorkerManager.java +156 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/InternalUtils.java +32 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/Logger.java +338 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/ShakeDetector.java +72 -0
- package/android/src/main/java/ee/forgr/capacitor_updater/ShakeMenu.java +169 -0
- package/dist/docs.json +2187 -625
- package/dist/esm/definitions.d.ts +1286 -249
- package/dist/esm/definitions.js.map +1 -1
- package/dist/esm/history.d.ts +1 -0
- package/dist/esm/history.js +283 -0
- package/dist/esm/history.js.map +1 -0
- package/dist/esm/index.d.ts +3 -2
- package/dist/esm/index.js +5 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/web.d.ts +36 -41
- package/dist/esm/web.js +94 -35
- package/dist/esm/web.js.map +1 -1
- package/dist/plugin.cjs.js +376 -35
- package/dist/plugin.cjs.js.map +1 -1
- package/dist/plugin.js +376 -35
- package/dist/plugin.js.map +1 -1
- package/ios/Sources/CapacitorUpdaterPlugin/AES.swift +69 -0
- package/ios/Sources/CapacitorUpdaterPlugin/BigInt.swift +55 -0
- package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/BundleInfo.swift +37 -10
- package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/BundleStatus.swift +1 -1
- package/ios/Sources/CapacitorUpdaterPlugin/CapacitorUpdaterPlugin.swift +1605 -0
- package/ios/Sources/CapacitorUpdaterPlugin/CapgoUpdater.swift +1526 -0
- package/ios/Sources/CapacitorUpdaterPlugin/CryptoCipher.swift +267 -0
- package/ios/Sources/CapacitorUpdaterPlugin/DelayUpdateUtils.swift +220 -0
- package/ios/Sources/CapacitorUpdaterPlugin/DeviceIdHelper.swift +120 -0
- package/ios/Sources/CapacitorUpdaterPlugin/InternalUtils.swift +311 -0
- package/ios/Sources/CapacitorUpdaterPlugin/Logger.swift +310 -0
- package/ios/Sources/CapacitorUpdaterPlugin/RSA.swift +274 -0
- package/ios/Sources/CapacitorUpdaterPlugin/ShakeMenu.swift +112 -0
- package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/UserDefaultsExtension.swift +0 -2
- package/package.json +41 -35
- package/android/src/main/java/ee/forgr/capacitor_updater/CapacitorUpdater.java +0 -1130
- package/ios/Plugin/CapacitorUpdater.swift +0 -858
- package/ios/Plugin/CapacitorUpdaterPlugin.h +0 -10
- package/ios/Plugin/CapacitorUpdaterPlugin.m +0 -27
- package/ios/Plugin/CapacitorUpdaterPlugin.swift +0 -675
- package/ios/Plugin/CryptoCipher.swift +0 -240
- /package/{LICENCE → LICENSE} +0 -0
- /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/DelayCondition.swift +0 -0
- /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/DelayUntilNext.swift +0 -0
- /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/Info.plist +0 -0
package/android/build.gradle
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
ext {
|
|
2
2
|
junitVersion = project.hasProperty('junitVersion') ? rootProject.ext.junitVersion : '4.13.2'
|
|
3
|
-
androidxAppCompatVersion = project.hasProperty('androidxAppCompatVersion') ? rootProject.ext.androidxAppCompatVersion : '1.
|
|
4
|
-
androidxJunitVersion = project.hasProperty('androidxJunitVersion') ? rootProject.ext.androidxJunitVersion : '1.
|
|
5
|
-
androidxEspressoCoreVersion = project.hasProperty('androidxEspressoCoreVersion') ? rootProject.ext.androidxEspressoCoreVersion : '3.
|
|
3
|
+
androidxAppCompatVersion = project.hasProperty('androidxAppCompatVersion') ? rootProject.ext.androidxAppCompatVersion : '1.7.1'
|
|
4
|
+
androidxJunitVersion = project.hasProperty('androidxJunitVersion') ? rootProject.ext.androidxJunitVersion : '1.3.0'
|
|
5
|
+
androidxEspressoCoreVersion = project.hasProperty('androidxEspressoCoreVersion') ? rootProject.ext.androidxEspressoCoreVersion : '3.7.0'
|
|
6
6
|
}
|
|
7
7
|
|
|
8
8
|
buildscript {
|
|
@@ -11,18 +11,18 @@ buildscript {
|
|
|
11
11
|
mavenCentral()
|
|
12
12
|
}
|
|
13
13
|
dependencies {
|
|
14
|
-
classpath 'com.android.tools.build:gradle:8.0
|
|
14
|
+
classpath 'com.android.tools.build:gradle:8.13.0'
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
apply plugin: 'com.android.library'
|
|
19
19
|
|
|
20
20
|
android {
|
|
21
|
-
namespace "ee.forgr.capacitor_updater"
|
|
22
|
-
|
|
21
|
+
namespace = "ee.forgr.capacitor_updater"
|
|
22
|
+
compileSdk project.hasProperty('compileSdkVersion') ? rootProject.ext.compileSdkVersion : 36
|
|
23
23
|
defaultConfig {
|
|
24
|
-
minSdkVersion project.hasProperty('minSdkVersion') ? rootProject.ext.minSdkVersion :
|
|
25
|
-
targetSdkVersion project.hasProperty('targetSdkVersion') ? rootProject.ext.targetSdkVersion :
|
|
24
|
+
minSdkVersion project.hasProperty('minSdkVersion') ? rootProject.ext.minSdkVersion : 24
|
|
25
|
+
targetSdkVersion project.hasProperty('targetSdkVersion') ? rootProject.ext.targetSdkVersion : 36
|
|
26
26
|
versionCode 1
|
|
27
27
|
versionName "1.0"
|
|
28
28
|
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
|
@@ -37,8 +37,8 @@ android {
|
|
|
37
37
|
abortOnError false
|
|
38
38
|
}
|
|
39
39
|
compileOptions {
|
|
40
|
-
sourceCompatibility JavaVersion.
|
|
41
|
-
targetCompatibility JavaVersion.
|
|
40
|
+
sourceCompatibility JavaVersion.VERSION_21
|
|
41
|
+
targetCompatibility JavaVersion.VERSION_21
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
|
|
@@ -49,13 +49,30 @@ repositories {
|
|
|
49
49
|
|
|
50
50
|
|
|
51
51
|
dependencies {
|
|
52
|
+
def work_version = "2.10.5"
|
|
53
|
+
implementation "androidx.work:work-runtime:$work_version"
|
|
54
|
+
implementation "com.google.android.gms:play-services-tasks:18.4.0"
|
|
55
|
+
implementation "com.google.guava:guava:33.5.0-android"
|
|
52
56
|
implementation fileTree(dir: 'libs', include: ['*.jar'])
|
|
53
57
|
implementation project(':capacitor-android')
|
|
54
58
|
implementation "androidx.appcompat:appcompat:$androidxAppCompatVersion"
|
|
55
|
-
implementation 'com.android.volley:volley:1.2.1'
|
|
56
59
|
implementation 'io.github.g00fy2:versioncompare:1.5.0'
|
|
57
|
-
implementation 'com.google.code.gson:gson:2.10.1'
|
|
58
60
|
testImplementation "junit:junit:$junitVersion"
|
|
61
|
+
testImplementation 'org.mockito:mockito-core:5.20.0'
|
|
62
|
+
testImplementation 'org.json:json:20250517'
|
|
63
|
+
testImplementation 'org.robolectric:robolectric:4.13'
|
|
59
64
|
androidTestImplementation "androidx.test.ext:junit:$androidxJunitVersion"
|
|
60
65
|
androidTestImplementation "androidx.test.espresso:espresso-core:$androidxEspressoCoreVersion"
|
|
66
|
+
implementation 'org.brotli:dec:0.1.2'
|
|
67
|
+
implementation 'com.squareup.okhttp3:okhttp:4.12.0'
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
tasks.withType(Test) {
|
|
71
|
+
testLogging {
|
|
72
|
+
events "passed", "skipped", "failed", "standardOut", "standardError"
|
|
73
|
+
exceptionFormat "full"
|
|
74
|
+
showStandardStreams = true
|
|
75
|
+
showCauses = true
|
|
76
|
+
showStackTraces = true
|
|
77
|
+
}
|
|
61
78
|
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
# Add project specific ProGuard rules here.
|
|
2
|
+
# You can control the set of applied configuration files using the
|
|
3
|
+
# proguardFiles setting in build.gradle.
|
|
4
|
+
#
|
|
5
|
+
# For more details, see
|
|
6
|
+
# http://developer.android.com/guide/developing/tools/proguard.html
|
|
7
|
+
|
|
8
|
+
# If your project uses WebView with JS, uncomment the following
|
|
9
|
+
# and specify the fully qualified class name to the JavaScript interface
|
|
10
|
+
# class:
|
|
11
|
+
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
|
12
|
+
# public *;
|
|
13
|
+
#}
|
|
14
|
+
|
|
15
|
+
# Uncomment this to preserve the line number information for
|
|
16
|
+
# debugging stack traces.
|
|
17
|
+
#-keepattributes SourceFile,LineNumberTable
|
|
18
|
+
|
|
19
|
+
# If you keep the line number information, uncomment this to
|
|
20
|
+
# hide the original source file name.
|
|
21
|
+
#-renamesourcefileattribute SourceFile
|
|
22
|
+
|
|
23
|
+
# Preserve annotation and signature metadata used by runtime checks
|
|
24
|
+
-keepattributes *Annotation*, Signature
|
|
25
|
+
|
|
26
|
+
# Preserve the entire Capgo plugin package
|
|
27
|
+
-keep class ee.forgr.capacitor_updater.** { *; }
|
|
28
|
+
|
|
29
|
+
# Preserve Capacitor classes and members accessed via reflection for autoSplashscreen
|
|
30
|
+
# These rules are safe even if SplashScreen plugin is not present - they only reference core Capacitor classes
|
|
31
|
+
-keep class com.getcapacitor.Bridge {
|
|
32
|
+
com.getcapacitor.MessageHandler msgHandler;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
-keep class com.getcapacitor.MessageHandler { *; }
|
|
36
|
+
|
|
37
|
+
-keep class com.getcapacitor.PluginCall {
|
|
38
|
+
<init>(com.getcapacitor.MessageHandler, java.lang.String, java.lang.String, java.lang.String, com.getcapacitor.JSObject);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
# Keep SplashScreen plugin methods that are called via reflection
|
|
42
|
+
# This applies to any plugin, not just SplashScreen
|
|
43
|
+
-keep class * implements com.getcapacitor.PluginHandle {
|
|
44
|
+
public void invoke(java.lang.String, com.getcapacitor.PluginCall);
|
|
45
|
+
}
|
|
@@ -6,9 +6,10 @@
|
|
|
6
6
|
|
|
7
7
|
package ee.forgr.capacitor_updater;
|
|
8
8
|
|
|
9
|
-
import com.getcapacitor.JSObject;
|
|
10
9
|
import java.text.SimpleDateFormat;
|
|
11
10
|
import java.util.Date;
|
|
11
|
+
import java.util.HashMap;
|
|
12
|
+
import java.util.Map;
|
|
12
13
|
import java.util.Objects;
|
|
13
14
|
import java.util.TimeZone;
|
|
14
15
|
import org.json.JSONException;
|
|
@@ -17,198 +18,225 @@ import org.json.JSONTokener;
|
|
|
17
18
|
|
|
18
19
|
public class BundleInfo {
|
|
19
20
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
)
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
21
|
+
private static final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSZ");
|
|
22
|
+
|
|
23
|
+
public static final String ID_BUILTIN = "builtin";
|
|
24
|
+
public static final String VERSION_UNKNOWN = "unknown";
|
|
25
|
+
public static final String DOWNLOADED_BUILTIN = "1970-01-01T00:00:00.000Z";
|
|
26
|
+
|
|
27
|
+
private final String downloaded;
|
|
28
|
+
private final String id;
|
|
29
|
+
private final String version;
|
|
30
|
+
private final String checksum;
|
|
31
|
+
private final BundleStatus status;
|
|
32
|
+
private final String link;
|
|
33
|
+
private final String comment;
|
|
34
|
+
|
|
35
|
+
static {
|
|
36
|
+
sdf.setTimeZone(TimeZone.getTimeZone("GMT"));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public BundleInfo(final BundleInfo source) {
|
|
40
|
+
this(source.id, source.version, source.status, source.downloaded, source.checksum, source.link, source.comment);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public BundleInfo(final String id, final String version, final BundleStatus status, final Date downloaded, final String checksum) {
|
|
44
|
+
this(id, version, status, sdf.format(downloaded), checksum, null, null);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
public BundleInfo(
|
|
48
|
+
final String id,
|
|
49
|
+
final String version,
|
|
50
|
+
final BundleStatus status,
|
|
51
|
+
final Date downloaded,
|
|
52
|
+
final String checksum,
|
|
53
|
+
final String link,
|
|
54
|
+
final String comment
|
|
55
|
+
) {
|
|
56
|
+
this(id, version, status, sdf.format(downloaded), checksum, link, comment);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
public BundleInfo(final String id, final String version, final BundleStatus status, final String downloaded, final String checksum) {
|
|
60
|
+
this(id, version, status, downloaded, checksum, null, null);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
public BundleInfo(
|
|
64
|
+
final String id,
|
|
65
|
+
final String version,
|
|
66
|
+
final BundleStatus status,
|
|
67
|
+
final String downloaded,
|
|
68
|
+
final String checksum,
|
|
69
|
+
final String link,
|
|
70
|
+
final String comment
|
|
71
|
+
) {
|
|
72
|
+
this.downloaded = downloaded != null ? downloaded.trim() : "";
|
|
73
|
+
this.id = id != null ? id : "";
|
|
74
|
+
this.version = version;
|
|
75
|
+
this.checksum = checksum != null ? checksum : "";
|
|
76
|
+
this.status = status != null ? status : BundleStatus.ERROR;
|
|
77
|
+
this.link = link;
|
|
78
|
+
this.comment = comment;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public Boolean isBuiltin() {
|
|
82
|
+
return ID_BUILTIN.equals(this.id);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
public Boolean isUnknown() {
|
|
86
|
+
return VERSION_UNKNOWN.equals(this.id);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
public Boolean isErrorStatus() {
|
|
90
|
+
return BundleStatus.ERROR == this.status;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
public Boolean isDeleted() {
|
|
94
|
+
return BundleStatus.DELETED == this.status;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
public boolean isDownloaded() {
|
|
98
|
+
return (!this.isBuiltin() && this.downloaded != null && !this.downloaded.isEmpty() && !this.isDeleted());
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
public String getDownloaded() {
|
|
102
|
+
return this.isBuiltin() ? DOWNLOADED_BUILTIN : (this.downloaded != null ? this.downloaded : "");
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
public BundleInfo setDownloaded(Date downloaded) {
|
|
106
|
+
return new BundleInfo(this.id, this.version, this.status, downloaded, this.checksum, this.link, this.comment);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
public String getChecksum() {
|
|
110
|
+
return this.isBuiltin() ? "" : (this.checksum != null ? this.checksum : "");
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
public BundleInfo setChecksum(String checksum) {
|
|
114
|
+
return new BundleInfo(this.id, this.version, this.status, this.downloaded, checksum, this.link, this.comment);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
public String getId() {
|
|
118
|
+
return this.isBuiltin() ? ID_BUILTIN : this.id;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
public BundleInfo setId(String id) {
|
|
122
|
+
return new BundleInfo(id, this.version, this.status, this.downloaded, this.checksum, this.link, this.comment);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
public String getVersionName() {
|
|
126
|
+
return this.version == null ? ID_BUILTIN : this.version;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
public BundleInfo setVersionName(String version) {
|
|
130
|
+
return new BundleInfo(this.id, version, this.status, this.downloaded, this.checksum, this.link, this.comment);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
public BundleStatus getStatus() {
|
|
134
|
+
if (this.isBuiltin()) {
|
|
135
|
+
return BundleStatus.SUCCESS;
|
|
136
|
+
}
|
|
137
|
+
return this.status != null ? this.status : BundleStatus.ERROR;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
public BundleInfo setStatus(BundleStatus status) {
|
|
141
|
+
return new BundleInfo(this.id, this.version, status, this.downloaded, this.checksum, this.link, this.comment);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
public String getLink() {
|
|
145
|
+
return this.link;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
public BundleInfo setLink(String link) {
|
|
149
|
+
return new BundleInfo(this.id, this.version, this.status, this.downloaded, this.checksum, link, this.comment);
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
public String getComment() {
|
|
153
|
+
return this.comment;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
public BundleInfo setComment(String comment) {
|
|
157
|
+
return new BundleInfo(this.id, this.version, this.status, this.downloaded, this.checksum, this.link, comment);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
public static BundleInfo fromJSON(final String jsonString) throws JSONException {
|
|
161
|
+
JSONObject json = new JSONObject(new JSONTokener(jsonString));
|
|
162
|
+
return new BundleInfo(
|
|
163
|
+
json.has("id") ? json.getString("id") : "",
|
|
164
|
+
json.has("version") ? json.getString("version") : BundleInfo.VERSION_UNKNOWN,
|
|
165
|
+
json.has("status") ? BundleStatus.fromString(json.getString("status")) : BundleStatus.PENDING,
|
|
166
|
+
json.has("downloaded") ? json.getString("downloaded") : "",
|
|
167
|
+
json.has("checksum") ? json.getString("checksum") : "",
|
|
168
|
+
json.has("link") ? json.getString("link") : null,
|
|
169
|
+
json.has("comment") ? json.getString("comment") : null
|
|
170
|
+
);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
public Map<String, Object> toJSONMap() {
|
|
174
|
+
final Map<String, Object> result = new HashMap<>();
|
|
175
|
+
result.put("id", this.getId());
|
|
176
|
+
result.put("version", this.getVersionName());
|
|
177
|
+
result.put("downloaded", this.getDownloaded());
|
|
178
|
+
result.put("checksum", this.getChecksum());
|
|
179
|
+
result.put("status", this.getStatus().toString());
|
|
180
|
+
if (this.link != null && !this.link.isEmpty()) {
|
|
181
|
+
result.put("link", this.link);
|
|
182
|
+
}
|
|
183
|
+
if (this.comment != null && !this.comment.isEmpty()) {
|
|
184
|
+
result.put("comment", this.comment);
|
|
185
|
+
}
|
|
186
|
+
return result;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
@Override
|
|
190
|
+
public boolean equals(final Object o) {
|
|
191
|
+
if (this == o) return true;
|
|
192
|
+
if (!(o instanceof BundleInfo)) return false;
|
|
193
|
+
final BundleInfo that = (BundleInfo) o;
|
|
194
|
+
return this.getId().equals(that.getId());
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
@Override
|
|
198
|
+
public int hashCode() {
|
|
199
|
+
return Objects.hash(this.version);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
@Override
|
|
203
|
+
public String toString() {
|
|
204
|
+
try {
|
|
205
|
+
// Build JSON manually with extra safety checks
|
|
206
|
+
StringBuilder json = new StringBuilder();
|
|
207
|
+
json.append("{");
|
|
208
|
+
|
|
209
|
+
// Safe ID access
|
|
210
|
+
String safeId = this.id != null ? this.id : "";
|
|
211
|
+
if (this.isBuiltin()) safeId = ID_BUILTIN;
|
|
212
|
+
json.append("\"id\":\"").append(safeId).append("\",");
|
|
213
|
+
|
|
214
|
+
// Safe version access
|
|
215
|
+
String safeVersion = this.version != null ? this.version : ID_BUILTIN;
|
|
216
|
+
json.append("\"version\":\"").append(safeVersion).append("\",");
|
|
217
|
+
|
|
218
|
+
// Safe downloaded access
|
|
219
|
+
String safeDownloaded = this.downloaded != null ? this.downloaded : "";
|
|
220
|
+
if (this.isBuiltin()) safeDownloaded = DOWNLOADED_BUILTIN;
|
|
221
|
+
json.append("\"downloaded\":\"").append(safeDownloaded).append("\",");
|
|
222
|
+
|
|
223
|
+
// Safe checksum access
|
|
224
|
+
String safeChecksum = this.checksum != null ? this.checksum : "";
|
|
225
|
+
json.append("\"checksum\":\"").append(safeChecksum).append("\",");
|
|
226
|
+
|
|
227
|
+
// Safe status access
|
|
228
|
+
BundleStatus safeStatus = this.status != null ? this.status : BundleStatus.ERROR;
|
|
229
|
+
if (this.isBuiltin()) safeStatus = BundleStatus.SUCCESS;
|
|
230
|
+
json.append("\"status\":\"").append(safeStatus.toString()).append("\"");
|
|
231
|
+
|
|
232
|
+
json.append("}");
|
|
233
|
+
return json.toString();
|
|
234
|
+
} catch (Exception e) {
|
|
235
|
+
// Log the error for debugging but still return valid JSON
|
|
236
|
+
System.err.println("BundleInfo toString() error: " + e.getMessage());
|
|
237
|
+
e.printStackTrace();
|
|
238
|
+
// Return absolute minimal JSON
|
|
239
|
+
return "{\"id\":\"" + (this.id != null ? this.id : "unknown") + "\",\"status\":\"error\"}";
|
|
240
|
+
}
|
|
241
|
+
}
|
|
214
242
|
}
|
|
@@ -10,35 +10,35 @@ import java.util.HashMap;
|
|
|
10
10
|
import java.util.Map;
|
|
11
11
|
|
|
12
12
|
public enum BundleStatus {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
13
|
+
SUCCESS("success"),
|
|
14
|
+
ERROR("error"),
|
|
15
|
+
PENDING("pending"),
|
|
16
|
+
DELETED("deleted"),
|
|
17
|
+
DOWNLOADING("downloading");
|
|
18
18
|
|
|
19
|
-
|
|
19
|
+
public final String label;
|
|
20
20
|
|
|
21
|
-
|
|
21
|
+
private static final Map<String, BundleStatus> BY_LABEL = new HashMap<>();
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
static {
|
|
24
|
+
for (final BundleStatus e : values()) {
|
|
25
|
+
BY_LABEL.put(e.label, e);
|
|
26
|
+
}
|
|
26
27
|
}
|
|
27
|
-
}
|
|
28
28
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
BundleStatus(final String label) {
|
|
30
|
+
this.label = label;
|
|
31
|
+
}
|
|
32
32
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
33
|
+
@Override
|
|
34
|
+
public String toString() {
|
|
35
|
+
return this.label;
|
|
36
|
+
}
|
|
37
37
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
38
|
+
public static BundleStatus fromString(final String status) {
|
|
39
|
+
if (status == null || status.isEmpty()) {
|
|
40
|
+
return BundleStatus.PENDING;
|
|
41
|
+
}
|
|
42
|
+
return BundleStatus.BY_LABEL.get(status);
|
|
41
43
|
}
|
|
42
|
-
return BundleStatus.BY_LABEL.get(status);
|
|
43
|
-
}
|
|
44
44
|
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
3
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
4
|
+
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
package ee.forgr.capacitor_updater;
|
|
8
|
+
|
|
9
|
+
import java.util.Map;
|
|
10
|
+
|
|
11
|
+
public interface Callback {
|
|
12
|
+
void callback(Map<String, Object> result);
|
|
13
|
+
}
|