2016-01-07 05:34:42 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2016-05-06 04:15:13 +08:00
|
|
|
|
using System.Linq;
|
2014-12-26 19:36:43 +08:00
|
|
|
|
using System.IO;
|
2016-05-06 04:15:13 +08:00
|
|
|
|
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
|
|
|
|
|
{
|
2016-05-06 04:15:13 +08:00
|
|
|
|
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>
|
2016-04-27 09:15:53 +08:00
|
|
|
|
public static List<PluginMetadata> Parse(string[] pluginDirectories)
|
2014-12-26 19:36:43 +08:00
|
|
|
|
{
|
2016-05-06 04:15:13 +08:00
|
|
|
|
PluginMetadatas.Clear();
|
|
|
|
|
var directories = pluginDirectories.SelectMany(Directory.GetDirectories);
|
|
|
|
|
ParsePluginConfigs(directories);
|
|
|
|
|
return PluginMetadatas;
|
2014-12-26 19:36:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
2016-05-06 04:15:13 +08:00
|
|
|
|
private static void ParsePluginConfigs(IEnumerable<string> directories)
|
2014-12-26 19:36:43 +08:00
|
|
|
|
{
|
2016-05-06 04:15:13 +08:00
|
|
|
|
Parallel.ForEach(directories, directory =>
|
2014-12-26 19:36:43 +08:00
|
|
|
|
{
|
2016-05-06 04:15:13 +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
|
|
|
|
{
|
2015-11-08 01:32:58 +08:00
|
|
|
|
Log.Fatal(e);
|
2014-12-29 23:02:50 +08:00
|
|
|
|
}
|
2014-12-26 19:36:43 +08:00
|
|
|
|
}
|
2016-05-06 04:15:13 +08:00
|
|
|
|
else
|
2014-12-26 19:36:43 +08:00
|
|
|
|
{
|
2016-05-06 04:15:13 +08:00
|
|
|
|
PluginMetadata metadata = GetPluginMetadata(directory);
|
|
|
|
|
if (metadata != null)
|
|
|
|
|
{
|
|
|
|
|
PluginMetadatas.Add(metadata);
|
|
|
|
|
}
|
2014-12-26 19:36:43 +08:00
|
|
|
|
}
|
2016-05-06 04:15:13 +08:00
|
|
|
|
});
|
2014-12-26 19:36:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static PluginMetadata GetPluginMetadata(string pluginDirectory)
|
|
|
|
|
{
|
2016-05-06 04:15:13 +08:00
|
|
|
|
string configPath = Path.Combine(pluginDirectory, PluginConfigName);
|
2014-12-26 19:36:43 +08:00
|
|
|
|
if (!File.Exists(configPath))
|
|
|
|
|
{
|
2015-11-08 01:32:58 +08:00
|
|
|
|
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;
|
2015-11-05 06:49:40 +08:00
|
|
|
|
// for plugins which doesn't has ActionKeywords key
|
2016-03-25 09:22:24 +08:00
|
|
|
|
metadata.ActionKeywords = metadata.ActionKeywords ?? new List<string> { metadata.ActionKeyword };
|
2015-11-05 06:49:40 +08:00
|
|
|
|
// 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
|
|
|
|
{
|
2015-11-08 01:32:58 +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))
|
|
|
|
|
{
|
2015-11-08 01:32:58 +08:00
|
|
|
|
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))
|
|
|
|
|
{
|
2015-11-08 01:32:58 +08:00
|
|
|
|
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;
|
|
|
|
|
}
|
|
|
|
|
}
|
2014-12-29 22:09:54 +08:00
|
|
|
|
}
|