]> git.wh0rd.org Git - tt-rss.git/commitdiff
implement plugin API version compatibility check
authorAndrew Dolgov <fox@fakecake.org>
Fri, 19 Apr 2013 13:26:22 +0000 (17:26 +0400)
committerAndrew Dolgov <fox@fakecake.org>
Fri, 19 Apr 2013 13:26:22 +0000 (17:26 +0400)
classes/plugin.php
classes/pluginhost.php

index 60f127633428021ebaf77fdf9847d32c698d2223..8fbacf363a82d65de5da8da8be0c73e344a578f9 100644 (file)
@@ -3,6 +3,8 @@ class Plugin {
        private $dbh;
        private $host;
 
+       const API_VERSION_COMPAT = 1;
+
        function init($host) {
                $this->dbh = $host->get_dbh();
                $this->host = $host;
@@ -20,5 +22,9 @@ class Plugin {
        function get_prefs_js() {
                return "";
        }
+
+       function api_version() {
+               return Plugin::API_VERSION_COMPAT;
+       }
 }
 ?>
index d51f70214a7a93d6cca0396f34c9b15338b2f995..dc75e31fb30b72f285a23e9302d4c46a7302bbcc 100644 (file)
@@ -13,6 +13,8 @@ class PluginHost {
        private $last_registered;
        private static $instance;
 
+       const API_VERSION = 1;
+
        const HOOK_ARTICLE_BUTTON = 1;
        const HOOK_ARTICLE_FILTER = 2;
        const HOOK_PREFS_TAB = 3;
@@ -137,6 +139,13 @@ class PluginHost {
                                if (class_exists($class) && is_subclass_of($class, "Plugin")) {
                                        $plugin = new $class($this);
 
+                                       $plugin_api = $plugin->api_version();
+
+                                       if ($plugin_api < PluginHost::API_VERSION) {
+                                               user_error("Plugin $class is not compatible with current API version (need: " . PluginHost::API_VERSION . ", got: $plugin_api)", E_USER_WARNING);
+                                               continue;
+                                       }
+
                                        $this->last_registered = $class;
 
                                        switch ($kind) {