2019-05-15 01:24:19 +02:00
|
|
|
//
|
|
|
|
// SyncDatabase.swift
|
|
|
|
// NetNewsWire
|
|
|
|
//
|
|
|
|
// Created by Maurice Parker on 5/14/19.
|
|
|
|
// Copyright © 2019 Ranchero Software. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import Foundation
|
2019-11-30 08:42:11 +01:00
|
|
|
import RSCore
|
2019-05-15 01:24:19 +02:00
|
|
|
import RSDatabase
|
|
|
|
|
2019-12-16 20:08:47 +01:00
|
|
|
public typealias SyncStatusesResult = Result<Array<SyncStatus>, DatabaseError>
|
|
|
|
public typealias SyncStatusesCompletionBlock = (SyncStatusesResult) -> Void
|
|
|
|
|
2020-01-03 02:21:18 +01:00
|
|
|
public typealias SyncStatusArticleIDsResult = Result<Set<String>, DatabaseError>
|
|
|
|
public typealias SyncStatusArticleIDsCompletionBlock = (SyncStatusArticleIDsResult) -> Void
|
|
|
|
|
2019-11-30 06:49:44 +01:00
|
|
|
public struct SyncDatabase {
|
|
|
|
|
2019-05-15 01:24:19 +02:00
|
|
|
private let syncStatusTable: SyncStatusTable
|
2019-11-30 06:49:44 +01:00
|
|
|
private let queue: DatabaseQueue
|
|
|
|
|
2019-05-15 01:24:19 +02:00
|
|
|
public init(databaseFilePath: String) {
|
2019-11-30 06:49:44 +01:00
|
|
|
let queue = DatabaseQueue(databasePath: databaseFilePath)
|
2019-12-16 07:28:48 +01:00
|
|
|
try! queue.runCreateStatements(SyncDatabase.tableCreationStatements)
|
2019-11-30 06:49:44 +01:00
|
|
|
queue.vacuumIfNeeded(daysBetweenVacuums: 11)
|
|
|
|
self.queue = queue
|
2019-05-15 01:24:19 +02:00
|
|
|
|
2019-11-30 06:49:44 +01:00
|
|
|
self.syncStatusTable = SyncStatusTable(queue: queue)
|
2019-05-15 01:24:19 +02:00
|
|
|
}
|
2019-11-30 06:49:44 +01:00
|
|
|
|
|
|
|
// MARK: - API
|
|
|
|
|
2020-04-29 23:14:18 +02:00
|
|
|
public func insertStatuses(_ statuses: [SyncStatus]) throws {
|
|
|
|
try syncStatusTable.insertStatuses(statuses)
|
2019-05-15 01:24:19 +02:00
|
|
|
}
|
|
|
|
|
2020-05-03 05:52:13 +02:00
|
|
|
public func selectForProcessing(limit: Int? = nil, completion: @escaping SyncStatusesCompletionBlock) {
|
|
|
|
return syncStatusTable.selectForProcessing(limit: limit, completion: completion)
|
2019-05-15 18:52:56 +02:00
|
|
|
}
|
2019-12-16 19:50:13 +01:00
|
|
|
|
|
|
|
public func selectPendingCount(completion: @escaping DatabaseIntCompletionBlock) {
|
|
|
|
syncStatusTable.selectPendingCount(completion)
|
2019-05-27 19:03:12 +02:00
|
|
|
}
|
2019-12-16 19:50:13 +01:00
|
|
|
|
2020-01-03 02:21:18 +01:00
|
|
|
public func selectPendingReadStatusArticleIDs(completion: @escaping SyncStatusArticleIDsCompletionBlock) {
|
|
|
|
syncStatusTable.selectPendingReadStatusArticleIDs(completion: completion)
|
|
|
|
}
|
|
|
|
|
|
|
|
public func selectPendingStarredStatusArticleIDs(completion: @escaping SyncStatusArticleIDsCompletionBlock) {
|
|
|
|
syncStatusTable.selectPendingStarredStatusArticleIDs(completion: completion)
|
|
|
|
}
|
|
|
|
|
2020-04-28 02:21:49 +02:00
|
|
|
public func resetAllSelectedForProcessing(completion: DatabaseCompletionBlock? = nil) {
|
|
|
|
syncStatusTable.resetAllSelectedForProcessing(completion: completion)
|
|
|
|
}
|
|
|
|
|
2019-12-16 08:07:28 +01:00
|
|
|
public func resetSelectedForProcessing(_ articleIDs: [String], completion: DatabaseCompletionBlock? = nil) {
|
2019-12-15 01:14:55 +01:00
|
|
|
syncStatusTable.resetSelectedForProcessing(articleIDs, completion: completion)
|
2019-05-15 18:52:56 +02:00
|
|
|
}
|
|
|
|
|
2019-12-16 08:07:28 +01:00
|
|
|
public func deleteSelectedForProcessing(_ articleIDs: [String], completion: DatabaseCompletionBlock? = nil) {
|
2019-12-15 01:14:55 +01:00
|
|
|
syncStatusTable.deleteSelectedForProcessing(articleIDs, completion: completion)
|
2019-05-15 18:52:56 +02:00
|
|
|
}
|
2019-11-30 06:49:44 +01:00
|
|
|
|
|
|
|
// MARK: - Suspend and Resume (for iOS)
|
|
|
|
|
|
|
|
/// Close the database and stop running database calls.
|
|
|
|
/// Any pending calls will complete first.
|
|
|
|
public func suspend() {
|
|
|
|
queue.suspend()
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Open the database and allow for running database calls again.
|
|
|
|
public func resume() {
|
|
|
|
queue.resume()
|
|
|
|
}
|
2019-05-15 01:24:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// MARK: - Private
|
|
|
|
|
|
|
|
private extension SyncDatabase {
|
|
|
|
|
|
|
|
static let tableCreationStatements = """
|
|
|
|
CREATE TABLE if not EXISTS syncStatus (articleID TEXT NOT NULL, key TEXT NOT NULL, flag BOOL NOT NULL DEFAULT 0, selected BOOL NOT NULL DEFAULT 0, PRIMARY KEY (articleID, key));
|
|
|
|
"""
|
|
|
|
}
|