Forums / Suggestions / Roadmap for 4.4. Any Ideas?

Roadmap for 4.4. Any Ideas?

Author Message

Gaetano Giunta

Tuesday 23 February 2010 11:19:52 am

With 4.3 pretty close to its stabilization deadline, it's time to start the drums rolling for the roadmap that will lead to the next version. Much in the same vein as the open discussion that took place on this forum about the improved admin interface for 4.3, I think the community can contribute in shaping the greatest version-to-be ever.

My own ideas wishes: make 4.4 a developer's best friend - keep improving the new interface introduced in 4.3, but focus on simplifying the developer's job.

  • move the webshop completely out of the kernel into a new extension - a leaner, meaner base install is a boon
  • move all code for displaying/editing templates and the RAD page out of the kernel AND start developing it with: a rad wizard for every feature commonly found in extensions: datatypes, fetch functions, functions, workflow events, cronjobs, etc... merge code from ezgeshi for syntax hilite and from ezcodesniffer for compliance checking
  • set up a proper dependency management framework for extensions
  • allow extensions to install/deinstall tables and data when enabled/disabled
  • improve the interface used for creating and installing packages, making more apparent the distinction from downloaded packages and packages locally created; allowing to create new version of local packages; allowing to pick remote package repos via gui
  • rebase the ez package format on pecl

Principal Consultant International Business
Member of the Community Project Board

Ivo Lukac

Tuesday 23 February 2010 11:48:06 pm

Few simple ones :)

  • include script for adding attributes on classes with many objects (already exists, you just need to put it in bin/php folder)
  • export to csv functions for objects, collections,shop,...
  • pdf export that works good with utf-8 (e.g. paradoxpdf extension)
  • owner changing in admin (owner extension)

http://www.linkedin.com/in/ivolukac
http://www.netgen.hr/eng/blog
http://twitter.com/ilukac

Jérôme Vieilledent

Wednesday 24 February 2010 12:25:27 am

"

Few simple ones :)

  • include script for adding attributes on classes with many objects (already exists, you just need to put it in bin/php folder)
  • export to csv functions for objects, collections,shop,...
  • pdf export that works good with utf-8 (e.g. paradoxpdf extension)
  • owner changing in admin (owner extension)
"

For export, you may take a look at eZXMLExport ;).

About PDF, if 4.3 roadmap has been respected, this will be packaged with eZ Publish 4.3 (based on eZComponent Document).

Here are my votes :

  • Content class inheritance
  • Package system that really works (eg: problems while packaging content objects)
  • Overridable kernel datatypes (datatypes that uses class autoloading system)
  • Idem for event types

Maybe other stuffs that I'll add later :)

paul bolger

Wednesday 24 February 2010 12:30:38 am

This probably doesn't sound very inspired, but I'd like to see a cleanup of the default templates to get rid of all that deprecated code. Maybe support for <section> and the like should be dropped completely in 4.5.

I'd also like to see the ability to hide content classes and image aliases from editors.

And, I'd like a new, stripped down, version of ezwebin. Lose all those extra divs which were added to allow rounded corners - there are better ways to do this now - rationalise the DOM

I'd also like to see some work done on images - make all the indexed images in ezwebin CSS sprites (a default ezwebin install has something like 60 images referenced in the stylesheets, and gets dismal scores in yslow).

Maybe something like this http://jaredhirsch.com/coolrunnings/about/ would be in order.

Paul Bolger

Sébastien Antoniotti

Wednesday 24 February 2010 1:13:46 am

For my part a real dream would be to get the possibility to manage many languages by siteaccess.
So, in a mutlisite/multilanguages configuration, we actually configure siteaccesses like this :

site1_fr
site1_en
site1_it
site1_admin
site2_en
site2_it
site2_admin

It would be nice to manage all languages into one public siteaccess to get this configuration :

site1_public (in many languages)
site1_admin
site2_public (in many languages)
site2_admin

Also, I'm OK with Paul to clean and purify the DOM and if possible reorganize, minimalize and merge the stylesheets provided by default.

