[TYPO3-core] (New) TYPO3 CMS Vision

Thomas Maroschik tmaroschik at dfau.de
Mon Aug 18 10:05:49 CEST 2014


Hi,

due to lack of time I have to cite a mail I've recently written, but it 
fits the topic. I am and was always an advocate for integrating Flow 
into CMS. Mostly due to the fact that creating a unified ecosystem 
should be our most important goal. But now my vision shifted slightly to 
include the broader PHP world instead of only our own one.

Read on what I wrote:

CMS is to me currently an „over-feature-complete“ that struggles to move 
forward due to it’s legacy. Many concepts there aren’t used widely 
anymore and still have to be maintained for this one single customer 
somewhere. The ACs fear removing features because it could also mean a 
loss of customers. Personally I don’t fear that because new features 
will evolve faster out of a lean code base and this could attract either 
some new or existing customers again.

I recently talked about our CMS architecture and how Conway’s law 
applies to it: http://en.wikipedia.org/wiki/Conway's_law
In it’s roots it’s just a big ball of mud where everything depends on 
everything and this may be due to it’s roots in a single person building 
that. Then more and more people joined the project and had basically 
access to all parts at once. This means even if the architecture is 
virtually based upon extensions the interdependencies between system 
extensions are terrible due to the fact that everybody may speak to 
everybody. In order to reduce this for the future we try to build those 
CIGs that oversee some substantial part of the system and communication 
happens via those aggregated channels.

Looking at Flow Conway’s  law applies to it too. Although it’s a smaller 
mudball than CMS it’s structure reflects strongly the communication 
structure of the team that has grown around Robert and Karsten.

Further my experience from the TYPO3 camps and Developer Days is that 
the biggest part of our „Developers“ out there are rather integrators. 
And they have a hard time to follow the becoming more and more complex 
products. Many of them have never written a single line of PHP or used 
ever the CLI but are willing to contribute and use our products!

So after spending the last two years with thinking about our ecosystem 
and talking to all product teams and users I personally see complexity 
as our biggest issue in our ecosystem.

We have very complex products, complex solutions around them 
(Gridelements, Surf, Fluid), complex team structures, complex workflows 
(Forge, Wiki, Gerrit, Jira, SSO), complex communication (as identified 
in the OSS watch workshop), …

I’m rather unsure now if integrating Flow in CMS is a big benefit for 
those users mentioned above as it makes CMS again a bit more complex to 
understand. Do they care about whatever runs their stuff as long as it 
runs and has their desired output?

I think CMS success story began with extensions/components/packages. 
People that were generalists could compose their system from components 
built by specialists and connect them in a defined way. This was a great 
approach as it lead to plenty of extensions and people building webpages 
in days instead of months. An impressive return on invest.

Currently I have the feeling that we lost the momentum and our products 
become fatter and fatter. A solution to that situation would be to 
decompose the products and enable people to combine things again as they 
need it. It would also be beneficial in keeping our core domains in our 
products clean: extensibility, storage and editing interface.

This is why I’m currently rather working on integrating composer 
strongly in Flow and CMS. We had a meeting on the DDs where some people 
from the CMS and Flow team have been asked by me if we want to commit 
fully to a composer based ecosystem. You can compare that to a 
conference in 1866 in Bern where Germany, France, Switzerland and other 
European countries tried to align upon a common rail standard. The 
standard here is already adopted by large parts of the PHP ecosystem and 
if we commit we could integrate more and more components from this 
ecosystem as maybe in the mid future vice versa.

While this sounds great on the paper we may not forget our integrators 
which are not familiar with the  command line where you interface with 
composer. This lead me to the proposal of building a Web UI on top of 
composer and ship it as an easy package. That would reduce complexity in 
a way that all our products won’t need an extension manager anymore but 
will use that single package where substantial parts are maintained by 
the whole php community. It would be also an interesting product for the 
php ecosystem as well, as this thing could be a one click installer not 
only for our products.

Currently our TYPO3 ecosystem relies upon centralized structures. We 
have for extensions the TER, Forge, Mailinglists, Git and SVN hosting. 
Back then there was only sourceforge which was ugly and we wanted to 
give our ecosystem a "one stop shopping“ solution to build their 
extensions. But it’s hard to maintain stuff that is solely used by 
people which are unable to contribute to that platforms. Meanwhile
there are plenty of services which do a better job for those like 
Github, Bitbucket, private Gitlab and so on. Many extensions already 
don’t use the TER anymore for distribution and ask their users to 
download their current version from github.

Composer flips that around and is just a directory to a decentralized 
structure. In the end it let’s the contributors of the ecosystem choose 
their own tools that will be maintained by themselves. This is great, 
because it’s agile. If you see a chance to improve your process you can 
do it without the need to ask someone. This could in the end help us to 
reduce complexity again. We don’t need to maintain forge, gerrit and 
more stuff for our ecosystem anymore because we are connected to the php 
ecosystem which could evolve unlike us without such centralized structures.

After all I hope this step leads to the mentioned decomposition of our 
products because the demand from the php ecosystem will be there. We 
have some unique properties in the products other projects are eager to 
get and this could enable them to contribute to the decomposition process.

So my personal vision for TYPO3? An ecosystem of great people that build 
and maintain small, focussed solutions which are then composed 
creatively into distinct products. We’re not running a company, we’re 
running a marketplace!

Greetz,

Tom


-- 
Thomas Maroschik
TYPO3 CMS Active Contributor

TYPO3 .... inspiring people to share!
Get involved: typo3.org


More information about the TYPO3-team-core mailing list