diff --git a/CHANGELOG b/CHANGELOG index ef157f2..2137a7d 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -2,12 +2,17 @@ Header: Version-History 1.5: -1.5.6 %(mrbaseman, 3 Oct 2018)% +1.5.6 %(mrbaseman, 04 Nov 2018)% - support a legacy module !opf_simple_backend! to switch between basic and advanced backend view - avoid warning during installation when shipped as core module - php 7.2 fixes - add configurl button in the filter edit view, if applicable - allow multiple uses of the same field type in extra fields + - change the logic when backend filtering shall be offered + - correctly start incrementing position of installed filters + - fix bug in !opf_filter_get_data()! to find index correctly + - fix the logic for the backend filtering - module filtering not for inline filters + - print footer always when an exit() is issued in the backend tool 1.5.5 %(mrbaseman, 5 Sep 2018)% - fix uninstall.php in case MEDIA_DIRECTORY does not start with a slash diff --git a/docs/files/CHANGELOG-txt.html b/docs/files/CHANGELOG-txt.html index 49c6c43..e5b0863 100644 --- a/docs/files/CHANGELOG-txt.html +++ b/docs/files/CHANGELOG-txt.html @@ -11,7 +11,7 @@ -

Version-History

1.5

1.5.6 (mrbaseman, 3 Oct 2018)

  • support a legacy module opf_simple_backend to switch between basic and advanced backend view
  • avoid warning during installation when shipped as core module
  • php 7.2 fixes
  • add configurl button in the filter edit view, if applicable
  • allow multiple uses of the same field type in extra fields

1.5.5 (mrbaseman, 5 Sep 2018)

  • fix uninstall.php in case MEDIA_DIRECTORY does not start with a slash
  • fix ajax drag&drop which caused warning when issued after editing a filter
  • fix: hand over $OPF_TYPE_ASSIGNMENTS correctly to opf_revert_type_consts
  • only apply filter to backend when backend is selected - ALL is for frontend
  • correctly apply filters for special pages like searchresults with $pageid==0
  • fix css for checktree so that indentation works correctly
  • bugfix: converting filter types between plugin and inline failed
  • updated assignments of modules to the categories
  • minor update of the help pages

1.5.4 (mrbaseman, 19 Apr 2017)

  • fix for opf_db functions when previous queries have triggered already an error

1.5.3 (mrbaseman, 7 Apr 2017)

  • added fallbacks in <opf_insert_frontend_files> in case the template lacks head
  • improved debug messages for calls to <opf_is_registered>

1.5.2 (mrbaseman, 8 Mar 2017)

  • use OPF_TYPE constants when exporting filters

1.5.1 (mrbaseman, 25 Jan 2017)

  • allow arrays for $ref_name in opf_move_up_before
  • switch to colon separator in ajax helper
  • if $ref_name is ommited in opf_move_up_before, move $name up to the top
  • update patch detection for WBCE and module filter replacement
  • suppress warning when opf_move_up_before is called and $ref_name not found
  • store active/inactive state not only inside opf but also as WBCE Settings value
  • add additional hint upon an attempt to install a module filter as a plugin
  • trigger upgrade/install of module filters
  • in opf_filter_is_active take settings constants into account
  • immediately reflect toggle of the active/inactive state in the dashboard

1.5.0 (mrbaseman, 29 Sept 2016)

  • fetch $page_id from constant PAGE_ID for all cases
  • automagically initialize the global filter list
  • allow to sort filters via drag&drop
  • make exported filter human-readable
  • improve processing of formatting of documentation
  • when exporting a filter create a filter.php file
  • during export also insert placeholders introduced in version 1.4.4
  • allow to convert between inline filters and plugin filters
  • added opf_move_up_before to move filters up in the list during installation
  • search for pre-existing module filters during installation of opf
  • cleaned up backend_body.js
  • support backend filtering, provided that the class “Tool” exists and the settings have been converted to modules (this relies on developments in the WBCE 2.0-dev Branch, so you might see the checkbox for the backend, but unless the backend is implemented as modules, most probably no filters are going to be applied) In case you have created a filter which screws up the backend completely, add the following line to your global config.php of your WBCE installation
define('WB_OPF_BE_OFF', 'off');

The value doesn’t really matter, just if the constant is defined, there will no filter be applied to the backend and you have access to the dashboard again and you can fix the filters.

1.4