eZ Publish Freelance
web : http://www.webaxis.fr

Roland Benedetti

Wednesday 24 February 2010 2:27:54 am

Hi all,
As announced in Geneva, i will try to update very quickly the roadmap from eZ in order to share and give more visibility on what we have been thinking at eZ, as of course, many things are already baking.In the mean time, i'll share some of my/our thoughts in this forum.

Without being too long for now, i can say that we definitely want to continue the good work done with the administration interface rewamp, and willing to involve even more users and all the community in that process (the 1st phase being a bit short for that).

I can also say that, if i agree with Gaetano, the 4.4 should be somehow the developers' best friend, we think it should be the editors' best friend as well (may be even more ?) ! This will remain a very important direction. Bruce and Damien came with some nice suggestions about that, for instance like splitting technical admin role and functionnal admin role, i definitely think we should explore that.

We will also go in the direction of the features discussed in Geneva, where workflow, metadata management, loading tools, user subscriptions and other great ideas where discussed (see http://share.ez.no/blogs/ez/speed-dating-with-15-candidates-for-ez-publish).

On going work on scalability will be done as ever, as we will always try to improve that side of the product !

And finally, no doubt mobile publishing is definitelly growing fast now, we might work on making our platform even more "mobile-friendly" !

Stay tuned and lets try to improve this community platform. A forum is great but we should bring may be new interactive tools like polls or rating.

I'm looking forward to read many other ideas and wishes here !

Roland

--
Roland Benedetti
eZ Systems, Product Management

Jérôme Vieilledent

Wednesday 24 February 2010 2:36:45 am

Thanks Roland

I add my vote on another one :

  • Improve the installation wizard in order to put newly created siteaccesses in a dedicated extension (should be optional I guess)

Karnichi Mohamed

Wednesday 24 February 2010 2:49:48 am

Hi all,

Here are some ideas

  • Getting ride of the spam comments on share.ez.no ;)
  • Online documentation update
  • +1 for cleaning html of the default designs
  • +1 for minimalizing css
  • +1 for a dedicated shop extension ( and why not, turning it into a community project )
  • Cache block expiry by multiple sub-trees
  • Api or Interface for content sharing between multiple eZPublish instances
  • Fixing settings files override order (i have to test for each new version if the order have changed or not, as there are a lot of different point of view concerning this)
  • Creating a dedicated (section/ tab / subtree) for custom settings and utility content objects in eZ Pulbish Admin interface
  • Per environment settings management (nice to have)
  • For all Content Packages use the same langage ( English UK or English USA but not the 2)
  • Per Content Class/Subtree State Groups(permit to assign a Specific object states group to a class or subtree, to simplify default states assignment)

[Update]

A great addition would be to permit override native module view and adding custom views to this ones (clean way to prevent hacks).

Big thanks to eZ crew for their efforts to make eZ Publish stronger faster and better !

http://www.amiralweb.com Certified eZPublish Expert

Nicolas Pastorino

Wednesday 24 February 2010 2:58:54 am

"
  • Getting rid of the spam comments on share.ez.no ;)
"

Hehe, yes, it is planned to address this, definitely :)
Sorry about the pollution.
Cheers !

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Jérôme Vieilledent

Wednesday 24 February 2010 3:18:42 am

"
  • Per environment settings management (nice to have)
"

Check out NovenINIUpdate ;) !

Karnichi Mohamed

Wednesday 24 February 2010 4:22:44 am

@ Jérôme I know about this extension : the matter here is to simplifiy developpers work, so it would be better if it was native :) .

http://www.amiralweb.com Certified eZPublish Expert

Jérôme Vieilledent

Wednesday 24 February 2010 5:19:48 am

I can only agree with that :)

Doug Brethower

Wednesday 24 February 2010 6:33:53 am

Gaetano, thank you. 5 stars is highest rating, yours deserves 10, can we vote twice? Hits every nail squarely on the head for my wishes from dev side.

