@capgo/capacitor-updater 8.0.1 → 8.2.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.
Files changed (55) hide show
  1. package/CapgoCapacitorUpdater.podspec +7 -5
  2. package/Package.swift +9 -7
  3. package/README.md +984 -215
  4. package/android/build.gradle +24 -12
  5. package/android/proguard-rules.pro +22 -5
  6. package/android/src/main/java/ee/forgr/capacitor_updater/BundleInfo.java +110 -22
  7. package/android/src/main/java/ee/forgr/capacitor_updater/Callback.java +2 -2
  8. package/android/src/main/java/ee/forgr/capacitor_updater/CapacitorUpdaterPlugin.java +1316 -489
  9. package/android/src/main/java/ee/forgr/capacitor_updater/{CapacitorUpdater.java → CapgoUpdater.java} +662 -203
  10. package/android/src/main/java/ee/forgr/capacitor_updater/{CryptoCipherV2.java → CryptoCipher.java} +138 -33
  11. package/android/src/main/java/ee/forgr/capacitor_updater/DelayCondition.java +0 -3
  12. package/android/src/main/java/ee/forgr/capacitor_updater/DelayUpdateUtils.java +260 -0
  13. package/android/src/main/java/ee/forgr/capacitor_updater/DeviceIdHelper.java +221 -0
  14. package/android/src/main/java/ee/forgr/capacitor_updater/DownloadService.java +497 -133
  15. package/android/src/main/java/ee/forgr/capacitor_updater/DownloadWorkerManager.java +80 -25
  16. package/android/src/main/java/ee/forgr/capacitor_updater/Logger.java +338 -0
  17. package/android/src/main/java/ee/forgr/capacitor_updater/ShakeDetector.java +72 -0
  18. package/android/src/main/java/ee/forgr/capacitor_updater/ShakeMenu.java +169 -0
  19. package/dist/docs.json +873 -154
  20. package/dist/esm/definitions.d.ts +881 -114
  21. package/dist/esm/definitions.js.map +1 -1
  22. package/dist/esm/history.d.ts +1 -0
  23. package/dist/esm/history.js +283 -0
  24. package/dist/esm/history.js.map +1 -0
  25. package/dist/esm/index.d.ts +1 -0
  26. package/dist/esm/index.js +1 -0
  27. package/dist/esm/index.js.map +1 -1
  28. package/dist/esm/web.d.ts +12 -1
  29. package/dist/esm/web.js +29 -2
  30. package/dist/esm/web.js.map +1 -1
  31. package/dist/plugin.cjs.js +311 -2
  32. package/dist/plugin.cjs.js.map +1 -1
  33. package/dist/plugin.js +311 -2
  34. package/dist/plugin.js.map +1 -1
  35. package/ios/Sources/CapacitorUpdaterPlugin/AES.swift +69 -0
  36. package/ios/Sources/CapacitorUpdaterPlugin/BigInt.swift +55 -0
  37. package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/BundleInfo.swift +37 -10
  38. package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/BundleStatus.swift +1 -1
  39. package/ios/Sources/CapacitorUpdaterPlugin/CapacitorUpdaterPlugin.swift +1610 -0
  40. package/ios/{Plugin/CapacitorUpdater.swift → Sources/CapacitorUpdaterPlugin/CapgoUpdater.swift} +541 -231
  41. package/ios/Sources/CapacitorUpdaterPlugin/CryptoCipher.swift +286 -0
  42. package/ios/Sources/CapacitorUpdaterPlugin/DelayUpdateUtils.swift +220 -0
  43. package/ios/Sources/CapacitorUpdaterPlugin/DeviceIdHelper.swift +120 -0
  44. package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/InternalUtils.swift +54 -0
  45. package/ios/Sources/CapacitorUpdaterPlugin/Logger.swift +310 -0
  46. package/ios/Sources/CapacitorUpdaterPlugin/RSA.swift +274 -0
  47. package/ios/Sources/CapacitorUpdaterPlugin/ShakeMenu.swift +112 -0
  48. package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/UserDefaultsExtension.swift +0 -2
  49. package/package.json +21 -19
  50. package/ios/Plugin/CapacitorUpdaterPlugin.swift +0 -975
  51. package/ios/Plugin/CryptoCipherV2.swift +0 -310
  52. /package/{LICENCE → LICENSE} +0 -0
  53. /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/DelayCondition.swift +0 -0
  54. /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/DelayUntilNext.swift +0 -0
  55. /package/ios/{Plugin → Sources/CapacitorUpdaterPlugin}/Info.plist +0 -0
