Warum Magento depressierte Node -Tag in der Modellressourcenerklärung in der Wunschliste verwendete

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

Frage

Ich habe eine interessante Sache in der Modellkonfiguration in config.xml gesehen. Ich war unbekannt über die Tags <deprecatedNode> in der Modellklassenerklärung und möchte über diese Tags wissen.

In einer benutzerdefinierten Erweiterung benötigen wir nur diese Art von Modellklassenerklärung.

 <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>

Bezug -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 wie Wishlist 's config.xml Definieren Sie das Modell mit depressierter Note und Ressourcenmodell, die mit diesem Muster deklarieren

<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>

Warum diese Art von Code, die in Magento verwendet wird

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

                <wishlist_resource>

                    <class>Mage_Wishlist_Model_Resource</class>
                    <deprecatedNode>wishlist_mysql4</deprecatedNode>
War es hilfreich?

Lösung

In Versionen vor 1.6 die <resourceModel> Knoten hatte normalerweise diesen Namen: [module]_mysql4.
Ausgehend von Version 1.6 unterstützt Magento (theoretisch) andere Arten von Datenbanken, nicht nur MySQL. Der Name des Ressourcenmodells wurde also geändert in wishlist_resource.
Aber um alte Erweiterungen herzustellen, die das einige Ressourcenmodell noch umschreiben könnten, funktioniert dies noch deprecatedNode wurde vorgestellt.
Wenn ein Modell oder ein Ressourcenmodell nicht mit dem gefunden wird [module]_resource Tag dann sucht Magento danach mit dem deprecatedNode Wert.
Schauen Sie sich diese Methoden an:
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;
}

und 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;
            }
        }
    }
    ....
}
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit magento.stackexchange
scroll top