Why SaaS vs. Open Source doesn’t have a clear cut answer
Photo by Omar Flores on Unsplash

Why SaaS vs. Open Source doesn’t have a clear cut answer

As someone who I hold in high regard once said: "Commerce is always Custom".

Every webshop out there has some form of customisation. This might be as little as a Payment and Shipping integration, or a connector to the bookkeeping software, but often the customisation is more extensive, for example:

  • A frontend with the company's branding, with a bespoke design
  • Improved search often going beyond catalogue content
  • Pulling in extra data on the product detail page
  • Integrating a PIM, ERP, WMS, and other systems with three-letter acronyms
  • Advanced tax and duty calculations
  • Internationalisation and localisation

And the list can go on.

A webshop does not operate in a vacuum. It needs to integrate with business processes, and is tailored to its consumers' expectations and wishes.

With that in mind, I’d love to address some of the myths that SaaS providers seem to perpetuate about their products and services. This is not to prove Open Source is inherently better, this is to underline that building an online retail operation on SaaS is subject to some of the same risks as Open Source. As such, all options should be evaluated when choosing a solution.?

As a note, the following opinions are my own. You are more than welcome to disagree with me. There are no absolutes however, so let’s keep away from “wrong” or “right” discussions. Just share your views. In my opinion any ecommerce application landscape will contain a mix of SaaS and Open Source products blending the best of both worlds.

To start off, let's have a quick look at the two terms, since they’re quite broad and often used in different ways. With SaaS, we describe software which is delivered as a service. It does not require the owner to take care of hosting, and the licence covers usage, not ownership of any kind. This means, the owner does not have access to the code, or is able to modify functionality. These services are generally offered via a website, with an online interface. And a set of APIs to integrate with.

Open Source describes software of which the source code is accessible and can be modified by a developer. Open Source software doesn’t mean “free”. While many Open Source platforms offer a free tier, most will have paid tiers that ensure the software is maintained by the company behind it. These platforms offer enterprise level SLA’s and support. However, even the licensed source code should be open to modification.

Without a doubt, if you can find a SaaS solution that covers all your needs with minor configuration tweaks, and the licensing cost is within your budget range, this is the solution you should go for. It keeps you from having to deal with

  • issues with incompatible software when upgrading
  • different parties for platform, development, and hosting
  • unpredictable cost of ownership (as long as you fall within the same licensing tier of that platform)

However, in reality this seldom happens. A webshop will need frontend customisations, features, and functionalities for end users, but also requirements to comply with local law and regulations for the countries in which they operate. These require templates, plugins, and integrations that might, or might not, be available via an ecommerce platform's store or marketplace.

Customising a SaaS stack

With adding these, we start to introduce dependencies though.

The template is built by a third party that might or might not have implemented it following best practices. The integrations for shipping, or sending marketing emails are custom software, Black Boxes, developed and run by teams that might or might not keep security in mind. And while their API connection to the ecommerce platform might not require quarterly upgrades, that doesn’t mean they don’t need upkeep. Backwards compatibility does not cover new functionality, which could mean an inability to use new platform features because 3rd party services do not support them. And over time features and API endpoints might be deprecated in favour of new, better functionalities in the ecommerce platform.

While we can argue a service would be kept up to date, there can be a myriad of reasons why a team would not be able or willing to build new features. A low Return On Investment might not allow it, war or pandemics might impact their teams, a developer might decide to focus on something else, and companies might be acquired.

And of course, there is a limit to what we can do with 3rd party templates, services, and integrations. These are built to cater to the common denominator of requirements. While they might cover most of your requirements, they certainly do not cover all.

For that we engage agencies, or hire in-house teams. Each platform has Implementation Partners who facilitate these custom projects. These agencies develop custom applications on top of SaaS platforms to cover the specific requirements. Often a “Composable Commerce” approach is used where several SaaS services are tied together under a “Bodyless” PWA, or SPA, frontend.

These services are connected together using so-called “glue code”. Custom code, writing specifically for the project with the express purpose of connecting and acting as adapters. This software however, does require hosting, managed much like hosting for Open Source software. As well as an agency that maintains and updates the software.?

This custom software is now critical to the operation of the ecommerce landscape, without it functioning properly your frontend would not work, or stock might not get updated. Thus negating much of the benefits touted over choosing for Open Source.

And this is where I would like to draw your attention to the similarities between using an Open Source platform, versus customisations built on top of SaaS. While we might not need to upgrade, for example, our ecommerce platform, we would still need to maintain and upgrade the custom code.?


When a case can be made for Open Source platforms

Recognizing that eCommerce requires customisation, there are benefits to be had from Open Source. By no means Open Source should be the answer to any functionality needed in an ecommerce build. It’s a solution which should be considered when customisation is needed.

Developing customisations within a framework or platform ensures that every developer trained in that solution, will be able to understand and work on those customisations. Frameworks are there to give developers a set of tools and standards to develop their solutions against.

It also allows us to grade that work: Does it follow coding standards, best practices? And is it built by a developer with a track record on that framework, or certification? It enables the merchant to decide to move to another Implementation Partner without having to replace large swaths of code.

Custom code, built on top of SaaS services, does not have these guard rails. There is no requirement on how this code is written, what quality standards it is held to, or even which language to use.?

