Updates most InstalledApp/Extension properties when refreshing apps

This commit is contained in:
Riley Testut
2020-01-24 15:03:16 -08:00
parent 74f44ddfe8
commit 01e95e1baf
4 changed files with 47 additions and 43 deletions

View File

@@ -168,7 +168,6 @@ private extension DatabaseManager
{ {
installedApp = InstalledApp(resignedApp: localApp, originalBundleIdentifier: StoreApp.altstoreAppID, context: context) installedApp = InstalledApp(resignedApp: localApp, originalBundleIdentifier: StoreApp.altstoreAppID, context: context)
installedApp.storeApp = storeApp installedApp.storeApp = storeApp
installedApp.installedDate = Date()
} }
let fileURL = installedApp.fileURL let fileURL = installedApp.fileURL
@@ -195,13 +194,7 @@ private extension DatabaseManager
} }
// Must go after comparing versions to see if we need to update our cached AltStore app bundle. // Must go after comparing versions to see if we need to update our cached AltStore app bundle.
installedApp.version = localApp.version installedApp.update(resignedApp: localApp)
if let provisioningProfile = localApp.provisioningProfile
{
installedApp.refreshedDate = provisioningProfile.creationDate
installedApp.expirationDate = provisioningProfile.expirationDate
}
do do
{ {

View File

@@ -54,10 +54,21 @@ class InstalledApp: NSManagedObject, InstalledAppProtocol
{ {
super.init(entity: InstalledApp.entity(), insertInto: context) super.init(entity: InstalledApp.entity(), insertInto: context)
self.name = resignedApp.name
self.bundleIdentifier = originalBundleIdentifier self.bundleIdentifier = originalBundleIdentifier
self.resignedBundleIdentifier = resignedApp.bundleIdentifier
self.refreshedDate = Date()
self.installedDate = Date()
self.expirationDate = self.refreshedDate.addingTimeInterval(60 * 60 * 24 * 7) // Rough estimate until we get real values from provisioning profile.
self.update(resignedApp: resignedApp)
}
func update(resignedApp: ALTApplication)
{
self.name = resignedApp.name
self.resignedBundleIdentifier = resignedApp.bundleIdentifier
self.version = resignedApp.version self.version = resignedApp.version
if let provisioningProfile = resignedApp.provisioningProfile if let provisioningProfile = resignedApp.provisioningProfile
@@ -65,13 +76,6 @@ class InstalledApp: NSManagedObject, InstalledAppProtocol
self.refreshedDate = provisioningProfile.creationDate self.refreshedDate = provisioningProfile.creationDate
self.expirationDate = provisioningProfile.expirationDate self.expirationDate = provisioningProfile.expirationDate
} }
else
{
self.refreshedDate = Date()
self.expirationDate = self.refreshedDate.addingTimeInterval(60 * 60 * 24 * 7) // Rough estimate until we get real values from provisioning profile.
}
self.installedDate = Date()
} }
} }

View File

@@ -36,10 +36,21 @@ class InstalledExtension: NSManagedObject, InstalledAppProtocol
{ {
super.init(entity: InstalledExtension.entity(), insertInto: context) super.init(entity: InstalledExtension.entity(), insertInto: context)
self.name = resignedAppExtension.name
self.bundleIdentifier = originalBundleIdentifier self.bundleIdentifier = originalBundleIdentifier
self.resignedBundleIdentifier = resignedAppExtension.bundleIdentifier
self.refreshedDate = Date()
self.installedDate = Date()
self.expirationDate = self.refreshedDate.addingTimeInterval(60 * 60 * 24 * 7) // Rough estimate until we get real values from provisioning profile.
self.update(resignedAppExtension: resignedAppExtension)
}
func update(resignedAppExtension: ALTApplication)
{
self.name = resignedAppExtension.name
self.resignedBundleIdentifier = resignedAppExtension.bundleIdentifier
self.version = resignedAppExtension.version self.version = resignedAppExtension.version
if let provisioningProfile = resignedAppExtension.provisioningProfile if let provisioningProfile = resignedAppExtension.provisioningProfile
@@ -47,13 +58,6 @@ class InstalledExtension: NSManagedObject, InstalledAppProtocol
self.refreshedDate = provisioningProfile.creationDate self.refreshedDate = provisioningProfile.creationDate
self.expirationDate = provisioningProfile.expirationDate self.expirationDate = provisioningProfile.expirationDate
} }
else
{
self.refreshedDate = Date()
self.expirationDate = self.refreshedDate.addingTimeInterval(60 * 60 * 24 * 7) // Rough estimate until we get real values from provisioning profile.
}
self.installedDate = Date()
} }
} }