Only addition is some where, some how, some time, clear documentation for newcomers. My preference, make the installation choices ezwebin, ezflow, learners. Within learners provide a self-contained, no linking out, no references to past versions, 10 step tutorial to cover care and feeding of eZ for user with assumption user has no html-php-database knowledge. Only that they can read, basically.

Simple is the key. Sooner comes simple, sooner get newbies valuable insights and convert them to project members.

Cheers!

Doug Brethower
Apple Certified Technical Consultant, Southwest, MO USA
http://share.ez.no/directory/companies/lakedata.net

Nicolas Pastorino

Wednesday 24 February 2010 6:56:00 am

"

Only addition is some where, some how, some time, clear documentation for newcomers. My preference, make the installation choices ezwebin, ezflow, learners. Within learners provide a self-contained, no linking out, no references to past versions, 10 step tutorial to cover care and feeding of eZ for user with assumption user has no html-php-database knowledge. Only that they can read, basically.

"

Hi Doug,

I support this approach, driven by the will to have great and simple educational content for beginners. This was already detailed by yourself there, in a great way : http://share.ez.no/forums/general/decreasing-time-required-to-grasp-ez-publish.

These "step-by-step-for-beginners-concrete-tutorials" should also make their way in share.ez.no's tutorials database. They could be linked from the "learners" package you are evoking, but need to be present here as well.

Keep up the good momentum,
Cheers !

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Jorge estévez

Wednesday 24 February 2010 9:38:12 am

Hello,

 

It’s sometimes hard, even for older developers to grab ideas scattered all over forums and comments on how to do simple and complex tasks, even more tedious is dealing with information for different ez versions, projects already published (extensions) and the ones that are being developed at a current stage.

 

I think there could be a new forum (or similar way) of knowing “How to’s” that will lead us to know simple and complex tasks.

 

There are so many features in ez that trying to understand all is impossible so when a new challenge is faced in a new project that involves an ez site you end up with a headache just searching and joining all pieces of information together (and sometimes we end up with a not so good solution at all)

 

It will help the newbies and older users to know the possibilities that ez could add to their projects and ease the information flow of discovering things that we could do that goes beyond our current knowledge, it could help newbies to get ideas on how ez can solve problems and thus compare the advantages and disadvantages of ez with other open source CMS’s.

 

A topic in a forum (or else) of “How to’s” could have links to extensions, new projects arising, pieces of code… and if moderated have their own roadmap to follow and contribution by the audience.

 

thank, keep it running ez

Diseño Web Cuba
Web Design Cuba
www.elfosdesign.com

Nicolas Lescure

Wednesday 24 February 2010 2:37:24 pm

I'd like :

  1. Workflow improvement : more native workflows, more triggers, user friendly interface for managing drafts/waiting contents/validations
  2. An easy way to manage staging (no more buggy packages please)
  3. Improve & debug ezsurvey
  4. Policies on attributes

Thanks :)

Jorge estévez

Wednesday 24 February 2010 3:34:28 pm

Yes::: Policies on attributes, How could I forget that...

Diseño Web Cuba
Web Design Cuba
www.elfosdesign.com

Jérôme Vieilledent

Wednesday 24 February 2010 11:27:57 pm

Policies on attributes : +1

Gaetano Giunta

Thursday 25 February 2010 1:15:13 am

@all: per-environment settings management

This is imho already possible: when there are not many siteaccesses in use, you can create a version of the siteaccesses per environemnt (eg. front_dev, front_test, front_prod, admin_dev, admin_test, admin_prod). It is true that it forces to have a lot of duplicate files and not to put stuff in settings/override that really belongs there, but I found it a simpler alternative to set up than cretating ad-hoc deployment scripts every time. But in the end what i think we need here is a settings system based on tags: for every setting it's not the file where you read it that decides the weight it has but a tag, eg. Dbname\override=thisandthat. But this is a topic that has already been discussed for a while (here and in the issue tracker), and it deserves a thread of its own. Maybe staring with writing down all the use-cases for the revamped ini system?