@@ -0,0 +1,112 @@
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
+ import UIKit
8
+ import Capacitor
9
+
10
+ extension UIApplication {
11
+ public class func topViewController(_ base: UIViewController? = UIApplication.shared.windows.first?.rootViewController) -> UIViewController? {
12
+ if let nav = base as? UINavigationController {
13
+ return topViewController(nav.visibleViewController)
14
+ }
15
+ if let tab = base as? UITabBarController, let selected = tab.selectedViewController {
16
+ return topViewController(selected)
17
+ }
18
+ if let presented = base?.presentedViewController {
19
+ return topViewController(presented)
20
+ }
21
+ return base
22
+ }
23
+ }
24
+
25
+ extension UIWindow {
26
+ override open func motionEnded(_ motion: UIEvent.EventSubtype, with event: UIEvent?) {
27
+ if motion == .motionShake {
28
+ // Find the CapacitorUpdaterPlugin instance
29
+ guard let bridge = (rootViewController as? CAPBridgeProtocol),
30
+ let plugin = bridge.plugin(withName: "CapacitorUpdaterPlugin") as? CapacitorUpdaterPlugin else {
31
+ return
32
+ }
33
+
34
+ // Check if shake menu is enabled
35
+ if !plugin.shakeMenuEnabled {
36
+ return
37
+ }
38
+
39
+ showShakeMenu(plugin: plugin, bridge: bridge)
40
+ }
41
+ }
42
+
43
+ private func showShakeMenu(plugin: CapacitorUpdaterPlugin, bridge: CAPBridgeProtocol) {
44
+ // Prevent multiple alerts from showing
45
+ if let topVC = UIApplication.topViewController(),
46
+ topVC.isKind(of: UIAlertController.self) {
47
+ plugin.logger.info("UIAlertController is already presented")
48
+ return
49
+ }
50
+
51
+ let appName = Bundle.main.infoDictionary?["CFBundleDisplayName"] as? String ?? "App"
52
+ let title = "Preview \(appName) Menu"
53
+ let message = "What would you like to do?"
54
+ let okButtonTitle = "Go Home"
55
+ let reloadButtonTitle = "Reload app"
56
+ let cancelButtonTitle = "Close menu"
57
+
58
+ let updater = plugin.implementation
59
+
60
+ func resetBuiltin() {
61
+ updater.reset()
62
+ bridge.setServerBasePath("")
63
+ DispatchQueue.main.async {
64
+ if let vc = (self.rootViewController as? CAPBridgeViewController) {
65
+ vc.loadView()
66
+ vc.viewDidLoad()
67
+ }
68
+ _ = updater.delete(id: updater.getCurrentBundleId())
69
+ plugin.logger.info("Reset to builtin version")
70
+ }
71
+ }
72
+
73
+ let bundleId = updater.getCurrentBundleId()
74
+ if let vc = (self.rootViewController as? CAPBridgeViewController) {
75
+ plugin.logger.info("getServerBasePath: \(vc.getServerBasePath())")
76
+ }
77
+ plugin.logger.info("bundleId: \(bundleId)")
78
+
79
+ let alertShake = UIAlertController(title: title, message: message, preferredStyle: .alert)
80
+
81
+ alertShake.addAction(UIAlertAction(title: okButtonTitle, style: .default) { _ in
82
+ guard let next = updater.getNextBundle() else {
83
+ resetBuiltin()
84
+ return
85
+ }
86
+ if !next.isBuiltin() {
87
+ plugin.logger.info("Resetting to: \(next.toString())")
88
+ _ = updater.set(bundle: next)
89
+ let destHot = updater.getBundleDirectory(id: next.getId())
90
+ plugin.logger.info("Reloading \(next.toString())")
91
+ bridge.setServerBasePath(destHot.path)
92
+ } else {
93
+ resetBuiltin()
94
+ }
95
+ plugin.logger.info("Reload app done")
96
+ })
97
+
98
+ alertShake.addAction(UIAlertAction(title: cancelButtonTitle, style: .default))
99
+
100
+ alertShake.addAction(UIAlertAction(title: reloadButtonTitle, style: .default) { _ in
101
+ DispatchQueue.main.async {
102
+ bridge.webView?.reload()
103
+ }
104
+ })
105
+
106
+ DispatchQueue.main.async {
107
+ if let topVC = UIApplication.topViewController() {
108
+ topVC.present(alertShake, animated: true)
109
+ }
110
+ }
111
+ }
112
+ }
@@ -34,9 +34,7 @@ extension UserDefaults: ObjectSavable {
34
34
  }
35
35
 
