blob: de2e21839344aecf2ffd78507b9f66d17fe650e0 (
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
|
using System.Text;
using System.Threading.Tasks;
using Microsoft.EntityFrameworkCore;
using SixLabors.ImageSharp;
using Timeline.Entities;
using Timeline.Models;
namespace Timeline.Services.Migration
{
public class TimelinePostContentToDataMigration : ICustomMigration
{
private readonly IDataManager _dataManager;
public TimelinePostContentToDataMigration(IDataManager dataManager)
{
_dataManager = dataManager;
}
public string GetName() => "TimelinePostContentToData";
public async Task Execute(DatabaseContext database)
{
#pragma warning disable CS0618
var postEntities = await database.TimelinePosts.ToListAsync();
foreach (var postEntity in postEntities)
{
if (postEntity.Content is null)
{
postEntity.Deleted = true;
}
else
{
if (postEntity.ContentType == "text")
{
var tag = await _dataManager.RetainEntry(Encoding.UTF8.GetBytes(postEntity.Content), false);
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, "Old image content does not have corresponding data with the tag.");
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();
#pragma warning restore CS0618
}
}
}
|