+1 for autoloading datatype php classes - also keep removing all the manual inclusions of php files everywhere (eg. for template operators/functions too)

+1 for allowing setup wizard to create a new extension with the siteaccesses if user desires so. More important: let the setup wizard ask if there needs to be user-login and user-registration to public siteaccess and disable it otherwise

+1 for cacheblock expiry by multiple subtree, but also by single node

@paul bolger: "hide content classes and image aliases from editors" - can't you just hide content classes via the roles & perms system? what do you want exactly here?

+10 for creating a new top-level node where content-related objects are put. It might be the design, after all (hey, it already exists!). Give it a tab on its own, just like media, maybe rename the tab to 'structure', show treemenu on the left and start using it. The great advantage being of course that all stuff put in there has no url_alias direct access and resides by default in a section of its own: extra bonus for security

extra workflow events: easily doable, in fact I've been thinking about grouping the existing ones in different public extensions in a single new extension

better management of staging/prod sync: improving the package system goes a long way towards that goal (eg. allow class definition to be upgraded without loosing existing content; allow package wizard to create new versions of existing packages, etc...)

Principal Consultant International Business
Member of the Community Project Board

Ole Morten Halvorsen

Thursday 25 February 2010 1:26:21 am

My 2 cent:

  1. Support for data migrations (allow data to move from development -> staging -> production)
  2. See #1

Currently deploying changes to existing classes, new objects, etc is a major PITA. The goal should be to allow for 100% automated deployments with support for rolling back changes.

We currently use Capistrano + Git to deploy websites, however changes to the DB have to be manually carried across. Not to mention the hassle of node and object ids and the fun of them being different on production vs staging vs development and the headaches that causes.

In some of our bigger enterprise sites it takes almost more time deploying new features than we spent developing them.

Ole

Senior Software Engineer - Vision with Technology

http://www.visionwt.com
http://www.omh.cc
http://www.twitter.com/omh

eZ Certified Developer
http://ez.no/certification/verify/358441
http://ez.no/certification/verify/272578

eZ debug

Timing: Jan 17 2025 22:03:51
Script start
Timing: Jan 17 2025 22:03:51
Module start 'content'
Timing: Jan 17 2025 22:03:52
Module end 'content'
Timing: Jan 17 2025 22:03:53
Script end

Main resources:

Total runtime1.1872 sec
Peak memory usage4,096.0000 KB
Database Queries285

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0077 588.8359180.8359
Module start 'content' 0.00771.0661 769.67191,221.7109
Module end 'content' 1.07380.1132 1,991.3828379.1172
Script end 1.1870  2,370.5000 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00380.3198210.0002
Check MTime0.00140.1151210.0001
Mysql Total
Database connection0.00120.100410.0012
Mysqli_queries1.021586.04982850.0036
Looping result0.00290.24252830.0000
Template Total1.153697.220.5768
Template load0.00270.223620.0013
Template processing1.150996.947520.5755
Template load and register function0.00010.008310.0001
states
state_id_array0.00120.099710.0012
state_identifier_array0.00110.096820.0006
Override
Cache load0.00290.24131900.0000
Sytem overhead
Fetch class attribute can translate value0.00180.1486130.0001
Fetch class attribute name0.00100.0875300.0000
XML
Image XML parsing0.01481.2467130.0011
class_abstraction
Instantiating content class attribute0.00010.0055370.0000
General
dbfile0.01591.3377850.0002
String conversion0.00000.000730.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
17content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
20content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
31content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
10content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
8content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
4content/datatype/view/ezxmltags/quote.tpldatatype/ezxmltext/quote.tplextension/ezwebin/design/ezwebin/override/templates/datatype/ezxmltext/quote.tplEdit templateOverride template
3content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
6content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezxmltags/strong.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/strong.tplEdit templateOverride template
2content/datatype/view/ezxmltags/ol.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ol.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 106
 Number of unique templates used: 12

Time used to render debug report: 0.0003 secs