Forums / Developer / Importing: Update entry if it already exists

Importing: Update entry if it already exists

Author Message

Siniša Šehović

Thursday 07 October 2004 1:17:49 am

Hi Paul

Please help:-)

Something strange happend!?
After importing hash into user table there is hash that I have created and I can't login but if I go to user in admin and "change" password with same password(hash import is demo password) "demo" i see that in user table is different hash of demo?!?!
How is that possible?

Best regards,
Sinisa

---
If at first you don't succeed, look in the trash for the instructions.

Siniša Šehović

Thursday 07 October 2004 2:19:32 am

Hi

I have figured out what was wrong!:)-)
Password hash is produced like username\password.
Now everything works great:)

S.

---
If at first you don't succeed, look in the trash for the instructions.

Paul Forsyth

Friday 08 October 2004 12:40:05 am

Glad it works! I was away for most of yesterday.

Paul

Lazaro Ferreira

Wednesday 20 October 2004 1:51:47 am

Paul,

I have read all the thread, and I have picked up this piece of code, that create and publish an user object

$ini =& eZINI::instance();

$userClassID = $ini->variable( "UserSettings", "UserClassID" );
$class =& eZContentClass::fetch( $userClassID );

$userCreatorID = $ini->variable( "UserSettings", "UserCreatorID" );
$defaultSectionID = $ini->variable( "UserSettings", "DefaultSectionID" );
$defaultUserPlacement = $ini->variable( "UserSettings", "DefaultUserPlacement" );

$contentObject =& $class->instantiate( $userCreatorID, $defaultSectionID, false);

$nodeAssignment =& eZNodeAssignment::create( array(
                                                   'contentobject_id' => $contentObject->attribute( 'id' ),
                                                   'contentobject_version' => 1,
                                                   'parent_node' => $defaultUserPlacement,
                                                   'is_main' => 1
                                                  )
                                           );
$nodeAssignment->store();
    
// Set a status for the content object version
$contentObjectVersion =& $contentObject->version($contentObject->attribute( 'current_version' ) );
$contentObjectVersion->setAttribute( 'status', EZ_VERSION_STATUS_DRAFT);
$contentObjectVersion->store();

// Set the members attributes
$contentObjectAttributes =& $contentObject->attribute('data_map');

$firstNameAttribute = $contentObjectAttributes['first_name'];
$lastNameAttribute = $contentObjectAttributes['last_name'];
$userAccountAttribute = $contentObjectAttributes['user_account']->content();

// Now set the details
$firstNameAttribute->setAttribute("data_text", "Enter first name");
$firstNameAttribute->store();
    
$lastNameAttribute->setAttribute("data_text", "Enter second name");
$lastNameAttribute->store();
    
$userAccountAttribute->setAttribute("login", "Choose login");
$userAccountAttribute->setAttribute("email", "Choose email");

// Entered md5 sum of 'publish'. Replace with hash of your own. Make sure the hash type matches.
$userAccountAttribute->setAttribute("password_hash", "9b6d0bb3102b87fae57bc4a39149518e");
    
// Keep the password type as 2. This is the default for eZ publish but look in ezuser.php for more options.
$userAccountAttribute->setAttribute("password_hash_type", 2);
$userAccountAttribute->store();

// Now publish the object.
$operationResult = eZOperationHandler::execute( 'content', 
                                                'publish',
                                                array( 'object_id' => $contentObject->attribute( 'id' ),
                                                       'version' => $contentObject->attribute('current_version' ) ) );

So, my understanding is that here I have all ezp API needed to create and publish my own content objects from my php module extension

Is that right ?

Lazaro
http://www.mzbusiness.com

Paul Forsyth

Wednesday 20 October 2004 2:10:28 am

Some of it, yes. Your own needs may differ of course. The code above is just an example. Search the forums for snippets of this code and you will see it used in other ways.

You could always use the code documentation found at http://pubsvn.ez.no/doxygen/

Btw, can yu reply to the original thread and not this one. Its easier to follow.

paul

First Last

Saturday 30 July 2005 9:45:12 am

Thank you for import script, but could you post format of CSV file to import? I don't know, how to prepare CSV file to be able to import it.

First Last

Monday 08 August 2005 11:05:28 am

Now I know how to import text fields, but could anyone help me how to import images?

Massimiliano Bariola

Saturday 18 March 2006 1:03:24 pm

Hi,

I tried the code provided to change the name of a node, but it does not seem to work. my code does not fail, but the name remains the same.

Please can anyone help me?

thank you!

Massimiliano Bariola

Saturday 18 March 2006 1:48:39 pm

I found it. $contentObject->rename($newname). 4 hours to find it ... sigh.

eZ debug

Timing: Jan 18 2025 19:00:59
Script start
Timing: Jan 18 2025 19:00:59
Module start 'content'
Timing: Jan 18 2025 19:00:59
Module end 'content'
Timing: Jan 18 2025 19:01:00
Script end

Main resources:

Total runtime0.2544 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0097 588.3672180.8125
Module start 'content' 0.00970.0086 769.1797106.4531
Module end 'content' 0.01830.2361 875.6328536.3750
Script end 0.2543  1,412.0078 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00391.5246200.0002
Check MTime0.00150.5863200.0001
Mysql Total
Database connection0.00150.575510.0015
Mysqli_queries0.189074.27661410.0013
Looping result0.00170.66981390.0000
Template Total0.235192.410.2351
Template load0.00110.415110.0011
Template processing0.234091.985710.2340
Override
Cache load0.00070.292510.0007
Sytem overhead
Fetch class attribute can translate value0.00100.396110.0010
XML
Image XML parsing0.00030.104510.0003
General
dbfile0.01325.1720200.0007
String conversion0.00000.002730.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.0001 secs