this version is a major re-engineering of the module with the goal to use it without PMF.  Special thanks to all who have tested and especially to NorHei for fruitful discussions and for providing additional testing ressources.

1.4.9 (mrbaseman, 23 Mar 2016)

  • change cachecontrols filter type to page(last)
  • realign code: wrap long lines and set tab width=4
  • make help browser work without javascript
  • fix css edit for filters that supply css files
  • provide export download link when javascript is disabled
  • allow to delete filters even without javascript
  • added French and Italian language support

1.4.8 (mrbaseman, 21 Feb 2016)

  • remove unused code part from add_filter to fix array conversion warnings
  • update plugin filters to use new placeholders introduced in 1.4.4 in order to pick up this change you have to remove the example filters before upgrading OpF
  • update documentation: added a section which explains the use of the constants and placeholders

1.4.7 (mrbaseman, 21 Feb 2016)

  • a couple of cosmetic bugfixes (correctly display Umlauts in filter list, replace German ss special char with ss in filter description, remove unused filter_id from template parsing, properly initialize TPL_EXTRA_FIELDS_BLOCK in edit_filter, fix for using global LANG inside method in WBCE)
  • security fix: check ftan for upload
  • several fixes for arrays as additional field (like in correct date example)
  • fix css edit for filters that provide css

1.4.6 (mrbaseman, 18 Feb 2016)

  • add module icon for WBCE 1.2
  • bugfix: do not allow moving up uppermost filter
  • switch from FTANs to IDKEYs in many places of the backend

1.4.5 (mrbaseman, 09 Feb 2016)

  • update documentation layout
  • include example plugins again
  • update patch check
  • merge in Stefek’s changes, thanks for your contribution and for your ideas you have contributed
  • automatically remove naturaldocs sources during install
  • various minor changes to make it working in upcoming wb-classic releases

1.4.4 (Stefek, 05 Feb 2016)

  • added the following tokens to apply instead of hardcoded pathes within OpF-Plugins:
{SYSVAR:WB_URL}   = will replace with the content of the Constant WB_URL
+

Version-History

1.5

1.5.6 (mrbaseman, 04 Nov 2018)

  • support a legacy module opf_simple_backend to switch between basic and advanced backend view
  • avoid warning during installation when shipped as core module
  • php 7.2 fixes
  • add configurl button in the filter edit view, if applicable
  • allow multiple uses of the same field type in extra fields
  • change the logic when backend filtering shall be offered
  • correctly start incrementing position of installed filters
  • fix bug in opf_filter_get_data() to find index correctly
  • fix the logic for the backend filtering - module filtering not for inline filters
  • print footer always when an exit() is issued in the backend tool

1.5.5 (mrbaseman, 5 Sep 2018)

  • fix uninstall.php in case MEDIA_DIRECTORY does not start with a slash
  • fix ajax drag&drop which caused warning when issued after editing a filter
  • fix: hand over $OPF_TYPE_ASSIGNMENTS correctly to opf_revert_type_consts
  • only apply filter to backend when backend is selected - ALL is for frontend
  • correctly apply filters for special pages like searchresults with $pageid==0
  • fix css for checktree so that indentation works correctly
  • bugfix: converting filter types between plugin and inline failed
  • updated assignments of modules to the categories
  • minor update of the help pages

1.5.4 (mrbaseman, 19 Apr 2017)

  • fix for opf_db functions when previous queries have triggered already an error

1.5.3 (mrbaseman, 7 Apr 2017)

  • added fallbacks in <opf_insert_frontend_files> in case the template lacks head
  • improved debug messages for calls to <opf_is_registered>

1.5.2 (mrbaseman, 8 Mar 2017)

  • use OPF_TYPE constants when exporting filters

1.5.1 (mrbaseman, 25 Jan 2017)

  • allow arrays for $ref_name in opf_move_up_before
  • switch to colon separator in ajax helper
  • if $ref_name is ommited in opf_move_up_before, move $name up to the top
  • update patch detection for WBCE and module filter replacement
  • suppress warning when opf_move_up_before is called and $ref_name not found
  • store active/inactive state not only inside opf but also as WBCE Settings value
  • add additional hint upon an attempt to install a module filter as a plugin
  • trigger upgrade/install of module filters
  • in opf_filter_is_active take settings constants into account
  • immediately reflect toggle of the active/inactive state in the dashboard

