2019-05-14 18:24:19 -05:00
|
|
|
//
|
|
|
|
// SyncDatabase.swift
|
|
|
|
// NetNewsWire
|
|
|
|
//
|
|
|
|
// Created by Maurice Parker on 5/14/19.
|
|
|
|
// Copyright © 2019 Ranchero Software. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
import RSDatabase
|
|
|
|
|
|
|
|
public final class SyncDatabase {
|
|
|
|
|
|
|
|
private let syncStatusTable: SyncStatusTable
|
|
|
|
|
|
|
|
public init(databaseFilePath: String) {
|
|
|
|
|
|
|
|
let queue = RSDatabaseQueue(filepath: databaseFilePath, excludeFromBackup: false)
|
|
|
|
self.syncStatusTable = SyncStatusTable(queue: queue)
|
|
|
|
|
|
|
|
queue.createTables(usingStatements: SyncDatabase.tableCreationStatements)
|
|
|
|
queue.vacuumIfNeeded()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public func insertStatuses(_ statuses: [SyncStatus]) {
|
|
|
|
syncStatusTable.insertStatuses(statuses)
|
|
|
|
}
|
|
|
|
|
2019-05-15 11:52:56 -05:00
|
|
|
public func selectForProcessing() -> [SyncStatus] {
|
|
|
|
return syncStatusTable.selectForProcessing()
|
|
|
|
}
|
|
|
|
|
2019-05-27 12:03:12 -05:00
|
|
|
public func selectPendingCount() -> Int {
|
|
|
|
return syncStatusTable.selectPendingCount()
|
|
|
|
}
|
|
|
|
|
2019-05-15 11:52:56 -05:00
|
|
|
public func resetSelectedForProcessing(_ articleIDs: [String]) {
|
|
|
|
syncStatusTable.resetSelectedForProcessing(articleIDs)
|
|
|
|
}
|
|
|
|
|
|
|
|
public func deleteSelectedForProcessing(_ articleIDs: [String]) {
|
|
|
|
syncStatusTable.deleteSelectedForProcessing(articleIDs)
|
|
|
|
}
|
|
|
|
|
2019-05-14 18:24:19 -05: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));
|
|
|
|
"""
|
|
|
|
}
|