Forums / Developer / Using a module in command line

Using a module in command line

Author Message

Antoine W.

Friday 15 April 2005 12:56:14 am

Hello,

I have an import script that uses some classes of ez (ezdb, ezuser, eZContentClass...). This script scans my old database and imports old web pages in ez publish.

For the moment, I run it as a module of eZ publish.
I would like to have it working <b>in command line</b>, for better performances.

I think it's not possible to keep this script as a module :

php ~/ez/index.php/admin/mymodule/myview

...dont work.

So I have tried to call this script directly, including some files :

include_once( EZ_DIR."lib/ezi18n/classes/eztextcodec.php" );
include_once( EZ_DIR."lib/ezutils/classes/ezdebug.php" );
include_once( EZ_DIR. "lib/ezutils/classes/ezmodule.php" );
include_once( EZ_DIR.'lib/ezutils/classes/ezexecution.php' );
include_once( EZ_DIR.'kernel/classes/ezcontentobjecttreenode.php' );
include_once( EZ_DIR.'kernel/classes/ezcontentobject.php' );
include_once( EZ_DIR."lib/ezxml/classes/ezxml.php" );
include_once( EZ_DIR.'lib/ezlocale/classes/ezdatetime.php' );

I have no errors, but <i>ezdb</i> dont seems to work ; following lines give me an error : <b>Invalid argument supplied for foreach()</b>.

$db =& eZDB::instance();
$rows =& $db->arrayQuery( "select * from mytable" );
foreach ( $rows as $row ) echo $row['myfield'];

eZDebug::printReport(); returns nothing.

I must maybe initialize some classes before using it ? how ?

Thanks.

Ralph Ekekihl

Friday 15 April 2005 1:42:18 am

Hey!

It looks like you are not inlcuding,

include_once( "lib/ezdb/classes/ezdb.php" );

that one is needed for eZDB instance, otherwise it should work.

Then you can have a look at:

lib/ezutils/classes/ezcli.php
kernel/classes/ezscript.php

too see how you integrate the CLI scripts into ezPublish. Also have a look at the scripts in the
ezpublish/bin/php folder.

Good luck!

Contactivity B.V.
http://www.contactivity.com

Antoine W.

Monday 18 April 2005 1:55:21 am

Thanks Ralph,
Scripts in /bin/php/ helped me.
In fact, $ezdb must be instanciated as below :

$db =& eZDB::instance( $type,
                       array( 'server' => $host,
                              'user' => $user,
                              'password' => $password,
                              'database' => $database ) );

eZ debug

Timing: Jan 19 2025 04:32:02
Script start
Timing: Jan 19 2025 04:32:02
Module start 'content'
Timing: Jan 19 2025 04:32:03
Module end 'content'
Timing: Jan 19 2025 04:32:04
Script end

Main resources:

Total runtime1.5658 sec
Peak memory usage4,096.0000 KB
Database Queries194

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0077 588.9531180.8359
Module start 'content' 0.00771.3183 769.7891545.9922
Module end 'content' 1.32600.2398 1,315.7813332.7500
Script end 1.5658  1,648.5313 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00420.2691210.0002
Check MTime0.00180.1135210.0001
Mysql Total
Database connection0.00120.073510.0012
Mysqli_queries1.484094.77281940.0076
Looping result0.00240.15251920.0000
Template Total1.527797.620.7639
Template load0.00200.129620.0010
Template processing1.525797.435220.7628
Template load and register function0.00020.013410.0002
states
state_id_array0.00170.106610.0017
state_identifier_array0.00100.064920.0005
Override
Cache load0.00170.1095340.0001
Sytem overhead
Fetch class attribute can translate value0.00170.107930.0006
Fetch class attribute name0.00320.201740.0008
XML
Image XML parsing0.00280.178830.0009
class_abstraction
Instantiating content class attribute0.00000.000940.0000
General
dbfile0.00380.2396270.0001
String conversion0.00000.000330.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
3content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
10content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
4content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
5content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 25
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs