authenticate_user($link, "admin", null);
}
+ if ($_SESSION["uid"]) {
+ load_user_plugins($link, $_SESSION["uid"]);
+ }
+
$purge_intervals = array(
0 => __("Use default"),
-1 => __("Never purge"),
$class_file = strtolower(basename($class));
$file = dirname(__FILE__)."/../plugins/$class_file/$class_file.php";
- if (file_exists($file)) require_once $file;
+ if (!isset($this->plugins[$class])) {
+ if (file_exists($file)) require_once $file;
- if (class_exists($class) && is_subclass_of($class, "Plugin")) {
- $plugin = new $class($this);
+ if (class_exists($class) && is_subclass_of($class, "Plugin")) {
+ $plugin = new $class($this);
- $this->register_plugin($class, $plugin);
+ $this->register_plugin($class, $plugin);
+ }
}
}
}
+ function is_system($plugin) {
+ $about = $plugin->_about();
+
+ return @$about[3];
+ }
+
+ // only system plugins are allowed to modify routing
function add_handler($handler, $method, $sender) {
$handler = str_replace("-", "_", strtolower($handler));
$method = strtolower($method);
- if (!is_array($this->handlers[$handler])) {
- $this->handlers[$handler] = array();
- }
+ if ($this->is_system($sender)) {
+ if (!is_array($this->handlers[$handler])) {
+ $this->handlers[$handler] = array();
+ }
- $this->handlers[$handler][$method] = $sender;
+ $this->handlers[$handler][$method] = $sender;
+ }
}
function del_handler($handler, $method) {
$handler = str_replace("-", "_", strtolower($handler));
$method = strtolower($method);
- unset($this->handlers[$handler][$method]);
+ if ($this->is_system($sender)) {
+ unset($this->handlers[$handler][$method]);
+ }
}
function lookup_handler($handler, $method) {
return false;
}
+ // only system plugins are allowed to modify commands
function add_command($command, $description, $sender) {
$command = "-" . str_replace("-", "_", strtolower($command));
- $this->commands[$command] = array("description" => $description,
- "class" => $sender);
+ if ($this->is_system($sender)) {
+ $this->commands[$command] = array("description" => $description,
+ "class" => $sender);
+ }
}
function del_command($command) {
$command = "-" . strtolower($command);
- unset($this->commands[$command]);
+ if ($this->is_system($sender)) {
+ unset($this->commands[$command]);
+ }
}
function lookup_command($command) {
print "</div>"; #pane
global $pluginhost;
+
$pluginhost->run_hooks($pluginhost::HOOK_PREFS_TAB,
"hook_prefs_tab", "prefFeeds");
print "</div>"; #container
-
}
private function feedlist_init_cat($cat_id, $hidden = false) {
<label for='prefs_show_advanced'>" .
__("Show additional preferences") . "</label>";
+ print "</form>";
print '</div>'; # inner pane
print '</div>'; # border container
+
+ print "</div>"; #pane
+
+ print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__('Plugins')."\">";
+
+ print "<h2>".__("Plugins")."</h2>";
+
+ print_notice("You will need to reload Tiny Tiny RSS for plugin changes to take effect.");
+
+ print "<form dojoType=\"dijit.form.Form\" id=\"changePluginsForm\">";
+
+ print "<script type=\"dojo/method\" event=\"onSubmit\" args=\"evt\">
+ evt.preventDefault();
+ if (this.validate()) {
+ notify_progress('Saving data...', true);
+
+ new Ajax.Request('backend.php', {
+ parameters: dojo.objectToQuery(this.getValues()),
+ onComplete: function(transport) {
+ notify('');
+ if (confirm(__('Selected plugins have been enabled. Reload?'))) {
+ window.location.reload();
+ }
+ } });
+
+ }
+ </script>";
+
+ print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"op\" value=\"pref-prefs\">";
+ print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"method\" value=\"setplugins\">";
+
+ print "<table width='100%'>";
+
+ print "<tr><td colspan='4'><h3>".__("System plugins")."</h3></td></tr>";
+
+ print "<tr class=\"title\">
+ <td width=\"5%\"> </td>
+ <td width='10%'>".__('Plugin')."</td>
+ <td width=''>".__('Description')."</td>
+ <td width='5%'>".__('Version')."</td>
+ <td width='10%'>".__('Author')."</td></tr>";
+
+ $system_enabled = array_map("trim", explode(",", PLUGINS));
+ $user_enabled = array_map("trim", explode(",", get_pref($this->link, "_ENABLED_PLUGINS")));
+
+ $tmppluginhost = new PluginHost($link);
+ $tmppluginhost->load_all();
+
+ foreach ($tmppluginhost->get_plugins() as $name => $plugin) {
+ $about = $plugin->_about();
+
+ if ($about[3]) {
+ if (in_array($name, $system_enabled)) {
+ $checked = "checked='1'";
+ } else {
+ $checked = "";
+ }
+
+ print "<tr>";
+
+ print "<td align='center'><input disabled='1'
+ dojoType=\"dijit.form.CheckBox\" $checked
+ type=\"checkbox\"></td>";
+
+ print "<td>$name</td>";
+ print "<td>" . htmlspecialchars($about[1]) . "</td>";
+ print "<td>" . htmlspecialchars(sprintf("%.2f", $about[0])) . "</td>";
+ print "<td>" . htmlspecialchars($about[2]) . "</td>";
+
+ print "</tr>";
+
+ }
+ }
+
+ print "<tr><td colspan='4'><h3>".__("User plugins")."</h3></td></tr>";
+
+ print "<tr class=\"title\">
+ <td width=\"5%\"> </td>
+ <td width='10%'>".__('Plugin')."</td>
+ <td width=''>".__('Description')."</td>
+ <td width='5%'>".__('Version')."</td>
+ <td width='10%'>".__('Author')."</td></tr>";
+
+
+ foreach ($tmppluginhost->get_plugins() as $name => $plugin) {
+ $about = $plugin->_about();
+
+ if (!$about[3]) {
+
+ if (in_array($name, $system_enabled)) {
+ $checked = "checked='1'";
+ $disabled = "disabled='1'";
+ } else if (in_array($name, $user_enabled)) {
+ $checked = "checked='1'";
+ $disabled = "";
+ } else {
+ $checked = "";
+ $disabled = "";
+ }
+
+ print "<tr>";
+
+ print "<td align='center'><input id='FPCHK-$name' name='plugins[]' value='$name' onclick='toggleSelectRow2(this);'
+ dojoType=\"dijit.form.CheckBox\" $checked $disabled
+ type=\"checkbox\"></td>";
+
+ print "<td>$name</td>";
+ print "<td>" . htmlspecialchars($about[1]) . "</td>";
+ print "<td>" . htmlspecialchars(sprintf("%.2f", $about[0])) . "</td>";
+ print "<td>" . htmlspecialchars($about[2]) . "</td>";
+
+ print "</tr>";
+
+
+
+ }
+
+ }
+
+ print "</table>";
+
+ print "<p><button dojoType=\"dijit.form.Button\" type=\"submit\">".
+ __("Enable selected plugins")."</button></p>";
+
print "</form>";
print "</div>"; #pane
}
}
+
+ function setplugins() {
+ $plugins = join(",", $_REQUEST["plugins"]);
+
+ set_pref($this->link, "_ENABLED_PLUGINS", $plugins);
+ }
}
?>
<?php
define('EXPECTED_CONFIG_VERSION', 26);
- define('SCHEMA_VERSION', 99);
+ define('SCHEMA_VERSION', 100);
$fetch_last_error = false;
$pluginhost = false;
return true;
}
+ function load_user_plugins($link, $owner_uid) {
+ if ($owner_uid) {
+ $plugins = get_pref($link, "_ENABLED_PLUGINS", $owner_uid);
+
+ global $pluginhost;
+ $pluginhost->load($plugins);
+ }
+ }
+
function login_sequence($link, $login_form = 0) {
if (SINGLE_USER_MODE) {
- return authenticate_user($link, "admin", null);
+ authenticate_user($link, "admin", null);
+ load_user_plugins($link, $_SESSION["uid"]);
} else {
if (!$_SESSION["uid"] || !validate_session($link)) {
setcookie("ttrss_lang", $_SESSION["language"],
time() + SESSION_COOKIE_LIFETIME);
}
+
+ if ($_SESSION["uid"]) {
+ load_user_plugins($link, $_SESSION["uid"]);
+ }
}
}
function _about() {
return array(1.0,
"Digest mode for tt-rss (tablet friendly UI)",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
function _about() {
return array(1.0,
"Example plugin #1",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
function _about() {
return array(1.0,
"Example feed plugin",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
function _about() {
return array(1.0,
"Example routing plugin",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
function _about() {
return array(1.0,
"Support for linking tt-rss instances together and sharing popular feeds.",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
function _about() {
return array(1.0,
"Updates tt-rss installation to latest version.",
- "fox");
+ "fox",
+ true);
}
function __construct($host) {
no_cache_incantation();
header('Content-Type: text/html; charset=utf-8');
-
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
create table ttrss_version (schema_version int not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
-insert into ttrss_version values (99);
+insert into ttrss_version values (100);
create table ttrss_enclosures (id integer primary key auto_increment,
content_url text not null,
insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('AUTO_ASSIGN_LABELS', 1, 'true', 'Assign articles to labels automatically', 3);
+insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('_ENABLED_PLUGINS', 2, '', '', 1);
+
update ttrss_prefs set access_level = 1 where pref_name in ('ON_CATCHUP_SHOW_NEXT_FEED',
'SORT_HEADLINES_BY_FEED_DATE',
'VFEED_GROUP_BY_FEED',
create table ttrss_version (schema_version int not null);
-insert into ttrss_version values (99);
+insert into ttrss_version values (100);
create table ttrss_enclosures (id serial not null primary key,
content_url text not null,
insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('AUTO_ASSIGN_LABELS', 1, 'true', 'Assign articles to labels automatically', 3);
+insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('_ENABLED_PLUGINS', 2, '', '', 1);
+
update ttrss_prefs set access_level = 1 where pref_name in ('ON_CATCHUP_SHOW_NEXT_FEED',
'SORT_HEADLINES_BY_FEED_DATE',
'VFEED_GROUP_BY_FEED',
--- /dev/null
+begin;
+
+insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('_ENABLED_PLUGINS', 2, '', '', 1);
+
+update ttrss_version set schema_version = 100;
+
+commit;
--- /dev/null
+begin;
+
+insert into ttrss_prefs (pref_name,type_id,def_value,short_desc,section_id) values('_ENABLED_PLUGINS', 2, '', '', 1);
+
+update ttrss_version set schema_version = 100;
+
+commit;