Adds InstalledApp.needsResign

When true, app will be resigned + reinstalled next refresh rather than just refreshing provisioning profiles.
This commit is contained in:
Riley Testut
2020-10-01 11:51:39 -07:00
parent 707c2db508
commit 12f33c355a
4 changed files with 19 additions and 15 deletions

View File

@@ -667,8 +667,19 @@ private extension AppManager
case .refresh(let app):
// Check if backup app is installed in place of real app.
let uti = UTTypeCopyDeclaration(app.installedBackupAppUTI as CFString)?.takeRetainedValue() as NSDictionary?
if app.certificateSerialNumber == group.context.certificate?.serialNumber && uti == nil
if app.certificateSerialNumber != group.context.certificate?.serialNumber || uti != nil || app.needsResign
{
// Resign app instead of just refreshing profiles because either:
// * Refreshing using different certificate
// * Backup app is still installed
// * App explicitly needs resigning
let installProgress = self._install(app, operation: operation, group: group) { (result) in
self.finish(operation, result: result, group: group, progress: progress)
}
progress?.addChild(installProgress, withPendingUnitCount: 80)
}
else
{
// Refreshing with same certificate as last time, and backup app isn't still installed,
// so we can just refresh provisioning profiles.
@@ -678,16 +689,6 @@ private extension AppManager
}
progress?.addChild(refreshProgress, withPendingUnitCount: 80)
}
else
{
// Refreshing using different certificate or backup app is still installed,
// so we need to resign + install.
let installProgress = self._install(app, operation: operation, group: group) { (result) in
self.finish(operation, result: result, group: group, progress: progress)
}
progress?.addChild(installProgress, withPendingUnitCount: 80)
}
case .activate(let app):
let activateProgress = self._activate(app, operation: operation, group: group) { (result) in

View File

@@ -62,7 +62,8 @@ class InstallAppOperation: ResultOperation<InstalledApp>
}
installedApp.update(resignedApp: resignedApp, certificateSerialNumber: certificate.serialNumber)
installedApp.needsResign = false
if let team = DatabaseManager.shared.activeTeam(in: backgroundContext)
{
installedApp.team = team