Forums / Suggestions / Package system

Package system

Author Message

Jan Borsodi

Thursday 24 July 2003 1:19:14 am

For eZ publish 3.2 we are currently working with the new class import/export system. For the basis of this we are starting the work on a package system which could be used for handling any kind of contributions or site exports.
For 3.2 we will only have time for the class (with templates) export.

A short overview of the package system.
Central to the system is the package definition which is an XML format defining what the package contains, who made etc, what is required for it to work etc.. It's loosely based on the RPM and PEAR package formats.
The package definition will be placed in an archive file of some sort. We will probably use tar.gz or zip files (maybe both).
A document of the package format will be added at a later time.

Here's some of my ideas on how the package system should work (in the future).

1.
Create a package module which will store all package data in db tables.
For instance you will start a new project/package, create a new release and add entries to the release.
Possible entries are just about anything the eZ publish system has available. For instance you could pick classes for export, nodes/objects with children, datatypes, workflowevents, modules, design and plain files.
You could manage documentation for the package using eZ publish objects and export it to a general xml format which is included in the package.

Since all data is in the DB you can go back to the project, improve you templates or add new entries to the class and then create a new release and export the package again.

2.
Allow people on ez.no to start projects. They could request a custom eZ publish installation in which they can do development, create new datatypes, new modules etc. all from the web browser (or with webdav, soap).
When they are making a release they would export the package file and send a soap request (automatically) to ez.no for upload to contributions.
I think this would boost development of eZ publish parts and it would also make it easier for many people to work together on a project.

3.
Detect packages in contribution upload. If it is detected a more advanced page is shown with all relevant information from the package. This avoids the need to repeat changelogs and descriptions which are already in the package.

4.
Allow the package system to work with svn, it could for instance fetch the difference between two revisions and include the diff in the package.
This would make it a lot easier to create security and important bugfixes.

5.
Download new packages from ez.no. This can be addons made by eZ system or contributed packages by the community.

Any comments?

--
Amos

Documentation: http://ez.no/ez_publish/documentation
FAQ: http://ez.no/ez_publish/documentation/faq

Paul Forsyth

Thursday 24 July 2003 1:42:32 am

Sounds good, Jan.

Im a little worried that there wont be an import facility in 3.2 for the exported classes. Can you clarify this?

How soon after 3.2 can we expect objects to be packaged in this way?

paul

Jan Borsodi

Thursday 24 July 2003 1:45:49 am

3.2 will come with an import facility for class exports. If not the exports would be useless ;)

--
Amos

Documentation: http://ez.no/ez_publish/documentation
FAQ: http://ez.no/ez_publish/documentation/faq

Paul Forsyth

Thursday 24 July 2003 2:07:40 am

Yes, i saw that. Had to ask the question though :)

Once the class import/export is complete will the matter of implementing the object part be straightforward, and come not long after the release of 3.2?

Having class export/import is v good, but having this work with objects is v important.

paul

Jeroen van Gorkum

Thursday 24 July 2003 2:09:22 am

this worries me a bit from an administration point of view.

* is a package only allowed to make changes / add to the database, or to the filesystem, too?

* would it be possible to revert to the state before the import completely?

* what if 2 packages 'depend' on each other, i.e. package 'x.a' is an extension to package 'x', and i uninstall them in the wrong order (x first), or only uninstall 'x'?

jeroen.

Tony Wood

Thursday 24 July 2003 2:41:55 am

I think one of the things to look out for with the package system will be the varying versions of eZ that people use. Some project are developed using 3.0 some 3.1 etc.
If I produce a package that only works with 3.2 because it uses widget x, then this will break any version 3.1 systems.

I think the package system needs
1. Each package needs a list of eZ versions it compatible with.
2. List possible/know conflicts. Manually tasks etc
3. List if it requires extra components and may download of list them. I am guessing that many packages will be conduits to other systems.
4. System version PHP, MySQL versions.

I think there needs to be a test and safe upgrade option for eZ. This should be as automated as possible, with checks and warnings where manual intervention is required. It does raise a problem though, this will not work if major changes such as overrides are implemented in every release ;-)

tony

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Jan Borsodi

Thursday 24 July 2003 6:53:52 am

We've already thought about dependencies etc.
I'll add the 'example' xml format as a document so you can see what our current ideas are.

--
Amos

Documentation: http://ez.no/ez_publish/documentation
FAQ: http://ez.no/ez_publish/documentation/faq

Jan Borsodi

Thursday 24 July 2003 7:16:43 am

First version of the document here:
http://ez.no/developer/ez_publish_3/documentation/incoming/package_format

--
Amos

Documentation: http://ez.no/ez_publish/documentation
FAQ: http://ez.no/ez_publish/documentation/faq

Zoltan Szabo

Sunday 27 July 2003 10:03:05 pm

Please don't forget about PostgreSQL users...

Tony Wood

Tuesday 29 July 2003 4:46:31 am

Could the package system also include a database integrity checker, this would ensure all the correct database changes have been made for the package and the version of eZ they are running.

This would be a useful standalone tool for developers anyway.

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Jan Borsodi

Tuesday 29 July 2003 1:37:22 pm

Database integrity checks is important. They fit right into the <require> part.

And the package will be made to work with any database eZ publish supports. PostgreSQL users should not worry ;)

I'm also thinking about having interactivity in the packages. For instance for an object import you could asked to choose the starting point of the import.

--
Amos

Documentation: http://ez.no/ez_publish/documentation
FAQ: http://ez.no/ez_publish/documentation/faq

Tony Wood

Thursday 31 July 2003 1:53:18 am

Could you explain this interactive element further Jan, I don't see what you mean.

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Paul Borgermans

Thursday 31 July 2003 2:08:42 am

>I'm also thinking about having interactivity in the
>packages. For instance for an object import you could
>asked to choose the starting point of the import.

Great,

I assume you mean here the entire xml archive to be relocated. Do you have plans/ideas to do this in a fragmented way (different object trees in the xml archive are relocated to different nodes)?

Or maybe this is better left to other tools that can manipulate the xml archive, like mapping attributes to a different class than the original. Or maybe even extract parts of the data from the xml attribute text fields which could be stored in other dedicated attributes.

Regards

-paul

eZ Publish, eZ Find, Solr expert consulting and training
http://twitter.com/paulborgermans

eZ debug

Timing: Jan 18 2025 04:11:58
Script start
Timing: Jan 18 2025 04:11:58
Module start 'content'
Timing: Jan 18 2025 04:11:58
Module end 'content'
Timing: Jan 18 2025 04:11:58
Script end

Main resources:

Total runtime0.1663 sec
Peak memory usage4,096.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0088 588.7031180.8516
Module start 'content' 0.00880.0040 769.5547113.8203
Module end 'content' 0.01280.1534 883.3750551.0156
Script end 0.1662  1,434.3906 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00362.1612200.0002
Check MTime0.00130.8063200.0001
Mysql Total
Database connection0.00271.595510.0027
Mysqli_queries0.117670.70231410.0008
Looping result0.00130.75961390.0000
Template Total0.153192.110.1531
Template load0.00070.413310.0007
Template processing0.152491.677410.1524
Override
Cache load0.00050.298410.0005
Sytem overhead
Fetch class attribute can translate value0.00140.832410.0014
XML
Image XML parsing0.00060.386610.0006
General
dbfile0.00321.9261200.0002
String conversion0.00000.003730.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
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0003 secs