blob: f6662a9751d7ec0159cf4390c3c51fb9f93cf0a8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
using Microsoft.EntityFrameworkCore;
using SixLabors.ImageSharp;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Timeline.Entities;
using Timeline.Models;
using Timeline.Services.Data;
namespace Timeline.Services.DatabaseManagement
{
public class TimelinePostContentToDataMigration : IDatabaseCustomMigration
{
private readonly IDataManager _dataManager;
public TimelinePostContentToDataMigration(IDataManager dataManager)
{
_dataManager = dataManager;
}
public string GetName() => "TimelinePostContentToData";
public async Task ExecuteAsync(DatabaseContext database, CancellationToken cancellationToken)
{
#pragma warning disable CS0618
var postEntities = await database.TimelinePosts.ToListAsync(cancellationToken);
foreach (var postEntity in postEntities)
{
if (postEntity.Content is null)
{
postEntity.Deleted = true;
}
else
{
if (postEntity.ContentType == "text")
{
var tag = await _dataManager.RetainEntryAsync(Encoding.UTF8.GetBytes(postEntity.Content), cancellationToken);
database.TimelinePostData.Add(new TimelinePostDataEntity
{
DataTag = tag,
Kind = MimeTypes.TextPlain,
Index = 0,
PostId = postEntity.Id,
LastUpdated = postEntity.LastUpdated
});
}
else
{
var data = await _dataManager.GetEntryAndCheck(postEntity.Content, Resource.TimelinePostContentToDataMigrationImageNoData, cancellationToken);
var format = Image.DetectFormat(data);
database.TimelinePostData.Add(new TimelinePostDataEntity
{
DataTag = postEntity.Content,
Kind = format.DefaultMimeType,
Index = 0,
PostId = postEntity.Id,
LastUpdated = postEntity.LastUpdated
});
}
}
postEntity.Content = null;
postEntity.ContentType = null;
postEntity.ExtraContent = null;
}
await database.SaveChangesAsync(cancellationToken);
#pragma warning restore CS0618
}
}
}
|