36
36
  func getObj<Object>(forKey: String, castTo type: Object.Type) throws -> Object where Object: Decodable {
37
- // print("forKey", forKey)
38
37
  guard let data: Data = data(forKey: forKey) else { throw ObjectSavableError.noValue }
39
- // print("data", data)
40
38
  let decoder: JSONDecoder = JSONDecoder()
41
39
  do {
42
40
  let object: Object = try decoder.decode(type, from: data)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@capgo/capacitor-updater",
3
- "version": "8.0.1",
3
+ "version": "8.2.0",
4
4
  "license": "MPL-2.0",
5
5
  "description": "Live update for capacitor apps",
6
6
  "main": "dist/plugin.cjs.js",
@@ -12,11 +12,11 @@
12
12
  "android/proguard-rules.pro",
13
13
  "android/build.gradle",
14
14
  "dist/",
15
- "ios/Plugin/",
15
+ "ios/Sources/",
16
16
  "CapgoCapacitorUpdater.podspec",
17
17
  "Package.swift"
18
18
  ],
19
- "author": "Martin Donadieu",
19
+ "author": "Martin Donadieu <martin@capgo.app>",
20
20
  "repository": {
21
21
  "type": "git",
22
22
  "url": "git+https://github.com/Cap-go/capacitor-updater.git"
@@ -37,48 +37,50 @@
37
37
  "ionic",
38
38
  "appflow alternative",
39
39
  "capawesome alternative",
40
+ "@capawesome/capacitor-live-update",
40
41
  "native"
41
42
  ],
42
43
  "scripts": {
43
44
  "verify": "npm run verify:ios && npm run verify:android && npm run verify:web",
44
- "verify:ios": "cd ios && pod install && xcodebuild -workspace Plugin.xcworkspace -scheme Plugin && cd ..",
45
- "verify:iosSPM": "xcodebuild -workspace ios/Plugin.xcworkspace -scheme Plugin -destination generic/platform=iOS",
45
+ "verify:ios": "xcodebuild -scheme CapgoCapacitorUpdater -destination generic/platform=iOS",
46
46
  "verify:android": "cd android && ./gradlew clean build test && cd ..",
47
47
  "verify:web": "npm run build",
48
+ "test": "npm run test:ios && npm run test:android",
49
+ "test:ios": "./scripts/test-ios.sh",
50
+ "test:android": "cd android && ./gradlew test && cd ..",
48
51
  "lint": "npm run eslint && npm run prettier -- --check && npm run swiftlint -- lint",
49
- "fmt": "npm run eslint -- --fix && npm run prettier -- --write && npm run swiftlint -- --autocorrect --format",
52
+ "fmt": "npm run eslint -- --fix && npm run prettier -- --write && npm run swiftlint -- --fix --format",
50
53
  "eslint": "eslint . --ext .ts",
51
54
  "prettier": "prettier \"**/*.{css,html,ts,js,java}\" --plugin=prettier-plugin-java",
52
55
  "swiftlint": "node-swiftlint",
53
- "docgen": "docgen --api CapacitorUpdaterPlugin --output-readme README.md --output-json dist/docs.json",
54
- "docgen:api": "docgen --api CapacitorUpdaterPlugin --output-readme api.md --output-json dist/docs.json && awk '{sub(/###/,\"##\")}1' api.md > temp.txt && mv temp.txt api.md",
56
+ "docgen": "node scripts/generate-docs.js",
55
57
  "build": "npm run clean && npm run docgen && tsc && rollup -c rollup.config.mjs",
56
58
  "clean": "rimraf ./dist",
57
59
  "watch": "tsc --watch",
58
60
  "prepublishOnly": "npm run build"
59
61
  },
60
62
  "devDependencies": {
61
- "@capacitor/android": "^7.0.0",
62
- "@capacitor/cli": "^7.0.0",
63
- "@capacitor/core": "^7.0.0",
63
+ "@capacitor/android": "^8.0.0",
64
+ "@capacitor/cli": "^8.0.0",
65
+ "@capacitor/core": "^8.0.0",
64
66
  "@capacitor/docgen": "^0.3.0",
65
- "@capacitor/ios": "^7.0.0",
67
+ "@capacitor/ios": "^8.0.0",
66
68
  "@ionic/eslint-config": "^0.4.0",
67
69
  "@ionic/prettier-config": "^4.0.0",
68
70
  "@ionic/swiftlint-config": "^2.0.0",
69
- "@types/node": "^22.13.1",
71
+ "@types/node": "^24.3.0",
70
72
  "eslint": "^8.57.0",
71
- "eslint-plugin-import": "^2.31.0",
73
+ "eslint-plugin-import": "^2.32.0",
72
74
  "husky": "^9.1.7",
73
- "prettier": "^3.4.2",
74
- "prettier-plugin-java": "^2.6.7",
75
+ "prettier": "^3.6.2",
76
+ "prettier-plugin-java": "^2.7.4",
75
77
  "rimraf": "^6.0.1",
76
- "rollup": "^4.34.6",
78
+ "rollup": "^4.50.0",
77
79
  "swiftlint": "^2.0.0",
78
- "typescript": "^5.7.3"
80
+ "typescript": "^5.9.2"
79
81
  },
80
82
  "peerDependencies": {
81
- "@capacitor/core": ">=7.0.0"
83
+ "@capacitor/core": "^8.0.0"
82
84
  },
83
85
  "prettier": "@ionic/prettier-config",
84
86
  "swiftlint": "@ionic/swiftlint-config",