Pourquoi utiliser magento tag deprecatedNode dans la déclaration de ressources de modèle en liste

magento.stackexchange https://magento.stackexchange.com/questions/15042

Question

Je l'ai vu une chose intéressante dans la configuration du modèle config.xml. J'étais inconnu sur les balises <deprecatedNode> dans la déclaration de classe modèle et veulent savoir sur cette balises.

Dans une extension personnalisée nous avons juste besoin de ce type de déclaration de classe modèle ..

 <models>
            <[module]>
                <class>[Namespace]_[Module]_Model</class>
                <resourceModel>[module]_mysql4</resourceModel>
            </[module]>
            <[module]_mysql4>
                <class>[Namespace]_[Module]_Model_Mysql4</class>
                <entities>
                    <[module]>
                        <table>[module]</table>
                    </[module]>
                </entities>
            </[module]_mysql4>
        </models>

Référence - http://www.magentocommerce.com/wiki/ 5 _-_ modules_and_development / 0 _-_ module_development_in_magento / custom_module_with_custom_database_table

But in magento existing modules comme Wishlist 's config.xml définir le modèle à déclarer deprecatedNode et resourceModel avec ce motif

<wishlist>
                <class>Mage_Wishlist_Model</class>
                <resourceModel>wishlist_resource</resourceModel>
            </wishlist>
<wishlist_resource>

    <class>Mage_Wishlist_Model_Resource</class>
                <deprecatedNode>wishlist_mysql4</deprecatedNode>
                <entities>
                    <wishlist>
                        <table>wishlist</table>
                    </wishlist>
                    <item>
                        <table>wishlist_item</table>
                    </item>
                    <item>
                        <table>wishlist_item</table>
                    </item>
                    <item_option><table>wishlist_item_option</table></item_option>
                </entities>
            </wishlist_resource>

POURQUOI CE TYPE DE CODE UTILISÉ DANS MAGENTO

 <resourceModel>wishlist_resource</resourceModel>
                </wishlist>

                <wishlist_resource>

                    <class>Mage_Wishlist_Model_Resource</class>
                    <deprecatedNode>wishlist_mysql4</deprecatedNode>
Était-ce utile?

La solution

Dans les versions précédentes à 1,6 le nœud <resourceModel> avait habituellement ce nom:. [module]_mysql4
À partir de la version 1.6 supports Magento (en théorie) d'autres types de bases de données non seulement MySQL. Ainsi, le nom du modèle de ressources changé à wishlist_resource.
mais pour faire de vieux extensions qui pourraient réécrire le modèle de certains ressources encore du travail, ce deprecatedNode a été introduit.
Si un modèle ou un modèle de ressource est introuvable en utilisant la balise [module]_resource puis regarde Magento pour l'aide de la valeur deprecatedNode.
Jetez un oeil à ces méthodes:
Mage_Core_Model_Resource::getEntity

public function getEntity($model, $entity)
{
    $modelsNode = Mage::getConfig()->getNode()->global->models;
    $entityConfig = $modelsNode->$model->entities->{$entity};

    /**
     * Backwards compatibility for pre-MMDB extensions.
     * In MMDB release resource nodes <..._mysql4> were renamed to <..._resource>. So <deprecatedNode> is left
     * to keep name of previously used nodes, that still may be used by non-updated extensions.
     */
    if (isset($modelsNode->$model->deprecatedNode)) {
        $deprecatedNode = $modelsNode->$model->deprecatedNode;
        if (isset($modelsNode->$deprecatedNode->entities->$entity)) {
            $entityConfig = $modelsNode->$deprecatedNode->entities->$entity;
        }
    }

    return $entityConfig;
}

et Mage_Core_Model_Config::getGroupedClassName

public function getGroupedClassName($groupType, $classId, $groupRootNode=null)
{
    ....
    $className = null;
    if (isset($config->rewrite->$class)) {
        $className = (string)$config->rewrite->$class;
    } else {
        /**
         * Backwards compatibility for pre-MMDB extensions.
         * In MMDB release resource nodes <..._mysql4> were renamed to <..._resource>. So <deprecatedNode> is left
         * to keep name of previously used nodes, that still may be used by non-updated extensions.
         */
        if ($config->deprecatedNode) {
            $deprecatedNode = $config->deprecatedNode;
            $configOld = $this->_xml->global->{$groupType.'s'}->$deprecatedNode;
            if (isset($configOld->rewrite->$class)) {
                $className = (string) $configOld->rewrite->$class;
            }
        }
    }
    ....
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à magento.stackexchange
scroll top