XenForo 2.1.12 Released Upgrade | XenForo 2.1 ENXF

Released 2x XenForo 2.1.12 Released Upgrade | XenForo 2.1 ENXF 2.1.12

No permission to download
Some of the changes in XF 2.1.6 include:
  • We need to detect if an icon defined as fa includes an fa prefix, such as fab etc., and if it already includes one, don't prepend our own.
  • Check that we do actually have some valid content before we start working with it, and bug out if not
  • Ensure we don't overwrite the rebuildDefaultData array in rebuild jobs. Additional data should be initialized in the defaultData array as normal.
  • When viewing the approval queue, ensure the "Spam clean" option only displays to moderators who have permission to use the spam cleaner.
  • Store the master Toggle cookie data for a set time, rather than per session (1 year). Support being able to specify the expiry date of each storage item and default it to 1 day. Fix some bugs which may have prevented entries from expiring when needed.
  • Enable Facebook story.php links to embed like normal Facebook posts.
  • Generally improve support for Duotone FA icons, especially in usage of addon.json.
  • When moving posts into an existing thread, ensure we only change the thread's visibility if the first source post is now the target's first post.
  • Fix incorrect logic in AbstractField for entity structures that may not support display grouping.
  • Workaround a weird quirk where some browsers may not render a broken image placeholder if the alt/title attributes are empty.
  • Add support for the theme attribute when rendering recaptcha. The value comes from the "Style type" style property in the "Color palette" group which has a light/dark value.
  • Update Linkedin connected account provider to use their updated API.
  • Apply proper fix to ensure the user's correct approval queue counts are displayed.
  • Fix an issue that would break prepending a table prefix to table names in the database adapter.
  • Reverse a change that allowed admin templates to be called from within public templates.
  • Display a more coherent error message when trying to warn a user for content they have already been warned for.
  • When deleting an attachment from content, prevent any upload errors.
  • Add missing (and undocumented!) structured data to the DiscussionForumPosting entry for the thread view.
  • Ensure that xfUniqueId() returns the new id attribute value if one was set.
  • Revert a previous change related to the conversion of some non-emoji characters to images.
  • Adjust styling of deleted structured list items (thread list etc) so that only the correct parts are underlined.
  • In the Admin CP template editor, ensure content of <xf:js> and <xf:css> tags are highlighted appropriately.
  • Prevent XF.CheckAll from updating disabled checkboxes.
  • In the news feed, ensure the reaction item is consistent so that "your post" links to the actual post.
  • If no error message exists when we check the permission for quick close/quick stick then give a generic no permission message.
  • Further fixes to sticky form submit row positioning with relation to notices.
  • In Markdown parsing, do not match a string of asterisks or underlines as valid blocks of bold or italics.
  • Prevent unexpected spacing changes when editing a message in the RTE that has tables
  • Support embedding IGTV URLs.
  • Prevent conversation reply counts from getting out of sync due to a race condition.
  • Fix mentions not always being processed correctly when a dotted capital I is present.
  • When filtering bookmarks in the popup, make the "show all" link respect the currently selected label.
  • Prevent double change logs when a user registration is outright rejected for spam behaviour.
  • Fix potential incorrect behavior when pasting into the RTE from external sources. Improve behavior when pasting from Google Docs.
  • Ensure that the RTE code editor dialog consistently automatically focuses the code editor when it is shown.
Some of the changes in XF 2.1.5 include:
  • Correctly handle Stripe review callbacks
  • Fix issue with the +/- buttons on number box elements not working in MS Edge browser.
  • Ensure the import permission helper doesn't fall over when faced with a permission value of 0.
  • Update Font Awesome to 5.11 and improve support for duotone icons.
  • Add "Spam" button on possible spammers when viewing reports.
  • Back out of a few older iOS workarounds which seem to only be applicable to very old versions of iOS related to inputs within fixed elements in order to fix some issues these cause with iOS 13.
  • Ensure favicon / title alert count indicator still displays for counts greater than 999.
  • When trying to find matching transactions when processing payments, ensure we limit it to transactions from the same provider.
  • Switch to a case insensitive match when analyzing an MP4 video ftyp types.
  • Workaround for displaying future relative timestamps in pages output from the guest page cache.
  • Changes to allow certain URLs which do not have a trailing slash to work in a more predictable way.
  • Only display "Spam" buttons to visitors who have permission to use the spam cleaner.
  • When fetching new Oembed data from an endpoint catch all exceptions and return the typical error output.
  • Fix an issue with fixed menu positioning on Safari when scrolling.
  • Prevent left/right aligned contents of spoilers from overspilling their container.
  • Avoid a quirk on the deferred loading rich text editor in Firefox which may insert an empty line when content is first entered.
  • Update Redis cache provider to use del function rather than delete.
  • Deaccent and romanize URLs before validation
  • Restore the ordering by post_date, post_id as per XF1, so that posts with identical datestamps are ordered sequentially.
  • Prevent superfluous dot character being prepended to forum list category anchor links.
  • Create a 'title' getter for the WarningAction entity (return \XF::phrase('warning_points:') . ' ' . $this->points;)
  • When displaying an unfurling error in the test tool, allow the error message to wrap as needed.
  • On the discouraged IP list in the Admin CP ensure that the list is properly paginated.
  • Disable validation when reverting to a previous revision of content
  • Check that the follow/unfollow ignore/unignore result returns something before attempting to read any associated errors
  • Remove the link URL, as there is no 'edit' page for a thread reply ban so a link URL is nonsensical
  • Update fa-warning to fa-exclamation-triangle in the XF Templater
  • Updated the Twitter dev link in the option_explain_tweet phrase
  • Ensure unfurled URLs are displayed in blocks but work nicely with floated images.
  • Prevent an undefined index error in some situations when rebuilding field cache data.
  • Add a further failover catch for when sites sent totally bonkers HTTP headers back to Guzzle for reasons best known to themelves....
  • Added meta description/og:description/twitter:description using the metadata_macros->metadata template macro
  • Use a URL friendly add-on ID when exporting languages/styles.
  • Force invisible reCaptcha to be visible on the login form. Creates a minor BC break in all Captcha classes that will need to be observed by any third-party captcha providers
  • Reduce number of queries on the node moderator lists with a new getFullNodeListCached method.
  • Update the xf_thread_read table after a thread merge to reflect the earliest read date for each source thread for each user, so that unread posts from source threads are not marked as read when they are merged into a destination thread whose original content has itself already been read
  • Implement a transaction and also fetch the last insert id on dupe
  • Wrap a bunch of jobs in transactions so we don't ever find out SELECT results are invalid by the time we UPDATE them
  • Implement the suggested check on is_counted from the report thread
  • Wrap Throwable in ErrorException for compatibility with Symfony component
  • Fix logic around user reaction scores when deleting content/changing Reaction scores
  • Prevent false positive detection of duplicate key exceptions in queries due to generic SQL state code.
  • Gracefully handle a race condition when inserting bookmarks.
  • Make the list sorter more usable on touch devices by ensuring the page doesn't scroll when trying to drag items.
  • Fix a situation where tables would not be converted to BB code correctly if there was CSS/alignment applied at the table row level.
  • Move setting up XenForo's error handling to be part of startSystem rather than standardizeEnvironment to ensure that the necessary classes/functions are available before they may be called.
  • Fix timestamp issues after timezone/DST changes
  • When loading recently used smilies/emoji, prioritize smilies over emojis when there are conflicting shortcodes. (This may still lead to the incorrect icon being shown, but only when the conflicting emoji is inserted instead of the smilie.)
XenForo 2.1.4 is now available for all licensed customers to download. We recommend that all customers running previous versions of XenForo 2.1 upgrade to this release to benefit from increased stability.

The following public templates have had changes:
  • account_bookmarks
  • account_ignored
  • bb_code.less
  • editor.less
  • node_list.less
  • reaction_item_post
  • thread_list_macros
  • thread_view
  • widget_new_threads
The following public templates have had changes:

  • bb_code_tag_quote
  • bookmark_macros
  • conversation_add
  • conversation_invite
  • conversation_list_macros
  • core_input.less
  • core_offcanvas.less
  • custom_fields_macros
  • editor.less
  • message.less
  • notice_cookies
