forked from jamesnovak/PortalRecordsMoverConsole
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Program.cs
74 lines (61 loc) · 2.83 KB
/
Program.cs
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
72
73
74
using System;
using System.IO;
using System.Text;
using PortalRecordsMover.AppCode;
using System.Threading.Tasks;
// Port of the Portal Records Mover http://XrmToolbox.com plugin by Tanguy Touzard
// Original project: PortalRecordsMover: https://github.com/MscrmTools/PortalRecordsMover/
// This project is console application version of the PortalRecordsMover plugin included with the XrmToolbox.
namespace PortalRecordsMover
{
public class PortalMover
{
public const string DT_FORMAT = "yyyy-MM-dd HH.mm.ss";
static StringBuilder _logger = new StringBuilder();
public static StringBuilder Logger { get => _logger; }
static void Main(string[] args) {
// process the settings from file and then override with command line args, if any
ReportProgress("Initializing the ExportSettings");
ExportSettings settings = ExportSettings.InitializeSettings(args);
if (!string.IsNullOrEmpty(settings.Config.ExportFilename)) {
ReportProgress($"Beginning the export - SourceEnvironment: {settings.Config.SourceEnvironment}, ExportFilename:{settings.Config.ExportFilename}");
var exporter = new Exporter(settings);
exporter.Export();
}
// if ImportFile is not null, then perform the import
if (!string.IsNullOrEmpty(settings.Config.ImportFilename)) {
ReportProgress($"Beginning the Import - TargetEnvironment: {settings.Config.TargetEnvironment}, ImportFilename:{settings.Config.ImportFilename}");
var importer = new Importer(settings);
importer.Import();
}
// output the log file
SaveLogFile().Wait();
Console.ReadKey();
}
/// <summary>
/// Save the log!
/// </summary>
/// <returns></returns>
static async Task SaveLogFile()
{
var now = DateTime.Now.ToString(DT_FORMAT);
var logFile = $"PortalRecordsMoverApp {now}.log";
byte[] encodedText = Encoding.Unicode.GetBytes(Logger.ToString());
using (FileStream sourceStream = new FileStream(logFile,FileMode.Append, FileAccess.Write, FileShare.None, bufferSize: 4096, useAsync: true)) {
await sourceStream.WriteAsync(encodedText, 0, encodedText.Length);
};
ReportProgress($"Logfile saved to {logFile}");
}
/// <summary>
/// Helper method to track logging for all of the processes
/// </summary>
/// <param name="message"></param>
public static void ReportProgress(string message)
{
var now = DateTime.Now.ToString(DT_FORMAT);
message = $"{now}: {message}";
Logger.AppendLine(message);
Console.WriteLine(message);
}
}
}