View File

@@ -46,6 +46,8 @@ class InstallAppOperation: ResultOperation<InstalledApp>
let backgroundContext = DatabaseManager.shared.persistentContainer.newBackgroundContext() let backgroundContext = DatabaseManager.shared.persistentContainer.newBackgroundContext()
backgroundContext.perform { backgroundContext.perform {
/* App */
let installedApp: InstalledApp let installedApp: InstalledApp
// Fetch + update rather than insert + resolve merge conflicts to prevent potential context-level conflicts. // Fetch + update rather than insert + resolve merge conflicts to prevent potential context-level conflicts.
@@ -56,9 +58,16 @@ class InstallAppOperation: ResultOperation<InstalledApp>
else else
{ {
installedApp = InstalledApp(resignedApp: resignedApp, originalBundleIdentifier: self.context.bundleIdentifier, context: backgroundContext) installedApp = InstalledApp(resignedApp: resignedApp, originalBundleIdentifier: self.context.bundleIdentifier, context: backgroundContext)
installedApp.installedDate = Date()
} }
installedApp.update(resignedApp: resignedApp)
if let team = DatabaseManager.shared.activeTeam(in: backgroundContext)
{
installedApp.team = team
}
/* App Extensions */
var installedExtensions = Set<InstalledExtension>() var installedExtensions = Set<InstalledExtension>()
if if
@@ -71,37 +80,31 @@ class InstallAppOperation: ResultOperation<InstalledApp>
guard let appExtensionBundle = Bundle(url: fileURL) else { continue } guard let appExtensionBundle = Bundle(url: fileURL) else { continue }
guard let appExtension = ALTApplication(fileURL: appExtensionBundle.bundleURL) else { continue } guard let appExtension = ALTApplication(fileURL: appExtensionBundle.bundleURL) else { continue }
let parentBundleID = self.context.bundleIdentifier
let resignedParentBundleID = resignedApp.bundleIdentifier
let resignedBundleID = appExtension.bundleIdentifier
let originalBundleID = resignedBundleID.replacingOccurrences(of: resignedParentBundleID, with: parentBundleID)
let installedExtension: InstalledExtension let installedExtension: InstalledExtension
if let appExtension = installedApp.appExtensions.first(where: { $0.bundleIdentifier == appExtension.bundleIdentifier }) if let appExtension = installedApp.appExtensions.first(where: { $0.bundleIdentifier == originalBundleID })
{ {
installedExtension = appExtension installedExtension = appExtension
} }
else else
{ {
installedExtension = InstalledExtension(resignedAppExtension: appExtension, originalBundleIdentifier: appExtension.bundleIdentifier, context: backgroundContext) installedExtension = InstalledExtension(resignedAppExtension: appExtension, originalBundleIdentifier: originalBundleID, context: backgroundContext)
installedExtension.installedDate = Date()
} }
installedExtension.update(resignedAppExtension: appExtension)
installedExtensions.insert(installedExtension) installedExtensions.insert(installedExtension)
} }
} }
installedApp.appExtensions = installedExtensions installedApp.appExtensions = installedExtensions
installedApp.version = resignedApp.version
if let profile = resignedApp.provisioningProfile
{
installedApp.refreshedDate = profile.creationDate
installedApp.expirationDate = profile.expirationDate
}
if let team = Team.first(satisfying: NSPredicate(format: "%K == %@", #keyPath(Team.isActiveTeam), NSNumber(value: true)), in: backgroundContext)
{
installedApp.team = team
}
// Temporary directory and resigned .ipa no longer needed, so delete them now to ensure AltStore doesn't quit before we get the chance to. // Temporary directory and resigned .ipa no longer needed, so delete them now to ensure AltStore doesn't quit before we get the chance to.
self.cleanUp() self.cleanUp()