PowerToys/Wox.Core/Plugin/PluginConfig.cs

103 lines
3.6 KiB
C#
Raw Normal View History

2016-01-07 05:34:42 +08:00
using System;
using System.Collections.Generic;
using System.Linq;
2014-12-26 19:36:43 +08:00
using System.IO;
using System.Threading.Tasks;
2014-12-26 19:36:43 +08:00
using Newtonsoft.Json;
2015-11-09 09:32:33 +08:00
using Wox.Infrastructure.Exception;
2014-12-26 19:36:43 +08:00
using Wox.Infrastructure.Logger;
using Wox.Plugin;
namespace Wox.Core.Plugin
{
internal abstract class PluginConfig
{
private const string PluginConfigName = "plugin.json";
private static readonly List<PluginMetadata> PluginMetadatas = new List<PluginMetadata>();
2014-12-26 19:36:43 +08:00
/// <summary>
/// Parse plugin metadata in giving directories
/// </summary>
/// <param name="pluginDirectories"></param>
/// <returns></returns>
public static List<PluginMetadata> Parse(string[] pluginDirectories)
2014-12-26 19:36:43 +08:00
{
PluginMetadatas.Clear();
var directories = pluginDirectories.SelectMany(Directory.GetDirectories);
ParsePluginConfigs(directories);
return PluginMetadatas;
2014-12-26 19:36:43 +08:00
}
private static void ParsePluginConfigs(IEnumerable<string> directories)
2014-12-26 19:36:43 +08:00
{
// todo use linq when diable plugin is implmented since parallel.foreach + list is not thread saft
foreach (var directory in directories)
2014-12-26 19:36:43 +08:00
{
if (File.Exists(Path.Combine(directory, "NeedDelete.txt")))
2014-12-26 19:36:43 +08:00
{
2014-12-29 23:02:50 +08:00
try
{
Directory.Delete(directory, true);
}
2016-01-07 05:34:42 +08:00
catch (Exception e)
2014-12-29 23:02:50 +08:00
{
Log.Fatal(e);
2014-12-29 23:02:50 +08:00
}
2014-12-26 19:36:43 +08:00
}
else
2014-12-26 19:36:43 +08:00
{
PluginMetadata metadata = GetPluginMetadata(directory);
if (metadata != null)
{
PluginMetadatas.Add(metadata);
}
2014-12-26 19:36:43 +08:00
}
}
2014-12-26 19:36:43 +08:00
}
private static PluginMetadata GetPluginMetadata(string pluginDirectory)
{
string configPath = Path.Combine(pluginDirectory, PluginConfigName);
2014-12-26 19:36:43 +08:00
if (!File.Exists(configPath))
{
Log.Warn($"parse plugin {configPath} failed: didn't find config file.");
2014-12-26 19:36:43 +08:00
return null;
}
PluginMetadata metadata;
try
{
metadata = JsonConvert.DeserializeObject<PluginMetadata>(File.ReadAllText(configPath));
metadata.PluginDirectory = pluginDirectory;
// for plugins which doesn't has ActionKeywords key
metadata.ActionKeywords = metadata.ActionKeywords ?? new List<string> { metadata.ActionKeyword };
// for plugin still use old ActionKeyword
metadata.ActionKeyword = metadata.ActionKeywords?[0];
2014-12-26 19:36:43 +08:00
}
2016-01-07 05:34:42 +08:00
catch (Exception e)
2014-12-26 19:36:43 +08:00
{
string msg = $"Parse plugin config {configPath} failed: json format is not valid";
Log.Error(new WoxException(msg));
2014-12-26 19:36:43 +08:00
return null;
}
if (!AllowedLanguage.IsAllowed(metadata.Language))
{
string msg = $"Parse plugin config {configPath} failed: invalid language {metadata.Language}";
Log.Error(new WoxException(msg));
2014-12-26 19:36:43 +08:00
return null;
}
if (!File.Exists(metadata.ExecuteFilePath))
{
string msg = $"Parse plugin config {configPath} failed: ExecuteFile {metadata.ExecuteFilePath} didn't exist";
Log.Error(new WoxException(msg));
2014-12-26 19:36:43 +08:00
return null;
}
return metadata;
}
}
}