1.5.0 (mrbaseman, 29 Sept 2016)

  • fetch $page_id from constant PAGE_ID for all cases
  • automagically initialize the global filter list
  • allow to sort filters via drag&drop
  • make exported filter human-readable
  • improve processing of formatting of documentation
  • when exporting a filter create a filter.php file
  • during export also insert placeholders introduced in version 1.4.4
  • allow to convert between inline filters and plugin filters
  • added opf_move_up_before to move filters up in the list during installation
  • search for pre-existing module filters during installation of opf
  • cleaned up backend_body.js
  • support backend filtering, provided that the class “Tool” exists and the settings have been converted to modules (this relies on developments in the WBCE 2.0-dev Branch, so you might see the checkbox for the backend, but unless the backend is implemented as modules, most probably no filters are going to be applied) In case you have created a filter which screws up the backend completely, add the following line to your global config.php of your WBCE installation
define('WB_OPF_BE_OFF', 'off');

The value doesn’t really matter, just if the constant is defined, there will no filter be applied to the backend and you have access to the dashboard again and you can fix the filters.

1.4

this version is a major re-engineering of the module with the goal to use it without PMF.  Special thanks to all who have tested and especially to NorHei for fruitful discussions and for providing additional testing ressources.

1.4.9 (mrbaseman, 23 Mar 2016)

  • change cachecontrols filter type to page(last)
  • realign code: wrap long lines and set tab width=4
  • make help browser work without javascript
  • fix css edit for filters that supply css files
  • provide export download link when javascript is disabled
  • allow to delete filters even without javascript
  • added French and Italian language support

1.4.8 (mrbaseman, 21 Feb 2016)

  • remove unused code part from add_filter to fix array conversion warnings
  • update plugin filters to use new placeholders introduced in 1.4.4 in order to pick up this change you have to remove the example filters before upgrading OpF
  • update documentation: added a section which explains the use of the constants and placeholders

1.4.7 (mrbaseman, 21 Feb 2016)

  • a couple of cosmetic bugfixes (correctly display Umlauts in filter list, replace German ss special char with ss in filter description, remove unused filter_id from template parsing, properly initialize TPL_EXTRA_FIELDS_BLOCK in edit_filter, fix for using global LANG inside method in WBCE)
  • security fix: check ftan for upload
  • several fixes for arrays as additional field (like in correct date example)
  • fix css edit for filters that provide css

1.4.6 (mrbaseman, 18 Feb 2016)

  • add module icon for WBCE 1.2
  • bugfix: do not allow moving up uppermost filter
  • switch from FTANs to IDKEYs in many places of the backend

1.4.5 (mrbaseman, 09 Feb 2016)

  • update documentation layout
  • include example plugins again
  • update patch check
  • merge in Stefek’s changes, thanks for your contribution and for your ideas you have contributed
  • automatically remove naturaldocs sources during install
  • various minor changes to make it working in upcoming wb-classic releases

1.4.4 (Stefek, 05 Feb 2016)

  • added the following tokens to apply instead of hardcoded pathes within OpF-Plugins:
{SYSVAR:WB_URL}   = will replace with the content of the Constant WB_URL
 {SYSVAR:WB_PATH}  = will replace with the content of the Constant WB_PATH
 {OPF:PLUGIN_URL}  = will replace with WB_URL.'/modules/outputfilter_dashboard/plugins/{your_plugin}'
 {OPF:PLUGIN_PATH} = will replace with WB_PATH.'/modules/outputfilter_dashboard/plugins/{your_plugin}'
  • added 2 CONSTANTS to work with OPF Plugins
OPF_PLUGINS_PATH
diff --git a/docs/index/Files.html b/docs/index/Files.html
index 752fbab..0875ed6 100644
--- a/docs/index/Files.html
+++ b/docs/index/Files.html
@@ -49,7 +49,7 @@
 
 
 