Where necessary, the merge system within the "outdated templates" page should be used to integrate these changes.
Some of the changes in XF 2.1.2 include:
  • Update Font Awesome to 5.8.1.
  • Update Froala to version 2.9.4.
  • A number of fixes related to Stripe payment handling including performance optimisation, and better error handling.
  • Ensure conversation recipient cache is correctly updated when users are merged.
  • Always link to the conversation/unread action from the conversation list/popup.
  • Do not reset conversation read-marking data when marking a conversation read/unread.
  • Add an AddUser relation to the XF TagContent entity.
  • Ensure user promotions and trophies are updated on session creation if user hasn't been active recently.
  • Ensure ignored members avatars are not shown as the last member in a list of second level categories.
  • Prevent URL unfurling entirely if the auto unfurl option is unchecked as this previously did not prevent forcing unfurling manually.
  • Remove unused sendmail -f parameter option. If the default sendmail command already specifies the -f parameter, attempt to remove it so it can be overridden later.
  • Attempt to improve prefix filtering performance on the search form.
  • When marking alerts read automatically for trophy awards, pass in the correct trophy IDs.
  • Even out the padding in the main message cell.
  • Make some adjustments to the sticky submit row to offset any bottom fixed notices.
  • Fix off-by-one error when handling the autolinking of URL tags.
  • Add optional hint to the labels input row when editing a bookmark.
  • When push notifications are disabled (globally or for a user) try to maintain the push conversations option value.
  • Use consistent lock/unlock wording for threads.
  • Ensure bounce emails are processed correctly when VERP is disabled.
  • Log user IP used for email confirmation
  • Extend the number of possible unicode replacements by including the EmojiOne "greedy" rules.
  • Correctly support specific autocomplete attribute types for registration and password changes.
  • Submit user's email address when checking for spam at the contact form.
  • Populate the session with the correct cache keys for unapproved counts.
  • Ensure last post username caches are passed to all avatar and username tags so that the default avatars of guest users display correctly.
  • Correctly handle embedding Imgur user URLs.
  • Handle more cases where pasted URLs are undesirably auto-linked.
  • Use a different label on the "Upgrade official XenForo add-ons" page to avoid confusion.
  • Fixes issue where numberbox buttons do not step the number up/down in IE11.
  • Coerce BB code to a string when parsing.
  • Display debug only options if applicable when viewing an add-ons specific options list.
  • Attempt to log the last triggered date of a banned email, even if it is a wildcard match.
  • Fix the success flash message when copying URL from the share_tooltip.
  • Send alerts for quoted posts on approval.
  • When unparsing BB code from HTML, include <s> tags.
  • Support embedding Facebook "photos" URLs.
  • Ensure that fullWidth buttons are actually fullWidth (if they are button elements, rather than anchors).
  • Use thread isIgnored method when filtering new threads results.
  • Prevent an out of range MySQL error when upgrading to XF 2.1.
  • Cast quoted post IDs to integers before querying for their user IDs.
  • Fix incorrect type hints in welcome message service.
  • Allow short circuiting of canEdit checks in the thread list macros item template.
  • Allow the hideUnviewable option to be passed into the string formatter as false when stripping BB code so that unviewable tags can be represented by their placeholder for profile posts and comments.
  • Constrain user IP searches by length to ensure IP versions aren't mixed.
  • Do not show following/follower users who are ignored by the current visitor on a user's profile.
  • Fixed variable typo in REST API thread filtering code.
  • Prevent some keyboard shortcuts in some cases when the rich text editor is focused when using IE11.
  • Ensure that editor HTML conversion maintains an attachment's height attribute.
  • Do not remove inactive class extensions from extension_hint.php.
  • Prevent long spoiler titles from breaking out of the viewport.
  • Make the line trimming around BB code list tags more consistent.
  • Invalidate the member stat results cache when the user limit changes.
  • When executing CLI commands, in the event that there is a database exception and a query, display that query in the error output.
  • Perform some additional string cleaning when filtering arrays of strings.
  • When viewing bookmarks, ensure the label filter is passed into the pagination.
  • Implement a (hopefully) temporary workaround for a macOS Chrome bug which causes the scroll bars to permanently cover party of the code in code blocks.
  • In the thread reply bans list, ensure the delete checkbox doesn't cover its label.
  • Only fetch content reactions for the reaction summary if it is associated with an existing user.
  • Restore gravatars for existing users which have them set, even if the option to add one is disabled.
  • Remove unused code from BB code tag renderer.
  • Add a less generic phrase for duplicate banned emails.
  • Add some additional explain text about the link building callback detailing the expected arguments.
  • Cast imported master phrase texts to string by default.
  • Ensure that content edit history diffs wrap correctly.
  • In a couple of places, use a count/total query when calculating the correct page number for profile posts.
  • Prevent an error in the member stats system when an empty result set is returned as an object instead of the expected array.
  • Perform some basic typo checking when validating email addresses via the contact form.
  • Changes text of "seperate_names_with_comma" phrase to "You may enter multiple names here."
  • When focusing the editor with an Android device, ensure that the contents are correctly scrolled into view.
  • Increase the BB code block sizing check window.
  • Take steps to reduce a race condition which may cause AJAX requests to not include the CSRF token.

