Forums / Suggestions / Give projects some love

Give projects some love

Author Message

Xavier Dutoit

Thursday 08 November 2007 10:23:50 pm

Following Tony's cry.

Same needs applies, and most of the suggestions about contrib can apply on projects as well, after the merge (next week ?).

X+

http://www.sydesy.com

Paul Forsyth

Friday 09 November 2007 1:42:59 am

Should we ask eZ to provide an activity list e.g: http://sourceforge.net/top/mostactive.php?type=week?

Paul

Heath

Friday 09 November 2007 2:07:22 am

Fantastic!

That is a great idea Paul, I second the idea.

With a little more notice on which projects are most active.

This might just increase activity on projects through friendly competition :)

Cheers,
Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Paul Forsyth

Friday 09 November 2007 2:14:42 am

Added as an enhancement:

http://issues.ez.no/11878

Gaetano Giunta

Friday 09 November 2007 7:10:33 am

One other thing that would be nice: have extensions to specify their db compatibility besides the ususal ez version.

As most extension developers likely not very interested in this, it could be made a mandatory attribute:
N/A - no db needed
Unknown
mysql
oracle
postgres

btw: Filed under bug id #011883

Principal Consultant International Business
Member of the Community Project Board

Tony Wood

Friday 09 November 2007 9:07:02 am

Great!

Lets spread the Lurve!

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

kracker (the)

Sunday 11 November 2007 11:13:07 am

<i>@Gaetano Giunta</i>

We were under the impression that the design of the eZ Publish would free most extensions from general database specific requirements.

eZ Publish already provides detailed requirements for databases (and versions) which may be used such as MySQL, Oracle, PostgreSQL.

eZ Publish extensions traditionally make use of the database abstracted through eZ Publish.

So unless your greatly pushing beyond standard use of eZ Publish the 'db compatibility' requirements are specified by eZ Publish so asking each extension to document this detail seems to me to be a trivial notion of duplication only bound to introduce further confusion rather than reduce it.

Certainly extensions which do truly have specific requirements should indeed document these unique requirements, yet for almost all extensions currently this is not necessary or applicable (IMHO).

<i>//kracker

Blink 182 - I Miss You | Gwen Stephani - Whatcha Waiting For | Kanye West - Stronger ...</i>

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Gaetano Giunta

Sunday 11 November 2007 12:49:36 pm

Sorry, but this is just wishful thinking.
To do real cross-database development there are about a thousand abstractions that the library in us must provide, eg:
- a string concatenation operator
- a string escaping function
- some functions/schemas to define tables, indexes and sequences
- datetime functions
etc...

the ez db lib provides most of those (except for the datetime stuff, since times are treated as integers), BUT...

...as soon as you are allowed to write SQL in your code, you have huge chances of breaking some database.
The most basic example being: "SELECT NAME FROM EMP AS E, ..."
The "as" for table names is ok with postgres and mysql, but it is a fault with oracle.
If you start looking at native string manipulation functions or, worse, bit manipulation functions, you will find that different databases have different function names.

So the careless developer, wh coded his extensions and relased to the community without ever getting paid for proper testing and docs, is likely to never have tested his code with oracle, and compatibility is far from being guaranteed.

Principal Consultant International Business
Member of the Community Project Board

Sunday 11 November 2007 1:44:31 pm

I <i>challenge</i> Gaetano to cite at least five existing eZ Publish extensions which are affected by this problem. Developers are supposed to use the API and -not- write sql directly.

Gaetano Giunta

Sunday 11 November 2007 2:20:48 pm

Hey guys, take it eZ.

I never said that I know for a fact that any single given extension is not compatible with Oracle or Postgres. In fact, I would be very happy to find out that it is not the case.

But I ran a quick grep for "arrayquery" on my harddisk and found sql embedded in:
ezapprove2
ezlabel
ezmedia
eznewsletter
ezodf
ezwebin
(note: not "wrong" sql, just plain sql)

I have not at the moment a full svn copy of all the community contributions, but my educated guess is that at least some of those do manipulate sql queries.

Principal Consultant International Business
Member of the Community Project Board

Paul Forsyth

Monday 12 November 2007 2:25:20 am

I think Gaetano has a good point. Certified extensions cost more when the db is 'touched' and by clarifying when the api is not used for db access it will be very clear what the risk is with an extension.

The automated approval tool should be able to work this all out to be honest which would make auto-generation of stats a doddle.

Paul

André R.

Wednesday 14 November 2007 3:07:45 pm

Mummy: All extensions that need some extra database table needs to do this, and I don't think that will improve much before we switch to persistantObject from eZ Components (but even then you will always have edge cases)

Gaetano Giunta: isn't 'as' a fairly standard sql functionality, do they have support for it in more recent versions? How do you normally do queries on oracle where you need to relate to 1 table several times?

Maybe a tested on / certified for: mysql/pgsql/mssql/oracle thingy??

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Gaetano Giunta

Thursday 15 November 2007 12:14:07 am

<i>isn't 'as' a fairly standard sql functionality, do they have support for it in more recent versions? How do you normally do queries on oracle where you need to relate to 1 table several times?</i>

SELECT ... FROM TABLE1 T1, TABLE2 T2, etc...

this is supported on all other rdbms, so it is really a no brainer.
AS is still supported (and needed) to alias names of select items

Principal Consultant International Business
Member of the Community Project Board

shekhar sarkar

Monday 19 January 2009 11:43:35 pm

hi guys,

The above article is nice. I know little bit about it. I want to know more about it. Thanks

NYK

From Tony: If this is not Spam let me know. Otherwise it will be deleted.

eZ debug

Timing: Jan 17 2025 23:48:02
Script start
Timing: Jan 17 2025 23:48:02
Module start 'content'
Timing: Jan 17 2025 23:48:03
Module end 'content'
Timing: Jan 17 2025 23:48:03
Script end

Main resources:

Total runtime1.0784 sec
Peak memory usage4,096.0000 KB
Database Queries241

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0053 587.7031180.8438
Module start 'content' 0.00530.9626 768.5469964.1250
Module end 'content' 0.96790.1104 1,732.6719360.3672
Script end 1.0783  2,093.0391 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00460.4306210.0002
Check MTime0.00170.1581210.0001
Mysql Total
Database connection0.00060.056110.0006
Mysqli_queries0.947687.87252410.0039
Looping result0.00250.22832390.0000
Template Total1.042796.720.5213
Template load0.00230.214220.0012
Template processing1.040396.468820.5202
Template load and register function0.00020.019610.0002
states
state_id_array0.00100.091210.0010
state_identifier_array0.00160.148720.0008
Override
Cache load0.00230.2118960.0000
Sytem overhead
Fetch class attribute can translate value0.00140.1329100.0001
Fetch class attribute name0.00170.1561210.0001
XML
Image XML parsing0.00900.8319100.0009
class_abstraction
Instantiating content class attribute0.00010.0078240.0000
General
dbfile0.00890.8212660.0001
String conversion0.00000.000630.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
10content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
14content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
19content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
6content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 51
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs