enhancement to check version compatibility

This commit is contained in:
Shaun Walker 2019-10-26 13:51:24 -04:00
parent e25bbe2e24
commit 72c7f4abb0

View File

@ -3,6 +3,9 @@ using System.IO;
using System.IO.Compression; using System.IO.Compression;
using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Hosting;
using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.Hosting;
using System.Xml;
using Oqtane.Shared;
using System;
namespace Oqtane.Infrastructure namespace Oqtane.Infrastructure
{ {
@ -32,38 +35,65 @@ namespace Oqtane.Infrastructure
Directory.CreateDirectory(folder); Directory.CreateDirectory(folder);
} }
// iterate through theme packages // iterate through packages
foreach (string packagename in Directory.GetFiles(folder, "*.nupkg")) foreach (string packagename in Directory.GetFiles(folder, "*.nupkg"))
{ {
string name = Path.GetFileNameWithoutExtension(packagename); string name = Path.GetFileNameWithoutExtension(packagename);
string[] segments = name.Split('.'); string[] segments = name.Split('.');
name = string.Join('.', segments, 0, segments.Length - 3); name = string.Join('.', segments, 0, segments.Length - 3);
// iterate through files and deploy to appropriate locations // iterate through files
using (ZipArchive archive = ZipFile.OpenRead(packagename)) using (ZipArchive archive = ZipFile.OpenRead(packagename))
{ {
string frameworkversion = "";
// locate nuspec
foreach (ZipArchiveEntry entry in archive.Entries) foreach (ZipArchiveEntry entry in archive.Entries)
{ {
string filename = Path.GetFileName(entry.FullName); if (entry.FullName.ToLower().EndsWith(".nuspec"))
switch (Path.GetExtension(filename).ToLower())
{ {
case ".dll": // open nuspec
entry.ExtractToFile(Path.Combine(binfolder, filename), true); XmlTextReader reader = new XmlTextReader(entry.Open());
break; reader.Namespaces = false; // remove namespace
case ".png": XmlDocument doc = new XmlDocument();
case ".jpg": doc.Load(reader);
case ".jpeg": // get framework dependency
case ".gif": XmlNode node = doc.SelectSingleNode("/package/metadata/dependencies/dependency[@id='Oqtane.Framework']");
case ".svg": if (node != null)
case ".js": {
case ".css": frameworkversion = node.Attributes["version"].Value;
filename = folder + "\\" + entry.FullName.Replace("wwwroot", name).Replace("/", "\\"); }
if (!Directory.Exists(Path.GetDirectoryName(filename))) reader.Close();
{ }
Directory.CreateDirectory(Path.GetDirectoryName(filename)); }
}
entry.ExtractToFile(filename, true); // if compatible with framework version
break; if (frameworkversion == "" || Version.Parse(Constants.Version).CompareTo(Version.Parse(frameworkversion)) >= 0)
{
// deploy to appropriate locations
foreach (ZipArchiveEntry entry in archive.Entries)
{
string filename = Path.GetFileName(entry.FullName);
switch (Path.GetExtension(filename).ToLower())
{
case ".pdb":
case ".dll":
entry.ExtractToFile(Path.Combine(binfolder, filename), true);
break;
case ".png":
case ".jpg":
case ".jpeg":
case ".gif":
case ".svg":
case ".js":
case ".css":
filename = folder + "\\" + entry.FullName.Replace("wwwroot", name).Replace("/", "\\");
if (!Directory.Exists(Path.GetDirectoryName(filename)))
{
Directory.CreateDirectory(Path.GetDirectoryName(filename));
}
entry.ExtractToFile(filename, true);
break;
}
} }
} }
} }