Wordpress theme breaks && in Jomres templates

Today I've been working on modifying Jomres behaviour in WordPress, specifically with respect to how it behaves when the theme doesn't offer Bootstrap. All of the work I've been doing recently is for Bootstrap 5 based sites, so changing the CDN loading from BS3 to BS5 allows more users to use the newer plugins.

Happily the work went great. Where previously Jomres would load CDN based copies of Bootstrap 3, it now loads Bootstrap 5 & Fontawesome. I also needed to look at the js and css loading functionality because while it worked fine in Twenty Twenty theme, it wouldn't work in Twenty Twenty Two. Given that all of the development work I'm doing now is for Bootstrap 5 based sites, I had to resolve these two issues if users want to use all available plugins.

I'll be honest, I'm pretty chuffed with how it looks, even on basic themes like Twenty Twenty Two.

However!

 (There's always a however, otherwise what's the point of a blog post?)

I came across an annoying problem. Firefox's browser console alerted me to a problem by reporting

Uncaught SyntaxError: '#' not followed by identifier

and when I looked more closely at the page source I saw that javascript from the dashboard, instead of being

if (startDate == endDate && whole_day_bookings == '0')

it was in fact

if (startDate == endDate && whole_day_bookings == '0')

It's no surprise that Firefox was throwing a wobbly. I learned that the problem was with wptexturizer which treats a rendered Jomres page as untrustworthy so it tries to santitise post data before it's presented to the user.

Now, I'm a great believer in security. Jomres has it's own input filtering code, and has for years. It's been a portal system for 17 years and in all that time I've treated user entered data as insecure so I've always striven to ensure that any data is sanitised long before it ever hits the database. I can kinda see where the WordPress developers are coming from with this solution, I've done similar things myself.

After a bit of Googling, I came across this stackoverflow post. The user was having similar problems to me, so I gave the solution a shot. I had to replace

$tags = array(' <!-- noformat on -->', ' <!-- noformat off -->');

with

$tags = array('/* noformat on */', '/* noformat off */');

because the html comments code broke the javascript, but it worked. Sorta.

I then discovered that wptexturizer was adding br and p tags to the rendered html content, causing yet more javascript errors. It also explained why I had a heck of a lot more whitespace in rendered Jomres templates than had any right to be there.

I tried everything, but nothing I did would work, including adding no_texturize_tags filters, probably because of how Jomres works. All the googling I've done throws up scores of results about disabling the function. It seems I'm not the only person who's been frustrated by the problem.

The only solution that actually worked was adding this line to the Jomres WP CMS bridging code. On installation and update of Jomres the bridging code is copied from that directory into the /wp-content/plugins/jomres directory.

add_filter( 'run_wptexturize', '__return_false' , PHP_INT_MAX );

What this does is it completely disables the wptexturizer function on any page that the Jomres plugin is run on.

Is it dangerous to remove this function? Maybe, in theory.

What wptexturizer is doing, as far as I can tell, is preventing javascript that a malicious user might have saved, typically in a blog post, from running on the post's display. So, in theory if you have guest posters who have figured out ways of evading WordPress's input filtering, then it's possible that by disabling this WordPress function I've opened up a crack in WordPress's armour.

The truth is, I think that function is probably overkill. As I already said, Jomres already sanitises data saved by property managers, even if the administrator allows use of html editors, and WP santises using it's own input filtering on posts.

On balance I'm satisfied that it makes sense to remove this function when rendering a Jomres page. If you're an admin and you allow guest posts by people you don't trust then one precaution that you could take is to not show guest posts on the same page that Jomres is run on. On any non-Jomres page, wptexturize is still going to be run, so show those posts there instead.

Honestly, I think that this is overkill too.

Wrapping up

I've googled and googled and I can't find any rationale that stresses that it's best to leave the wptexturizer function enabled. I've found absolutely scores by designers complaining about what it does, but none that say that it should be retained. If you know different, please do drop me a line.

 

WordPress, Input Filtering

  • Created on .

ABOUT US

vince picDeveloped and maintained by Vince Wooll, Jomres was initially conceived in early 2005 as a Mambo based solution to a client’s hotel management needs. While it wasn't originally expected to be an online booking system it quickly morphed into one as users requested more and more features.

As the number of feature requests grew Vince knew that he would need to dedicate more time to the project and in July 2005 Jomres was released as a commercial project. Since then Jomres has become the world's oldest online booking plugin for any PHP CMS. It has been used in Joomla 1.0, 1.5, 2.5, 3 & 4 and WordPress 4, 5 & 6.

Aladar joined the project in 2010 after using Jomres for his own projects. He was active on the forum, helping other members of the community and eventually Vince invited him to join the team. Between 2010 and 2018 he was an integral part of the project and made many significant contributions.

Whilst not formally part of the Jomres project, Rodrigo Rocco and Vince have become firm friends. Rod is a freelancer who specialises in doing custom work for Jomres users and developing custom plugins for the system that take advantage of it's modular design. He has built many useful extensions including his fabulous Valentina Template Override Package.

Jomres and the Jomres Logo is trademarked and can't be used without written consent from the owner.

www.jomres.net is not affiliated with or endorsed by the Joomla! Project, Open Source Matters or the WordPress project. The Joomla! & WordPress names and logos are used under a limited license granted by Open Source Matters and the WordPress Projects.

© Copyright 2005 - 2022 Vince Wooll