Update_7_31.cs 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. using Comal.Classes;
  2. using InABox.Core;
  3. using InABox.Database;
  4. namespace PRS.Shared
  5. {
  6. public class Update_7_31 : DatabaseUpdateScript
  7. {
  8. public override VersionNumber Version => new VersionNumber(7, 31);
  9. private static void Migrate<T>()
  10. where T : Entity, IPersistent, IPostable, new()
  11. {
  12. List<T> items;
  13. do
  14. {
  15. items = DbFactory.Provider.Query<T>(
  16. new Filter<T>(x => x.PostedStatus).IsEqualTo(null),
  17. new Columns<T>(x => x.ID).Add(x => x.PostedStatus), top: 1000).ToObjects<T>().ToList();
  18. foreach (var item in items)
  19. {
  20. item.PostedStatus = PostedStatus.NeverPosted;
  21. item.OriginalValues.TryAdd("PostedStatus", null);
  22. }
  23. DbFactory.Provider.Save(items);
  24. Logger.Send(LogType.Information, "", $"{items.Count} {typeof(T).Name}s processed");
  25. } while (items.Count > 0);
  26. }
  27. public override bool Update()
  28. {
  29. Migrate<Bill>();
  30. Migrate<Invoice>();
  31. Migrate<PurchaseOrder>();
  32. Migrate<TimeSheet>();
  33. return true;
  34. }
  35. }
  36. }