I would be remiss though not to address the topic of upgrades of Open Source software. I’ll be the first to recognise the pain of upgrades having worked for 15 years in this field. However we have learned there are ways to minimise the impact. Follow framework best practices, write clean code, be wary of adding too many 3rd party plugins, all help facilitate easy upgrading. And upgrade early and often, making sure the platform keeps updated.

And last, consider if a new feature should be added as a custom piece of code, or to combine Open Source development, with offerings of SaaS services.

I’d argue it’s generally accepted in the ecommerce space that it makes little sense to build product search, or AI powered recommendations bespoke. In most cases, the SaaS services out there deliver more value.

“Open Source platforms need to be hosted, SaaS doesn’t”

I want to start off by making it clear that while a SaaS platform doesn’t need to be hosted by the merchant, this doesn’t mean a solution built on top of SaaS wouldn’t need hosting.

The custom code written to tie in the various services, and cater to bespoke business needs still needs to be hosted as well, negating the argument that SaaS solutions prevent the need for dealing with hosting.

But ignoring this, “On Premise” or “Self hosted” solutions are rarely hosted by the merchant themselves. Instead we rely on specialised hosting companies with solutions built for these platforms. These hosting companies understand the application, and will be knowledgeable in scaling and performance, with the added benefit that if a hosting partner does not live up to expectations, one can choose to switch partners. This approach empowers brands to? decide in which geographical location to store data and who has access to it.

The hosting company often acts as a 24/7 point of contact for issues, and will work together with the merchant's agency or in-house team.

And while they might charge for a bigger server when scaling is needed, they do not impose API rate limits, or take a percentage of each order.

“Open Source monoliths create lock-in”

While I’m not gonna dispute that replacing or replatforming, even just a part of the stack, generally is a monumental challenge, I would like to address the myth that this is an inherent characteristic of Open Source platforms, or monolithic architectures for that matter. Or that Open Source, monolithic, platforms make it difficult to follow some of the Composable Commerce principles.

While a SaaS platform (split up in microservices that are all API-first) might, in theory, make it easier to swap parts of your complete stack such as search or product management, it seldom is that straight forward.

Every solution, SaaS service, and platform comes with a very specific set of features. These features often overlap between services, for example search engines often contain personalisation and recommendation features, or leave gaps when for example a content management platform lacks a robust Digital Asset Management functionality.

This means when replacing functionalities we will need to address these overlaps and gaps with custom code and extra SaaS services.

With any architectural approach, attention should be given to introduce sufficient separation of concerns, abstractions, decoupling, and documentation to later on have the ability to replace functionality. Microservices,?

And when talking about data ownership Open Source offers a clear and competitive advantage in many cases. Most SaaS puts limitations on extracting data, which can lead to data loss when switching to a new platform or SaaS service. As a merchant, it has to be understood that your order data, customer data, and product data are your greatest assets. It’s what truly holds value.

Alessandro Ronchi put it well when likening it to buying a music CD versus using Spotify.?When buying the CD, we own that music and have unrestricted access to it. On Spotify however, we rent the access to it as long as we pay. This isn’t inherently a bad thing, if that decision is made consciously, and we are aware of the implications:?

  • When we discontinue our licence to SaaS platforms, or even downscale the licence, we could lose access to the data.?
  • SaaS platforms often retain rights to data. They can use it for their own means, and share it with 3rd parties.
  • There is no definitive control over where data is stored, who can access it, and what it is used for.

It does underline one of the reasons companies choose Open Source. It’s not per se the code they want to own. It’s the rights and access to their data.

When to use what

I’m not going to pretend there is a clearcut set of rules to decide on the right solution. What I would like to impart on you, the reader, is the need to critically evaluate solutions.

Consider how customisations are addressed, where your bespoke business logic lives, and what gaps need to be covered when choosing for specific platforms. Your ecommerce application landscape will, most likely, benefit most from a blend of solutions.

Don’t count out Open Source just because of the SaaS hype.

For another view on the matter, I recommend reading this article by Guido Jansen as well.

Jhaanvi Agrawal

Digital Marketer

8 个月

Sander, thanks for sharing! Pleasure meeting, you look for connecting with you! Keen to hear about your next post.?? Speak to you soon, Jhaanvi ADFAR Tech ??

回复
Rafael Corrêa Gomes

Digital Commerce Expert | Adobe Commerce | Technical and Strategic Leadership for Business Success

2 年

Excellent article Sander. I liked the business / technical analysis of the trade-offs you did. Thank you for sharing your insights.

Filip Rakowski

Co-founder & CTO @ Alokai | Modernizing eCommerce frontend-first, without risk | MACH Tech Council Member | Forbes 30 under 30 | YC Alumni (W21) | Vue.js CMTY Partner

2 年

Excellent article Sander Mangel! I had similar thoughts when I've read the post you're replying to here!

Igor Miniailo

Principal Enterprise Architect

2 年

Great article, Sander!

Wouter Dieters

AI bedrijfsadviseur gespecialiseerd in workflowoptimalisatie & -automatisering | Praktisch, analytisch & resultaatgericht | MKB | B2C & B2B | Benelux & DACH | 15 jaar+ eCommerce & 5 jaar+ AI

2 年

Sander, thanks for sharing this article! I will share it within my network as well.

要查看或添加评论,请登录

社区洞察