[horde] Horde 6 - Inline HTML error

Nels Lindquist nlindq at maei.ca
Fri Apr 10 19:20:18 UTC 2026


Hi, Ralf.

I've been testing this for several days, and haven't run into any issues with PHP 8.5.5.

I used 'composer require "horde/css_parser:dev-feat/sabberworm-dual-version as 2.0.0beta6.1' to alias for a specific dependency on css_parser:2.0.0beta6; is there an easier/better way to do that?

--
Nels Lindquist
<nlindq at maei.ca>


On 2026-04-07 12:56 AM, Ralf Lang wrote:
> Hi Nels,
> 
> feat: Support Sabberworm CSS Parser 9.3 / PHP 8.5 for modern interface by ralflang · Pull Request #7 · horde/Css_Parser <https://github.com/horde/Css_Parser/pull/7>
> 
> Those who dare can test drive this yet unreleased version of horde/css_parser which works with Sabberworm 9 / PHP 8.5 natively.
> I don't feel confident yet and will need to do some of my own testing or wait for PR feedback.
> 
> On Mon, Apr 6, 2026 at 11:32 PM Nels Lindquist <nlindq at maei.ca <mailto:nlindq at maei.ca>> wrote:
> 
>     Okay; got it working, but it was a bit of an effort.
> 
>     I had:
> 
>     horde/css_parser             2.0.0beta5   CSS parser library
>     horde/cssminify              2.0.0beta6   CSS minification library
> 
>     Upgrading did nothing initially.
> 
>     I tried installing sabberworm/php-css-parser, which gave me version
>     9.3.0, and the entire site stopped loading, with different errors:
> 
>     PHP Fatal error:  Class Sabberworm\CSS\Property\Declaration contains 1
>     abstract method and must therefore be declared abstract or implement the
>     remaining method (Sabberworm\CSS\Renderable::__toString) in
>     /var/www/html/horde6/vendor/sabberworm/php-css-parser/src/Property/Decla
>     ration.php on line 27
>     Stack trace:
>     #0 /var/www/html/horde6/vendor/composer/ClassLoader.php(576): include()
>     #1 /var/www/html/horde6/vendor/composer/ClassLoader.php(427):
>     {closure:Composer\Autoload\ClassLoader::initializeIncludeClosure():575}()
>     #2 [internal function]: Composer\Autoload\ClassLoader->loadClass()
>     #3
>     /var/www/html/horde6/vendor/thecodingmachine/safe/generated/8.1/classobj.php(17):
>     class_alias()
>     #4
>     /var/www/html/horde6/vendor/sabberworm/php-css-parser/src/Rule/Rule.php(16):
>     Safe\class_alias()
>     #5 /var/www/html/horde6/vendor/composer/autoload_real.php(45):
>     require('...')
>     #6 /var/www/html/horde6/vendor/composer/autoload_real.php(49):
>     {closure:ComposerAutoloaderInit40e1abd60ba24c0f96585851b5c9f552::getLoader():41}()
>     #7 /var/www/html/horde6/vendor/autoload.php(22):
>     ComposerAutoloaderInit40e1abd60ba24c0f96585851b5c9f552::getLoader()
>     #8 /var/www/html/horde6/web/horde/services/ajax.php(2): require_once('...')
>     #9 {main}
> 
>     I tried force installing horde_cssparser:2.0.0beta6, but it explicitly
>     requires sabberworm/php-css-parser:8.9.0, which it didn't want to
>     install on PHP 8.5.
> 
>     Adding the --ignore-platform-reqs flag for composer bypassed the PHP
>     version limitation and I ended up with the same versions you've got.
> 
>     It seems to be running fine on PHP 8.5, and I'm no longer getting errors
>     when loading inline HTML.
> 
>     -- 
>     Nels Lindquist
>     nlindq at maei.ca <mailto:nlindq at maei.ca>
> 
>     On 2026-04-06 1:30 PM, Brent wrote:
>      >   It appears you have an older css parser or something.  Here's my
>      > configuration that is working with the same mime local file to enable
>      > html viewing.
>      >
>      > $ composer show|grep css
>      > horde/css_parser             2.0.0beta6   CSS parser library
>      > horde/cssminify              2.0.0beta6   CSS minification library
>      > sabberworm/php-css-parser    8.9.0        Parser for CSS Files written
>      > in PHP
>      >
>      > Enable the test.php script and see if it finds anything. Ralph and the
>      > team have put a lot more helpful debugging information into it and maybe
>      > it'll help isolate the issue.
>      >
>      > brent
>      >
>      > Quoting Nels Lindquist <nlindq at maei.ca <mailto:nlindq at maei.ca>>:
>      >
>      >> PHP 8.5 FPM.
>      >> Latest H6 updated this morning.
>      >>
>      >> I enabled inline HTML in IMP, by setting:
>      >>
>      >>> $mime_drivers['html']['inline'] = true;
>      >>
>      >> in var/config/imp/mime_drivers.local.php.
>      >>
>      >> After doing so, I'm now receiving an error when attempting to view
>      >> mail messages with HTML:
>      >>
>      >> [imp] Error: Call to undefined method
>      >> Horde\Css\Parser\Parser::keepOnlyDangerousCss() in
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Html.php:617
>      >>
>      >> Stack trace:
>      >> #0
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Html.php(558):
>      >> IMP_Mime_Viewer_Html->_parseCss()
>      >> #1
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Html.php(166):
>      >> IMP_Mime_Viewer_Html->_processDomDocument()
>      >> #2 /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Html.php(76):
>      >> IMP_Mime_Viewer_Html->_IMPrender()
>      >> #3
>      >> /var/www/html/horde6/vendor/horde/mime_viewer/lib/Horde/Mime/Viewer/Base.php(157): IMP_Mime_Viewer_Html->_renderInline()
>      >> #4 /var/www/html/horde6/vendor/horde/imp/lib/Contents.php(665):
>      >> Horde_Mime_Viewer_Base->render()
>      >> #5
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Alternative.php(137): IMP_Contents->renderMIMEPart()
>      >> #6
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Mime/Viewer/Alternative.php(55): IMP_Mime_Viewer_Alternative->_IMPrender()
>      >> #7
>      >> /var/www/html/horde6/vendor/horde/mime_viewer/lib/Horde/Mime/Viewer/Base.php(157): IMP_Mime_Viewer_Alternative->_renderInline()
>      >> #8 /var/www/html/horde6/vendor/horde/imp/lib/Contents.php(665):
>      >> Horde_Mime_Viewer_Base->render()
>      >> #9
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Contents/Message.php(594):
>      >> IMP_Contents->renderMIMEPart()
>      >> #10
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Contents/Message.php(336):
>      >> IMP_Contents_Message->_getInlineOutput()
>      >> #11
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Contents/Message.php(176):
>      >> IMP_Contents_Message->getInlineOutput()
>      >> #12 /var/www/html/horde6/vendor/horde/imp/lib/Ajax/Queue.php(462):
>      >> IMP_Contents_Message->showMessage()
>      >> #13
>      >> /var/www/html/horde6/vendor/horde/imp/lib/Ajax/Application/Handler/Common.php(702): IMP_Ajax_Queue->message()
>      >> #14
>      >> /var/www/html/horde6/vendor/horde/core/lib/Horde/Core/Ajax/Application.php(179): IMP_Ajax_Application_Handler_Common->showMessage()
>      >> #15 /var/www/html/horde6/vendor/horde/horde/services/ajax.php(64):
>      >> Horde_Core_Ajax_Application->doAction()
>      >> #16 /var/www/html/horde6/web/horde/services/ajax.php(3):
>      >> require_once('...')
>      >> #17 {main} [pid 536324 on line 76 of
>      >> "/var/www/html/horde6/vendor/horde/core/lib/Horde/ErrorHandler.php"]
>      >>
>      >> --
>      >> Nels Lindquist
>      >> nlindq at maei.ca <mailto:nlindq at maei.ca>
>      >> --
>      >> Horde mailing list
>      >> Frequently Asked Questions: http://horde.org/faq/To <http://horde.org/faq/To> unsubscribe, mail:
>      >> horde-unsubscribe at lists.horde.org <mailto:horde-unsubscribe at lists.horde.org>




More information about the horde mailing list