enhancement to check version compatibility
This commit is contained in:
parent
e25bbe2e24
commit
72c7f4abb0
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user