-
1.5.6 (mrbaseman, 3 Oct 2018)
+
1.5.6 (mrbaseman, 04 Nov 2018)
diff --git a/docs/index/General.html b/docs/index/General.html index 9e5eaa4..a4285a6 100644 --- a/docs/index/General.html +++ b/docs/index/General.html @@ -81,7 +81,7 @@ -
1.5.6 (mrbaseman, 3 Oct 2018)
Vor der Installation von OutputFilter-Dashboard muß das alte Frontend-Filter-Admin Modul - wenn vorhanden - deinstalliert werden, nicht zu verwechseln mit dem Frontend-Output-Filter!
Website Baker 2.8 oder neuer.
+
1.5.6 (mrbaseman, 04 Nov 2018)
Vor der Installation von OutputFilter-Dashboard muß das alte Frontend-Filter-Admin Modul - wenn vorhanden - deinstalliert werden, nicht zu verwechseln mit dem Frontend-Output-Filter!
Website Baker 2.8 oder neuer.
diff --git a/functions.php b/functions.php index bb9e47c..d3d8916 100644 --- a/functions.php +++ b/functions.php @@ -1186,12 +1186,11 @@ function opf_apply_filters(&$content, $type, $module, $page_id, $section_id, $wb foreach($opf_FILTERS as $key => $filter) { if(is_array($filter) && isset($filter['pages_parent'])) { if($filter['active'] && $filter['type']==$type - && ($module=='' || in_array($module, $filter['modules']) || in_array('all', $filter['modules'])) - && ( ($page_id == 'backend') && (in_array('backend', $filter['pages'])) - || ( ($page_id != 'backend') && (in_array('all', $filter['pages']) || in_array($page_id, $filter['pages'])) ) - || ( ($page_id != 'backend') && (in_array('all', $filter['pages_parent']) || in_array($page_id, $filter['pages_parent'])) ) - || ( ($page_id == '0') && (in_array('all', $filter['pages']) || in_array('all', $filter['pages_parent']) || in_array('0', $filter['pages_parent']) ) ) - + && ( $module==FALSE || $module=='' || in_array($module, $filter['modules']) || in_array('all', $filter['modules']) ) + && ( ( ($page_id == 'backend') && (in_array('backend', $filter['pages']) || in_array('backend',$filter['pages_parent'])) ) + || ( ($page_id != 'backend') && (in_array('all', $filter['pages']) || in_array($page_id, $filter['pages'])) ) + || ( ($page_id != 'backend') && (in_array('all', $filter['pages_parent']) || in_array($page_id, $filter['pages_parent'])) ) + || ( ($page_id == '0') && (in_array('all', $filter['pages']) || in_array('all', $filter['pages_parent']) || in_array('0', $filter['pages_parent'])) ) )) { if(!function_exists($filter['funcname'])) { @@ -1448,7 +1447,7 @@ function opf_make_pages_parent_checktree($pages_parent, $pages, $type='tree') { } elseif($type=='tree') { $plist = '
    '; $plist .= '
  • '; - if (class_exists ("Tool") && defined('WBCE_VERSION')){ // backend-filtering supported + if (defined('WBCE_VERSION') && version_compare(WBCE_VERSION, '1.3.0', '>=')){ // backend-filtering in general for pages supported $plist .= '
  • '; } $plist .= '
    • '; diff --git a/functions_outputfilter.php b/functions_outputfilter.php index 1f06a4a..0d669fc 100644 --- a/functions_outputfilter.php +++ b/functions_outputfilter.php @@ -577,7 +577,7 @@ function opf_register_filter($filter, $serialized=FALSE) { // get next free position for type $position = opf_db_query_vars( "SELECT MAX(`position`) FROM `".TABLE_PREFIX."mod_outputfilter_dashboard` WHERE `type`='%s'", $type); - if(!$position) $position = 0; // NULL -> no entries + if($position===NULL) $position = 0; // NULL -> no entries else ++$position; // new entry or update? @@ -1363,7 +1363,7 @@ function opf_filter_get_data($name='') { $name = opf_check_name($name); if(!$name) $name = opf_filter_get_name_current(); - if($name && in_array($name, $opf_FILTERS)) + if($name && array_key_exists($name, $opf_FILTERS)) return($opf_FILTERS[$name]); else return(FALSE); } diff --git a/install.php b/install.php index f67c3cc..1cf2eed 100755 --- a/install.php +++ b/install.php @@ -107,12 +107,16 @@ } } -// run install scripts of already present module filters -foreach( preg_grep('/\/install.php/', opf_io_filelist(WB_PATH.'/modules')) as $installer){ - if(strpos($installer,'outputfilter_dashboard')===FALSE){ - $contents = file_get_contents($installer); - if(preg_match('/opf_register_filter/',$contents)){ - require($installer); +// Only block this if WBCE CMS installer is running, if this is an Upgrade or +// Module install, we need this. But the installer registers the filter-modules later. +if(!defined('WB_INSTALLER')){ + // run install scripts of already present module filters + foreach( preg_grep('/\/install.php/', opf_io_filelist(WB_PATH.'/modules')) as $installer){ + if(strpos($installer,'outputfilter_dashboard')===FALSE){ + $contents = file_get_contents($installer); + if(preg_match('/opf_register_filter/',$contents)){ + require($installer); + } } } } diff --git a/naturaldocs_txt/CHANGELOG.txt b/naturaldocs_txt/CHANGELOG.txt index 139dc56..ebf5b0c 100644 --- a/naturaldocs_txt/CHANGELOG.txt +++ b/naturaldocs_txt/CHANGELOG.txt @@ -2,12 +2,17 @@ Header: Version-History 1.5: -1.5.6 %(mrbaseman, 3 Oct 2018)% +1.5.6 %(mrbaseman, 04 Nov 2018)% - support a legacy module !opf_simple_backend! to switch between basic and advanced backend view - avoid warning during installation when shipped as core module - php 7.2 fixes - add configurl button in the filter edit view, if applicable - allow multiple uses of the same field type in extra fields + - change the logic when backend filtering shall be offered + - correctly start incrementing position of installed filters + - fix bug in !opf_filter_get_data()! to find index correctly + - fix the logic for the backend filtering - module filtering not for inline filters + - print footer always when an exit() is issued in the backend tool 1.5.5 %(mrbaseman, 5 Sep 2018)% - fix uninstall.php in case MEDIA_DIRECTORY does not start with a slash diff --git a/naturaldocs_txt/functions_outputfilter.php b/naturaldocs_txt/functions_outputfilter.php index 9319859..76edab4 100644 --- a/naturaldocs_txt/functions_outputfilter.php +++ b/naturaldocs_txt/functions_outputfilter.php @@ -577,7 +577,7 @@ function opf_register_filter($filter, $serialized=FALSE) { // get next free position for type $position = opf_db_query_vars( "SELECT MAX(`position`) FROM `".TABLE_PREFIX."mod_outputfilter_dashboard` WHERE `type`='%s'", $type); - if(!$position) $position = 0; // NULL -> no entries + if($position===NULL) $position = 0; // NULL -> no entries else ++$position; // new entry or update? @@ -1363,7 +1363,7 @@ function opf_filter_get_data($name='') { $name = opf_check_name($name); if(!$name) $name = opf_filter_get_name_current(); - if($name && in_array($name, $opf_FILTERS)) + if($name && array_key_exists($name, $opf_FILTERS)) return($opf_FILTERS[$name]); else return(FALSE); } diff --git a/tool.php b/tool.php index be51bec..4c0cf06 100644 --- a/tool.php +++ b/tool.php @@ -93,19 +93,15 @@ } $simple_backend=dirname($ModPath)."/opf_simple_backend/tool.php"; -if(class_exists('Settings') && defined('WBCE_VERSION') - && file_exists($simple_backend)){ - if(((isset($_POST['show_advanced_backend'])) && ($_POST['show_advanced_backend'] == 0)) - || ((!(isset($_POST['show_advanced_backend'])) && - (!(Settings::Get( 'opf_show_advanced_backend', TRUE)))))){ +if(class_exists('Settings') && defined('WBCE_VERSION') && file_exists($simple_backend)){ + if(isset($_POST['show_advanced_backend']) || ! Settings::Get( 'opf_show_advanced_backend', TRUE)){ include($simple_backend); - if($need_footer){ + if( ! Settings::Get( 'opf_show_advanced_backend', TRUE)){ $admin->print_footer(); + exit(0); } - exit(0); - } else { - $simple_backend=dirname($ModPath)."/opf_simple_backend/advanced.php"; } + $simple_backend=dirname($ModPath)."/opf_simple_backend/advanced.php"; } else { $simple_backend=""; } diff --git a/upgrade.php b/upgrade.php index 879326c..840c0d1 100755 --- a/upgrade.php +++ b/upgrade.php @@ -104,8 +104,8 @@ } // Only block this if WBCE CMS installer is running, if this is an Upgrade or -// Module install, we need this thing. -if(!defined('WB_INSTALL')){ +// Module install, we need this. But the installer registers the filter-modules later. +if(!defined('WB_INSTALLER')){ // run install scripts of module filters - they should start upgrade if already installed foreach( preg_grep('/\/install.php/', opf_io_filelist(WB_PATH.'/modules')) as $installer){ if(strpos($installer,'outputfilter_dashboard')===FALSE){