The following public templates have had changes:
  • account_bookmarks
  • account_preferences
  • account_security
  • bb_code.less
  • bookmark_edit
  • conversations_popup
  • conversation_list_macros
  • core_button.less
  • core_datalist.less
  • core_fa.less
  • diff.less
  • editor_base.less
  • helper_js_global
  • helper_thread_options
  • lost_password_confirm
  • member_about
  • message.less
  • node_list_category
  • node_list_forum
  • PAGE_CONTAINER
  • register_form
  • register_macros
  • search_result_profile_post
  • search_result_profile_post_comment
  • setup_fa.less
  • thread_list_macros
  • thread_view
XenForo 2.1.1 is now available for all licensed customers to download. We recommend that all customers running previous versions of XenForo 2.1 upgrade to this release to benefit from increased stability.

We have also made some improvements to the importer framework. Notably it is now possible to perform a multi-process import in order to make better use of multi-core processors. If you run an import via the CLI and you add the --processes option with a value greater than 1, then multiple PHP processes will be used to perform the import, instead of a single CPU core being used as is the PHP default. Your results may vary, but with the number of processes set to equal the number of physical cores on a sufficiently powerful server, you should notice a significant increase in performance.

You can also run your import command with the new --finalize option which will run the finalize stage automatically after the data import has finished.

While we're talking about importers we should also point out that we are today also releasing XenForo Importers 1.2.0 with a new "Invision Community Forums" importer, XenForo Media Gallery 2.1.1 which reintroduces a number of importers originally included in XFMG 1.x and XenForo Resource Manager 2.1.1 which includes an XFRM to XFRM importer. See below for more information.

If you are upgrading from XenForo 2.1.0, please be aware that there is a new option called "Convert Markdown-style content to BB code" which is now disabled by default. If you would like to use Markdown-style formatting in your messages, you will need to enable this option first.

The following public templates have had changes:
  • app_nav.less
  • app_sectionlinks.less
  • app_staffbar.less
  • bb_code.less
  • bb_code_preview.less
  • bookmark_edit
  • bookmark_macros
  • category_view
  • core_bbcode.less
  • core_block.less
  • core_contentrow.less
  • core_menu.less
  • core_pikaday.less
  • core_tab.less
  • editor.less
  • forum_post_thread
  • forum_view
  • google_analytics
  • member_macros
  • member_tooltip
  • member_view
  • PAGE_CONTAINER
  • poll_macros
  • prefix_input
  • register_form
  • register_macros
  • share_page_macros
  • structured_list.less
  • thread_list_macros
Today, we are excited to announce that XenForo 2.1.0 has completed its pre-release phase and is now our primary supported XenForo version. This release adds a number of significant features to XenForo. The major features include:
  • Native push notifications on supported devices/browsers
  • Editor button management
  • Enhanced editor integration and advanced BB code option syntax
  • Markdown support
  • Tables
  • Reactions
  • URL unfurling
  • Emoji enhancements including an improved smilie menu with easy emoji access
  • Video uploads
  • Approval queue improvements
  • Guest performance improvements including guest page caching
  • Content bookmarking and sharing
  • A fully featured REST API
  • One click XenForo upgrades and easier add-on installation
  • BB code and rich text editing for profile posts and comments
Current requirements

The following are minimum requirements:
  • PHP 5.6 or newer (PHP 7.2 recommended)
  • MySQL 5.5 and newer (MySQL 5.7/8.0 or equivalent recommended)
  • All of the official add-ons require XenForo 2.1.
  • Enhanced Search requires at least Elasticsearch 2.0.
Top