PowerToys/Wox/PluginLoader/BasePluginLoader.cs

126 lines
4.2 KiB
C#
Raw Normal View History

2013-12-20 19:38:10 +08:00
using System;
using System.Collections.Generic;
using System.IO;
2014-01-03 18:16:05 +08:00
using System.Linq;
using System.Reflection;
2014-01-12 21:02:39 +08:00
using System.Windows.Forms;
using Newtonsoft.Json;
2014-01-29 18:33:24 +08:00
using Wox.Helper;
using Wox.Plugin;
using Wox.Plugin.SystemPlugins;
2013-12-20 19:38:10 +08:00
2014-01-29 18:33:24 +08:00
namespace Wox.PluginLoader
2013-12-20 19:38:10 +08:00
{
public abstract class BasePluginLoader
{
private static string PluginPath = Path.Combine(Path.GetDirectoryName(System.Windows.Forms.Application.ExecutablePath), "Plugins");
private static string PluginConfigName = "plugin.json";
2013-12-20 19:38:10 +08:00
protected static List<PluginMetadata> pluginMetadatas = new List<PluginMetadata>();
public abstract List<PluginPair> LoadPlugin();
2013-12-20 19:38:10 +08:00
2014-01-12 18:15:30 +08:00
public static void ParsePluginsConfig()
2013-12-20 19:38:10 +08:00
{
2014-01-12 18:15:30 +08:00
pluginMetadatas.Clear();
2014-01-03 18:16:05 +08:00
ParseSystemPlugins();
ParseThirdPartyPlugins();
if (Plugins.DebuggerMode != null)
{
PluginMetadata metadata = GetMetadataFromJson(Plugins.DebuggerMode);
if (metadata != null) pluginMetadatas.Add(metadata);
}
2013-12-20 19:38:10 +08:00
}
2014-01-03 18:16:05 +08:00
private static void ParseSystemPlugins()
{
2014-01-03 23:52:36 +08:00
PluginMetadata metadata = new PluginMetadata();
metadata.Name = "System Plugins";
metadata.Author = "System";
metadata.Description = "system plugins collection";
metadata.Language = AllowedLanguage.CSharp;
metadata.Version = "1.0";
metadata.PluginType = PluginType.System;
metadata.ActionKeyword = "*";
metadata.ExecuteFileName = "Wox.Plugin.SystemPlugins.dll";
metadata.PluginDirecotry = Path.GetDirectoryName(System.Windows.Forms.Application.ExecutablePath);
2014-01-03 23:52:36 +08:00
pluginMetadatas.Add(metadata);
2014-01-03 18:16:05 +08:00
}
private static void ParseThirdPartyPlugins()
2014-01-29 18:33:24 +08:00
{
if (!Directory.Exists(PluginPath))
Directory.CreateDirectory(PluginPath);
2013-12-20 19:38:10 +08:00
string[] directories = Directory.GetDirectories(PluginPath);
foreach (string directory in directories)
{
2014-03-11 23:54:37 +08:00
if (File.Exists((Path.Combine(directory, "NeedDelete.txt"))))
{
Directory.Delete(directory,true);
continue;
}
PluginMetadata metadata = GetMetadataFromJson(directory);
2013-12-20 19:38:10 +08:00
if (metadata != null) pluginMetadatas.Add(metadata);
}
}
private static PluginMetadata GetMetadataFromJson(string pluginDirectory)
2013-12-20 19:38:10 +08:00
{
string configPath = Path.Combine(pluginDirectory, PluginConfigName);
PluginMetadata metadata;
if (!File.Exists(configPath))
2013-12-20 19:38:10 +08:00
{
2014-03-23 17:43:46 +08:00
Log.Warn(string.Format("parse plugin {0} failed: didn't find config file.", configPath));
2013-12-20 19:38:10 +08:00
return null;
}
try
{
metadata = JsonConvert.DeserializeObject<PluginMetadata>(File.ReadAllText(configPath));
2014-01-03 18:16:05 +08:00
metadata.PluginType = PluginType.ThirdParty;
metadata.PluginDirecotry = pluginDirectory;
}
catch (Exception)
{
string error = string.Format("Parse plugin config {0} failed: json format is not valid", configPath);
2014-03-23 17:43:46 +08:00
Log.Warn(error);
2013-12-23 19:21:51 +08:00
#if (DEBUG)
{
throw new WoxException(error);
2013-12-20 19:38:10 +08:00
}
#endif
return null;
}
2013-12-20 19:38:10 +08:00
if (!AllowedLanguage.IsAllowed(metadata.Language))
{
string error = string.Format("Parse plugin config {0} failed: invalid language {1}", configPath,
metadata.Language);
2014-03-23 17:43:46 +08:00
Log.Warn(error);
#if (DEBUG)
{
throw new WoxException(error);
}
#endif
return null;
2013-12-20 19:38:10 +08:00
}
if (!File.Exists(metadata.ExecuteFilePath))
2013-12-20 19:38:10 +08:00
{
string error = string.Format("Parse plugin config {0} failed: ExecuteFile {1} didn't exist", configPath,
metadata.ExecuteFilePath);
2014-03-23 17:43:46 +08:00
Log.Warn(error);
2013-12-23 19:21:51 +08:00
#if (DEBUG)
{
throw new WoxException(error);
2013-12-23 19:21:51 +08:00
}
#endif
2013-12-20 19:38:10 +08:00
return null;
}
return metadata;
}
2013-12-20 19:38:10 +08:00
}
}