Generate docker file table

This commit is contained in:
nicolas.dorier
2019-01-28 18:36:30 +09:00
parent 881975a0f5
commit 66c20cfa39
5 changed files with 149 additions and 19 deletions

View File

@@ -14,23 +14,30 @@ namespace DockerFileBuildHelper
{
class Program
{
class Options
{
public string BuildAllScriptOutput { get; set; }
public string READMEOutput { get; set; }
}
static int Main(string[] args)
{
string outputFile = null;
var opts = new Options();
for (int i = 0; i < args.Length; i++)
{
if (args[i] == "-o")
outputFile = args[i + 1];
opts.BuildAllScriptOutput = args[i + 1];
if (args[i] == "-omd")
opts.READMEOutput = args[i + 1];
}
return new Program().Run(outputFile) ? 0 : 1;
return new Program().Run(opts) ? 0 : 1;
}
private bool Run(string outputFile)
private bool Run(Options options)
{
var fragmentDirectory = Path.GetFullPath(Path.Combine(FindRoot("contrib"), "..", "docker-compose-generator", "docker-fragments"));
List<Task<bool>> downloading = new List<Task<bool>>();
List<DockerInfo> dockerInfos = new List<DockerInfo>();
foreach(var image in new[]
foreach (var image in new[]
{
Image.Parse("btcpayserver/docker-compose-generator"),
Image.Parse("btcpayserver/docker-compose-builder:1.23.2"),
@@ -77,7 +84,7 @@ namespace DockerFileBuildHelper
mightBeUnavailable = true;
}
if (info.DockerFilePathARM32v7 != null)
{
{
var dockerFile = DockerFile.Parse(info.DockerFilePathARM32v7);
builder.AppendLine($"# {info.GetGithubLinkOf(dockerFile.DockerFullPath)}");
builder.AppendLine($"[[ \"$(uname -m)\" == \"armv7l\" ]] && DOCKERFILE=\"{dockerFile.DockerFullPath}\"");
@@ -88,7 +95,7 @@ namespace DockerFileBuildHelper
builder.AppendLine($"# {info.GetGithubLinkOf(dockerFile.DockerFullPath)}");
builder.AppendLine($"[[ \"$(uname -m)\" == \"aarch64\" ]] && DOCKERFILE=\"{dockerFile.DockerFullPath}\"");
}
if(mightBeUnavailable)
if (mightBeUnavailable)
{
builder.AppendLine($"if [[ \"$DOCKERFILE\" ]]; then");
builder.Indent++;
@@ -109,12 +116,83 @@ namespace DockerFileBuildHelper
builder.AppendLine();
}
var script = builder.ToString().Replace("\r\n", "\n");
if (string.IsNullOrEmpty(outputFile))
outputFile = "build-all.sh";
File.WriteAllText(outputFile, script);
Console.WriteLine($"Generated file \"{Path.GetFullPath(outputFile)}\"");
if (string.IsNullOrEmpty(options.BuildAllScriptOutput))
options.BuildAllScriptOutput = "build-all.sh";
File.WriteAllText(options.BuildAllScriptOutput, script);
Console.WriteLine($"Generated file \"{Path.GetFullPath(options.BuildAllScriptOutput)}\"");
if (!string.IsNullOrEmpty(options.READMEOutput))
{
var readme = File.ReadAllText(options.READMEOutput);
var start = readme.IndexOf("| Source |");
var end = start;
for (; end < readme.Length; end++)
{
if (readme[end] == '\r' && readme[end + 1] == '\n' && readme[end + 2] != '|')
{
end += 2;
break;
}
if (readme[end] == '\n' && readme[end + 1] != '|')
{
end += 1;
break;
}
}
StringBuilder tb = new StringBuilder();
tb.Append(readme.Substring(0, start));
tb.AppendLine("| Source | Image | Version | x64 | arm32v7 | links |");
tb.AppendLine("|---|---|---|:-:|:-:|:-:|");
dockerInfos = dockerInfos.OrderBy(i => i.Image.Source).ToList();
// Make sure bitcoin appears before shitcoin
PushToEnd(2, dockerInfos);
PushToEnd(2, dockerInfos);
PushToEnd(7, dockerInfos);
PushToEnd(7, dockerInfos);
foreach (var image in dockerInfos)
{
string source = "*";
if (image.Image.Source != null)
{
source = Path.GetFileName(image.Image.Source);
}
tb.Append($"| {source} | {image.Image.ToString(false)} | {image.Image.Tag} |");
if (!string.IsNullOrEmpty(image.DockerFilePath))
{
tb.Append($" [✔️]({image.GetGithubLinkOf(image.DockerFilePath)}) |");
}
else
{
tb.Append($" ️❌ |");
}
if (!string.IsNullOrEmpty(image.DockerFilePathARM32v7))
{
tb.Append($" [✔️]({image.GetGithubLinkOf(image.DockerFilePathARM32v7)}) |");
}
else
{
tb.Append($" ️❌ |");
}
tb.AppendLine($" [Github]({image.GitLink}) - [DockerHub]({image.DockerHubLink}) |");
}
tb.Append(readme.Substring(end));
File.WriteAllText(options.READMEOutput, tb.ToString());
}
return true;
}
private void PushToEnd(int index, List<DockerInfo> dockerInfos)
{
var temp = dockerInfos[index];
dockerInfos.RemoveAt(index);
dockerInfos.Add(temp);
}
HttpClient client = new HttpClient();
private async Task<bool> CheckLink(DockerInfo info, string path)
{
@@ -122,7 +200,7 @@ namespace DockerFileBuildHelper
return true;
var link = info.GetGithubLinkOf(path);
var resp = await client.GetAsync(link);
if(!resp.IsSuccessStatusCode)
if (!resp.IsSuccessStatusCode)
{
Console.WriteLine($"\tBroken link detected for image {info.Image} ({link})");
return false;
@@ -145,6 +223,7 @@ namespace DockerFileBuildHelper
if (imageStr == null)
continue;
var image = Image.Parse(imageStr.ToString());
image.Source = file;
yield return image;
}
}
@@ -154,7 +233,7 @@ namespace DockerFileBuildHelper
DockerInfo dockerInfo = new DockerInfo();
var name = $"{image.User}/{image.Name}";
bool firstTry = true;
retry:
retry:
switch (name)
{
case "btglnd":