ScheduleLog

final class ScheduleLog : Model, @unchecked Sendable

ScheduleLog records changes made to the events in the schedule, both by manual schedule updates (done by uploading a .ics file) and automatic schedule updates (where the server periodically queries Sched.com and applies changes automatically).

Properties

  • id

    The edit’s ID.

    Declaration

    Swift

    @ScheduleLog
    .ID var id: Int? { get set }
  • TRUE if this update was started automatically by the server. The server is currently set up to use Queues to query Sched.com once per hour and automatically apply any schedule updates to our db. FALSE if this was a manual update.

    Declaration

    Swift

    @ScheduleLog
    .Field var automaticUpdate: Bool { get set }
  • The total number of changes between the existing db and the new schedule information. May be > than the number of events modified as it may count a time and location change to a single event as 2 changes.

    Declaration

    Swift

    @ScheduleLog
    .Field var changeCount: Int { get set }
  • The JSON built from the EventUpdateDifferenceData, describing what changed. Will be nil if there was an error or if this was an automatic schedule update check and nothing changed.

    Declaration

    Swift

    @ScheduleLog
    .OptionalField var differenceData: Data? { get set }
  • If this was an automated schedule update and it failed, the failure reason.

    Declaration

    Swift

    @ScheduleLog
    .OptionalField var errorResult: String? { get set }
  • Timestamp of the model’s creation, set automatically.

    Declaration

    Swift

    @ScheduleLog
    .Timestamp var createdAt: Date? { get set }

Initialization

  • Declaration

    Swift

    init()
  • Initializes a new ScheduleLog for a successful update event.

    Declaration

    Swift

    init(diff: EventUpdateDifferenceData?, isAutomatic: Bool) throws

    Parameters

    diff

    The changes between the old and new schedule. Pass in NIL if there we no changes.

    isAutomatic

    TRUE if this update was done by the automatic Queues system.

  • Initializes a new ScheduleLog that reports an error indicating the schedule update did not complete.

    Declaration

    Swift

    init(error: Error) throws

    Parameters

    diff

    The changes between the old and new schedule..