- Details
- Written by: Max Milbers
- Category: Latest News
- Hits: 56
From time to time it happens. We have an XSS issue. Reported by Aman Rai. More Infos later. Version vm4.4.4 has a fix to prevent them.
[Update] After some further investigation together with the Joomla core team, this issue can not be exploited in the latest Joomla versions. If you have Joomla 5.1.4 or later or 4.4.8 or later installed, the issue is already fixed. We did not check against joomla 3.
[Update 2] Sorry guys, a little error found. If you store a product with media, the checkbox "is image" is not preselected. The fix is ready, but this time we want to take more time for testing to prevent such stupid errors (mea culpa).
- Adjustments for Tableupdater to prevent unecessary updating of keys in mysql8
- vmUri extended whitelist, function works now also with given query
- vRequest extended function getVar to work with given source
- install.sql fixed TINYINT(4) against TINYINT(1)
- added the option to add no searchfield
- added setConvertInt also for plugin tables
- added property "isImage" for medias, works BC
- fixed currency if none is set
- fixed adding of new states in the new admin layout
- fixed problem in router
- user registration fix if not in checkout
- Details
- Written by: Max Milbers
- Category: Latest News
- Hits: 139
Just a note to my last news. The problem goes on, I just tried to install VirtueMart on the last joomla5.3 and it was not even possible to install it. On the other hand, it is funny to read the patch notes. One patch will fix an issue of joomla 5, but for j5.3, we solved it already in this release. The question is, why we have to solve something, which worked since vm2.6? After this release should be more time to work on WP and make some committs.
DOWNLOAD VirtueMart 4.4.2 with the Membership
NOW
Features
- Template vmBasic, Added register and checkout button, removed registration fields from cart view.
- Bundles added option "orderableBrowse" for disabling add to car in listing
- Added option calculateVariantsOnFreshLoad, which directly calculates the price for the selected variant (with php)
- Fixed dragndrop for customs, products, categories, countries
- Added missing states list and states edit layouts to new admin template
- Hiddden config reuseorders, default is set to 0/off now
For developers
- New variable to set origin debug state, vmEcho::$debugSet and vmEcho::$logDebugSet
- VmEcho added check for function_exists('var_dump'), which is used if existing
- VmJsApi function setPath, we add BE and FE override paths only if given, also added the override paths of the current admin template
Fixes
- Fixes for pagination in cowork with RuposTel, correct use of index.php and using categoryId via request over the one set in the menuItem
- Fixed problem with jumping thumbs in product edit related products/categories
- Enhanced table updater to work also with Index and better check which indexes should be modified
- User model, unset register pw in case of fail in log
- Added new pattern using vmEcho::$debugSet
- Fixed old VmConfig::$_debug against VmEcho::$_debug
- Customfields function calculateModificators added check for string before vmJsApi::safe_json_decode
- xml format fixes
- Translated text for "catalogue mode and accessing cart"
- Textinputplugin checks letters only if there are some letters, fixed missing jQuery
- Model customs function getCustoms, removed useless return as $data->items instead just as $data
- Removed outdated dead code
- PayPal Checkout fixed mix of dynamic and static calls
- Use of new VmEcho debugSet pattern and new ppdebug
- Details
- Written by: Max Milbers
- Category: Latest News
- Hits: 283
The new version 4.4 has few new features, but reflects the evolving development process. Longterm users know that VirtueMart is developed in a rapid prototyping and KaiZen philosophy style. So if we develop a new feature, our testers sometimes have 10 new test versions a day. On the other hand, we try to evolve the code without hard breaks. For example developers can use the same function to get a category tree, but the technic behind that function drastically changed over the years. No stone was left unturned.
A known joomla ecommerce component announced last weeks, that they stop development. Of course some eager developers created a fork, but they will run into the same problems as the prior developers. And these problems are similar to our problems, in that it is not enough to just keep the core development paid and ongoing, we must as a community also keep our 3rd party developers and encourage new ones to join us.
Lets create a VirtueMart for Joomla and Wordpress
If we manage VirtueMart on Wordpress we can increase our ecosystem drastically. Years ago, I already managed it to see the sample products on Wordpress. To bring VirtueMart alive on WordPress I need people who are at best 3rd party developers for it and who can help to make it a round thing. Furthermore users who know Wp and are willing to test. And finally people who want to setup a real store with VirtueMart and Wordpress.
There are 2 main reasons, first we have competitors in the joomla area, compared to 12 years ago and Joomla base itself is shrinking. It is not simple to gain insight using just the download numbers, but I think it is possible to see a trend. Btw, our download numbers were horrible after providing the new installer only for members, because the members downloads are not counted with our redmine system. So yes, it is fragile. Back to Joomla downloads, there are a lot things to consider, for example joomla 4.4 has not a lot downloads, because on the same day they released j5. For example j4.4.9 has only a bit more than 65k updaters. But j4.4.8 has a bit more than 100k. Of course a lot updated to j5 already.
But the trend is,...
- Joomla 1.5.26 (last joomla 1.5) was downloaded as installer more than 1 Million times and 800k Updaters (ca 1,6 Million pages), Lifetime 4 years
- Joomla 2.5.28 (last joomla 2.5) was downloaded as installer more than 450k and 1,6 Million Updaters (ca 2 Million pages), Lifetime 2 years
- Joomla 3.10.12 (last joomla 3) was downloaded as installer just 50k but 1 Million Updaters (ca 1 Million pages), Lifetime 9 years
- Joomla 4.3.2 (last joomla 4 without j5) was downloaded as installer just 50k and only 250k Updaters (ca 280K pages)
- Joomla 5.1.4 (last joomla 5.1) was downloaded as installer just 50k and only 100k Updaters (ca 130K pages) 3 years old
- Joomla 5.2.0 (last joomla 5) was downloaded as installer just 20k and only 80k Updaters (ca 90K pages), 1 years old
People loved Joomla 1.5 so much, that they installed the last version more times, than updating. But you can assume that most updaters to joomla 5 are just people who used joomla 4 before. So I think that there are less than 1 million joomla pages left (compared to the aproximate 3 million maxium)
and in prior times we also had more mirrors in local communities. Yes I did not count the downloads from, for example the german community page. But I doubt the numbers are very different. It is clear to see that the joomla community is sick of "general updates".
From my point of view it is very old school to change the architecture for a major new version. When I grew up with computers, it was a typical problem that old programs just did not work on new operating systems. Windows 3.1 software did not work on DOS, and Win95 software may stopped working on WinXP. The Linux world was not better! But with the time, it changed. Nowadays you can assume that a win7 program works on win10. The same for Linux. But somehow, in the joomla world,... But I still have great hope, that Joomla 5 is the standard for the next 10 years, but not like Joomla 3 (which had core changes until j3.5, so for us it was just 5 years). A system lives by the 3rd party developers joining. The lower the maintenance costs the higher the chance that people use it in the long run. On the other hand there must also be new opportunities for 3rd party developers to earn money. At best with new features and not just maintaining old ones.
The next problem are our free extensions. A lot free extensions vanished, after any big change in the joomla core. When I started with j1.5 there were tons of free extensions for small problems. The next problem is to find a replacement for the old good working extensions. There are still shops running on very outdated joomlas, because the maintainers do not find solutions for already solved problems for Joomla 3, 4, 5.
and here a direct speech of GJC, one of our forum moderators:
"It is pretty obvious to me.. the majority of my direct customs are one person small shops -
they get by but they aren't making big money, normally the shop is a side line or add on to their other activities.
How can I in all honesty come to them and say you must upgrade to J4/5 because it's wonderfully rewritten and uses the latest php etc etc.
When I show them it they hate the admin ( changed just for change ) and they ask sensible questions like is it faster? is it better? will it increase my sales? etc.. and of course I have to say no .. your customers will see no difference if I build the template the same as u have now but you get to use extra clicks to reach anything in the admin.
My host offers 1 click php 5.2 to 8.4 .. they tell me all phps are "hardened" and that they are happy to offer these versions for the foreseeable future.
I also do a lot of migrations for web agencies that of course really push their clients to upgrade..
I have never yet found a client that liked the new admin or thought anything was any better after the upgrade ..
all it did was cost them a lot of money with the suspicion that it probably wasn't necessary ...
I bet when J6 swings around they will tell the agency where they can stick it... "
So in short, our customers dont see any added value by a new joomla core. And new features of Joomla dont need a new core. Joomla 5 itself is super! But Joomla already lost a lot ground against the simple working solutions. Joomla should stop reinventing the wheel all the time. There is so much that the Joomla community could do to enhance joomla without touching the core (except bugfixes). I think, almost any new feature for normal users could have been done in joomla 1.5 as well. For example versioning, better media uploader, and so on. So Joomla should take a break and care for documentation of the code and use the current core to develop new features.
Just while I am writing this article, I want to add an image. I use "Insert Image", but I cannot upload in this dialog and I need to enter some path? Then I used "Images and Links". There you can upload an image. Then I set the image for the content page, looks awful. I need class to prevent floating. So I use the generated link there to use again "Insert Image" and can now copy paste the path. To make this better we do not need to change the core, just the editor and that is a typical example.
Of course, all the architectural changes and usability changes are made to make development easier and the code faster, cleaner, more robust, and so on. But all these cool things can't show their value if it changes when it's just starting to run.
But, as I explained the last news, we should have peace against adjustments for the next 3 years at least. We could stand still and wait, but I think we should push forward. I suggest to develop VirtueMart for WordPress. That would open the VirtueMart ecosystem to a lot new potential users. I know that there are Wordpress users waiting for it. Join development here https://forum.virtuemart.net/index.php?topic=152160.0
The new features which round up 4.4.0
New Features
- Use category menu items with manufacturer categories
- Use manufacturer menu items with manufacturer categories
- New optional feature, registration is only available if a product is in the cart
- Added option for ask a question to vendor, could be misused for spam similar to ask a question about a product
- Plugin trigger plgVmOnSendVmEmail can prevent sending of mail completly by returning false
- New plugin trigger for vmError
- Sales report with sku
Enhancements/Fixes
- Added missing trigger plgVmDisplayLogin to bs5-login layout
- Fixed hard coded string "Do you have an account?" https://forum.virtuemart.net/index.php?topic=152097.0
- Grid changes for desktops and styling fixes
- Removed unnecessary VmConfig::getConfig
- Fixed updating of category_categories table
- Router fix productdetail
- PayPal Checkout added check for requested userfields published
- PayPal Checkout, fixed popup plugin with enabled Joomla HTTPS Headers plugin
- Moved ajax function recalculate to an own json file, more compatible to joomla
- User model considers joomla setting for register mail
- Removed unnecessary references
- VmModel set _maxItems to public in product model, set the hidden config absMaxProducts to 400 and fixed that maxItems returned one product too much
- Small fix for product module
- Small fixes for TcPdf and PHP8
- Removed Multi-media upload for other views than product edit.
Templaters
- The logic which decides if registration should be shown is moved to the view.html. Just use the provided booleans
- Enhanced the function for templaters to show register fields and button yes/no and so on
- Details
- Written by: Max Milbers
- Category: Latest News
- Hits: 1889
New Template vmBasic
The new template is written by Spyros Petrakis and is kept simple to enable easy modification. It works fast out of the box and is written fully in Bootstrap 5. Mobile ready and simple to configure. Natively supported OPC.
The new layout system of VirtueMart allows you to use different bootstrap layouts and this now comes into play. The layout files of the vmBasic are integrated in the core as files with the prefix bs5-, meaning these basic layouts can easily be used in any other bootstrap 5 templates. This means VirtueMart has arrived in the Bootstrap 5 world finally. Special Virtuemart css classes are reduced, so it is also easier to learn. This should increase the out of the box useablity of templates for VirtueMart. The Bootstrap 5 layout is set for Joomla 5 automatically. Existing layout overrides are kept.
Rough times behind, calm waters ahead, let's sail into the future.
The last few years have been characterised by constant changes in the software environment of VirtueMart. Yeah, I know, I have written this often already, but it really had a massive impact from j3 to j4 to j4.2 to mysql strict mode to php8.0 to php8.2 to bootstrap 5. The errors for the mysql strict mode and PHP8.2 were unpleasant to find. The prior big advantage to use PHP was the simple type juggling, but that has become much stricter and as a result we had to remove a lot small inconsistences in the code. For example, before it was allowed to initialise a variable with false (boolean) and to set it later to "all" (string). Now it must be initialised as string directly. The mysql strict mode created similar problems. Storing of strings formed as integer like "7" were stored correctly before, but now it must be a correct integer.
This created a lot of work, but the mysql strict mode existed for years and the new strict php types just follow developer languages like Java or C, so there are no hidden surprises. After our changes these modernisations should now be catered for. Joomla 5 will be supported the next 3 years at least. There is no release date yet for PHP 9 and the known changes are mostly covered (PHP8 Warnings will become fatals, so we did our homework already to 98%). The development for Bootstrap 6 has not even started yet (officially) and they say a new version would take at least 5 years. This means these problems cannot appear again in this massive way. This is good news especially for shops who were forced to frequently update their template over the last years.
Interesting new features for shopowners
- New bootstrap 5 frontend template (vmbasic)
- Moved vmbasic bs5 views and assets in the core folders
- Frontend Template system checks now also in media/templates/site/yourTemplate/com_virtuemart... for ressources, this means common joomla 5 templates should work as expected (by VirtuePlanet.com)
- Added storing and loading of user addresss to cart for native OPC
- New media type webp by vdweb.cz and alxgan https://forum.virtuemart.net/index.php?topic=151601.0 and tagarrison (fancybox)
- Enhanced feature recommend a friend, ask a question, call for price, there is now a new option, which allows to use this function only as customer who already bought
Enhancements (or fixes)
- Enhanced the user switcher (started with a bug in some templates)
- Userfields in the array can now be accessed by name, this makes it a lot easier to controll a form or output of an address
- Added manufacturer and manufacturer images for category views with set manufacturerId cart view,
- Added "text/csv" to safe mime types. So we can use the vm file uploader also for csv files
- Enhanced autochecker of the cart to work also with text fields (for the native OPC)
- Enhancements for multi image uploading and enhanced image recognition by a community member
- Changed loading of user data in the backend, loaded before only BT form, it checks now for published, but not cart attributs
- Added language switcher and vendor module to public svn
- Function deleteOldPendingOrder changed rules, it deletes P and U state now, if an orderId is given in the cart.
- It is possible to set an OrderId for the cart
- Enhanced PayPal Checkout; Button loader with asnchron fetch
- Enhanced PayPal Checkout; Disabled trigger plgVmOnUpdateOrderPayment completly. Problem, doing a partial refund on PayPal sets the R Order status, which triggers this function, which does a complete refund.
- PayPal removed old debugs, cleaned debug mode, less logging
- HandlePaymentUserCancel sets the order status now on P NOT C anylonger.
- Enhanced the invoice download button. Appears now also if the pdf is not rendered (because it is then rendered for the download)
- Enhanced info messages if safe path is missing
- Fixed display of shipment/payment in order/invoice, if something went wrong (fallback to method name)
- Enhancement for xml update files
Fixes
- vDispatcher adjusted to Joomla 5 by stAn of RuposTel, this means that the recaptcha works again for joomla 5 and also other j4/j5 plugin
- Fix for the styling of invalid checkboxes and tos on checkout page.
- Fixing the "customer_notified" record broke the comments in the mail.
- Fixes for userfields display
- vmURI urlencode replacement for PHP8 created a loop accidently
- #__virtuemart_order_histories table, increased order_status_code to char 3
- Removed js note in cart "unreachable code"
- userfields enhanced function getUserFields, added switch to give query (without ordering by)
- userfields $_fld->type == 'webaddress' returns an URL as <a> html element
- spwizard added function_exists('str_contains') for people using php 7
- Fixed dragndrop for the product view product sorting (by AH)
- Important fix, so that editing an order executes the same filters, actions for userfields like coming from the cart
- Important fix for storing of customfields. Due accidently using the same variable name, it could happen, that the wrong customfield was set
- during the foreach loop on the looped array.
- VmUploader shows for admins a complete path and for users just the file name after successful upload
- Smaller fix in mediahandler to prevent folders used as image
- Enhanced the vmtable, addloggable directly adds setInteger enhanced product table, added variables to be cast to integer
- Removed old arrays in userfields
- Invoice_locked should be fixed. Considers the object/array problem now
- Fix for category dropdown as tree
- fixed product model getNeighborProducts if there is no extra "where", can happen if a shop shows only productdetails
- Increased varchars of column layout of the product table
- Details
- Written by: Max Milbers
- Category: Latest News
- Hits: 5198
[Hotfix Update 4.2.12]
There was a problem with creation of invoices. The Locking boolean was not correctly set and/or wrongly read. At least we know what we have todo next to prevent coding traps.
The focus of this release was to identify and fix bugs. In addition, we added small enhancements for the Joomla 4/5 GUI. Tooltips should work again and opening a VM view in the backend opens the VM menu and minimises the joomla one.
We also invested a lot time in the routing process. It may be necessary to remove setting the itemid per layout file.
Please check this link for details https://dev.virtuemart.net/projects/virtuemart/repository/virtuemart/revisions/10996.
DOWNLOAD VirtueMart 4.2.8 with the Membership
NOW
All tables are changed to InnoDB. VirtueMart used before a mixed set. Tables which are most time just read were MyIsam and tables which are often read and write (like orders) used InnoDB. MyIsam has not been developed further for years and InnoDB has become faster for all tasks (don't pin me down to "all" of them). The provided server configurations won't pay attention to MyIsam (reserved RAM, for example), so now it seems the best time to switch to InnoDB for all VM tables.
We also worked with PayPal Checkout. The merchant onboarding process is sometimes not finished. We found out, that this is caused by popup blockers of the browsers, even without extra popup blocker plugins.
Housekeeping wise, despite all my personal efforts, the email server was still not running right. Reseting password did not work, so I enlisted the aid of our server admin and it is now fixed. Emails were received again at strict hosters. It turned out, everyting in our domain space was configured without www, except the email server. The fix broke emails a day before Easter and unfortunately the holidays meant that we did not identify the issue until a week later. This is software, the idea "Let's do it right, lets update anything" can result in some setbacks.
Thanks to our membership, we could contract Spirous Petrakis of yourgeek.gr and the next release will have a new Bootstrap 5 native VirtueMart template by Petrakis. This is no vaporware, the template will be offered to the core team for beta testing right after the release. Offering it to early would have delayed this important maintenance release.
Another result of the VM membership subscription is the multi image upload written by the team of 911websiterepair.com. It simplifies adding media, if you do not want to manipulate the existing one. But make sure that you store your product first!
General enhanced features
- Multi file image upload by 911websiterepair
- Classes for userfields by Gerald DWP
- Updated product module with option "any product" (by community input)
- Enhanced translation for custom drop down by GJC
- changed MyISAM to InnoDB
Fixes for Joomla 4/5 and PHP8.2
- Fixed seo link of products, category was missing
- Opening a VirtueMart backend view minimises the joomla menu automatically. There is an hidden config to disable it.
- Fixed tooltips in j5
- Updates for TcPDF for PHP8.2
- Added full path for vmvalidator to ensure loading in joomla 5
- Added lost empty option for select product detail layout in product edit
- Revenue, added VendorInformation for interval products
Fixes
- Fixes for router to prevent unecessary "result" in the link and added more views to the whitelist
- Fixed router problems in j4, correct use of the preprocess. itemids are set correctly, removed unecessary or wrong Itemids from the layouts
- CouponHandler fixed foreach for allowed products, allowed categories
- Javascript, replaced all "delegate" against "on"
- Fixed that dropdown could not be used to add the same option twice
- Fixed removeable and draggable enhanced css
- Important fixes in the cart to ensure that the individual cart is correctly linked in the carts array
- fixed update of carts
- Model category, function getParents uses now a language depended cache
- Added itemid to pagination links
- Fixed manual installation of "shipping advanced"
- Small fixes for mediahandler, removed unecessary loads
- Fixed closeBtn to showCloseButton of fancybox
- Fixed checkFilterDir if given filterDir is empty
- Model users, send registration email only, if mail is active
- Fix for customfield Multichild in BE
- Fixed multichild variant with radios
- Fix for storing shipment address as guest
- Better check to allow shopper change, if already switched
- Fixed multichild variant with radios
- CalculationHelper added order by for loading rules
- added missing help icons and other minors for backend views
- Structural core fixes Important fix in VmModel function getData, uses reset if an array of ids is given Important fix for VmController
- function getStrByAcl, uses now the unfiltered POST data
- added vmJsApi::writeJS to correct places.
- calculationHelper added order by for loading rules
and a lot adjustments for php8.2, removed unused or dangerous code
For developers
- orderdone view has now the orderId
- getPluginMethods with new $userId dependence
- product Model added importVMPlugins to begin of function sortSearchListQuery
- added register of vmrouterHelper for autoloading cart helper
- Layout orderdone now set by cart->layout
- enhanced Exception message if sending of email fails
PayPal Checkout
- PayPal Checkout enhanced merchant onboarding. Added notice to disable popup blockers
- Minor fixes for PayPal function updateStatusForOneOrder called by PayPal now with triggers