Import Script Problems

Author Message

Kenneth Colwell

Wednesday 11 February 2004 1:31:03 pm

Hi,

Thank you for providing these scripts they are a huge help. However, I have two problems after completing my import. After I imported all of my articles I found that a significant amount of those articles and some folders had been duplicated or somehow placed in the root folder. It seems like a lot of the folders have blank description fields in the orginal 2.2.9 database.

Also I found that my images are uploaded and that I can access them via the images folder but they are not appearing in the individual articles.

Any ideas?

Thanks,
Ken Colwell

Kenneth Colwell

Wednesday 11 February 2004 2:21:54 pm

Perhaps the problem is that the importfolder.php script doesn't look for folders that have a smaller id number than the folder that they have been placed inside. For example if you look at our 2.2.9 site we have a folder named baseball: http://www.muc.edu/article/archive/68/ that has been moved into a folder that we created later named men?s teams: http://www.muc.edu/article/archive/339/

Since the script does a simple SELECT * FROM eZArticle_Category ORDER BY ID and the sends the folders to addFolder function. When the script gets to folder 68 its parent folder doesn?t exist yet so it just dumps it into the root folder.

Does this sound like the source of my folder problem or am I just totally off the mark?

Thanks,
Ken Colwell

Kenneth Colwell

Thursday 12 February 2004 7:08:09 am

I guess I will just keep talking to myself and hope that it helps someone in the future. :-)

Changing line 170 of importFolder.php from ORDER BY ID to ORDER BY ParentID seems to semi-fix the problem of sub-folders that have a smaller id number than there parent folder.

However this problem still exists if there are other subfolders within the original subfolder with smaller id numbers than the original parent folder.

Thanks,
Ken C.

Georg Franz

Thursday 12 February 2004 8:07:18 am

Hi Ken,

no, sorting by ParentID won't help. You have to implement a "getTree"-Class.

Do something similar in the importfolder.php:

class mytree
{

	var $data;
	var $table;
	var $ID;
	
	function mytree( $id=-1, $table = 'eZArticle_Category' )
    {
        if ( $id != -1 )
        {
            $this->ID = $id;
            $this->table = $table;
            $this->get( $this->ID, $table );
        }
    }
    
    function get( $id=-1, $table = 'eZArticle_Category')
    {
        if ( $id != "" )
        {
            $db =& eZDB::instance();
		    $db->setIsSQLOutputEnabled( false );
			$data = $db->arrayQuery( "SELECT *
			FROM
			  $table
		    WHERE ID = $id" );
			$this->data = $data;
        }
    }
    
    function id()
    {
    	return $this->ID;	
    }
    
    function getByParent( $parent, $table = "eZArticle_Category" )
    {
        if ( get_class( $parent ) == "mytree" )
        {
            $db =& eZDB::instance();
		    $db->setIsSQLOutputEnabled( false );
			
            $return_array = array();
            $category_array = array();

            $parentID = $parent->id();

            $show_str = "";
            
		    $query = "SELECT ID 
                      FROM $table 
                      WHERE ParentID='$parentID'
                      ORDER BY Name
                            ";

            $category_array = $db->arrayQuery( $query );

            for ( $i=0; $i < count($category_array); $i++ )
            {
                $return_array[$i] = new mytree( $category_array[$i]["ID"], $table );
            }
            return $return_array;
        }
        else
        {
            return 0;
        }
    }

    
	function getTree( $table = "eZArticle_Category", $parentID=0, $level=0   )
	{
	    if ( get_class( $parentID ) == "mytree" )
	        $category = $parentID;
	    else
	        $category = new mytree( $parentID, $table );
	
	    $categoryList = $category->getByParent( $category, $table );
	
	    $tree = array();
	    $level++;
	    foreach ( $categoryList as $category )
	    {
	        array_push( $tree, array( $return_array[] = $category, $level ) );
	
	        if ( $category != 0 )
	        {
	            $tree = array_merge( $tree, mytree::getTree( $table, $category, $level  ) );
	        }
	    }
	    return $tree;
	}
}

(...)

Alter the function "folderList":

function folderList($table = 'eZArticle_Category'  )
{
    $tree = mytree::getTree($table);
    $folderArray = array();
    foreach ($tree as $item)
    {
    	$folderArray[] = $item[0]->data[0];
    }
	return $folderArray;
}

To get the sorted folders:

$articleFolderList =& folderList('eZArticle_Category' );

$imageFolderList =& folderList('eZImageCatalogue_Category' );

(and so on)

Best wishes,
Georg.

--
http://www.schicksal.com Horoskop website which uses eZ Publish since 2004

Kenneth Colwell

Thursday 12 February 2004 9:51:27 am

Thank you, Thank you, Thank you!

I was on the way to your solution to this problem but working from the 2.2.9 tree menu/sitemap script was giving me headaches. Your code worked like a charm.

Many thanks,
Ken Colwell

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 19 2025 07:21:18
Script start
Timing: Jan 19 2025 07:21:18
Module start 'layout'
Timing: Jan 19 2025 07:21:18
Module start 'content'
Timing: Jan 19 2025 07:21:18
Module end 'content'
Timing: Jan 19 2025 07:21:18
Script end

Main resources:

Total runtime0.0164 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0047 589.1563152.6250
Module start 'layout' 0.00470.0050 741.781339.4609
Module start 'content' 0.00970.0048 781.242293.4609
Module end 'content' 0.01450.0018 874.703138.3047
Script end 0.0163  913.0078 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002314.3467140.0002
Check MTime0.00116.7809140.0001
Mysql Total
Database connection0.00063.938710.0006
Mysqli_queries0.003622.071130.0012
Looping result0.00000.238810.0000
Template Total0.00159.210.0015
Template load0.00084.762810.0008
Template processing0.00074.426510.0007
Override
Cache load0.00063.365010.0006
General
dbfile0.00021.413880.0000
String conversion0.00000.046640.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_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