Alles rund um Magento!

Patch für CustomerController / Magento 1.4.0.1

Da derzeit das Error-Handling im CustomerController des Backends kaputt. Statt der Exception-Message erscheint eine andere Exception: sehr unschön und mühsam beim Debuggen:

Item (Mage_Customer_Model_Address) with the same id "1" already exist
 
#0 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Eav/Model/Entity/Collection/Abstract.php(236): Varien_Data_Collection->addItem(Object(Mage_Customer_Model_Address))
#1 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Customer/Model/Customer.php(204): Mage_Eav_Model_Entity_Collection_Abstract->addItem(Object(Mage_Customer_Model_Address))
#2 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Adminhtml/controllers/CustomerController.php(112): Mage_Customer_Model_Customer->addAddress(Object(Mage_Customer_Model_Address))
#3 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Core/Controller/Varien/Action.php(418): Mage_Adminhtml_CustomerController->editAction()
#4 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(254): Mage_Core_Controller_Varien_Action->dispatch('edit')
#5 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Core/Controller/Varien/Front.php(177): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
#6 /var/www/virtual/mage/mage-df-1/app/code/core/Mage/Core/Model/App.php(304): Mage_Core_Controller_Varien_Front->dispatch()
#7 /var/www/virtual/mage/mage-df-1/app/Mage.php(596): Mage_Core_Model_App->run(Array)
#8 /var/www/virtual/mage/mage-df-1/index.php(78): Mage::run('', 'store')
#9 {main}

Ich habe den Bug als Issue erfasst, doch es dürfte wohl etwas dauern, bis Varien das Issue bearbeitet und die nächste Version veröffentlicht. Den Patch habe ich auch dem Issue im Magento-Bugtracker angehängt aber offensichtlich können Dateien von außen nicht abgerufen werden, was sehr schade ist. Daher veröffentliche ich den Patch auch mal hier:

### Eclipse Workspace Patch 1.0
#P magento-1.4
Index: app/code/core/Mage/Adminhtml/controllers/CustomerController.php
===================================================================
--- app/code/core/Mage/Adminhtml/controllers/CustomerController.php	(revision 61891)
+++ app/code/core/Mage/Adminhtml/controllers/CustomerController.php	(working copy)
@@ -107,9 +107,12 @@
         }
         if (isset($data['address']) && is_array($data['address'])) {
             foreach ($data['address'] as $addressId => $address) {
-                $addressModel = Mage::getModel('customer/address')->setData($address)
+                if (!($addressModel = $customer->getAddressItemById($addressId))) {
+                    $addressModel = Mage::getModel('customer/address');
+                    $customer->addAddress($addressModel);
+                }
+                $addressModel->setData($address)
                     ->setId($addressId);
-                $customer->addAddress($addressModel);
             }
         }

Web-Entwickler (m/w) für Magento in Karlsruhe gesucht

We make websites run

Als spezialisierter Dienstleister für Webtechnologien sorgen wir bei Flagbit dafür, dass die Webseiten unserer Kunden optimal zu Geltung kommen. Open Source-Systeme wie TYPO3, Magento oder das Zend Framework nutzen wir, um Webseiten, Online Shops oder individuale Webanwendungen zu erstellen, die auf unsere Kunden sowie deren Kunden maßgeschneidert sind. Gleichzeitig geben wir den Open Source-Communities durch regelmäßige Veröffentlichungen von Modulen oder Blog-Beiträgen einen Teil unserer Arbeit zurück.

Wir suchen nun Verstärkung für unser junges Team, welches sich sowohl um Kunden wie Radio FFN, Josef Seibel, das Zentrum für Europäische Wirtschaftsforschung, die Hochschule Mannheim, MSC/Gleichmann Electronics, Bosch-Rexroth, brand eins (Gemeinschaftsprojekt mit blindwerk – neue medien KG) oder Netviewer (Gemeinschaftsprojekt mit ping 24/7) als auch um eigene Produkte wie TypoGento oder die Magento Integration Platform kümmert.

Deine Aufgaben

Im Rahmen unserer Arbeit mit Magento gibt es eine Vielzahl von Arbeiten zu erledigen. In deinen Verantwortungsbereich fallen:

  • Konzeption und Entwicklung von maßgeschneiderten Shop-Systemen
  • Konzeption und Entwicklung von Erweiterungs-Modulen für Magento für Kunden oder die Open Source Gemeinde
  • Wartung und Weiterentwicklung bestehender Systeme
  • Entwicklung von Individual-Software auf Basis von Magento oder dem Zend Framework
  • Diskussion, Gestaltung und Realisierung interessanter Open Source Projekte
  • Schulung von Kunden oder Anwendern

Dein Profil

Zum Erledigen der Aufgabenstellungen sind einige fachliche und menschliche Anforderungen notwendig. Dass du dich mit dem Internet, dem Web und den notwendigen Geräten auskennst, setzen wir einfach mal voraus. Was du außerdem mitbringen solltest:

  • Fundierte Kenntnisse in XHTML, CSS, PHP5 & MySQL
  • Grundkenntnisse im Administrieren von Server-Technologien
  • Möglichst bereits Erfahrungen mit dem Zend Framework und/oder Magento
  • Lernbereitschaft, Motivation und Teamfähigkeit
  • Selbständiges Arbeiten, freundliches, kundenorientiertes Auftreten
  • Vorzeigbares Deutsch & Englisch in Wort und Schrift

Vorteilhaft wären darüber hinaus Erfahrungen in den Punkten:

  • Konzeption oder Leitung von Web-Projekten
  • Kenntnisse in Javascript, AJAX und Webservices
  • Erfahrungen mit TYPO3
  • Kenntnisse in SVN, Unit Testing oder Continuous Integration

Was dich bei uns erwartet

Natürlich soll all die gute Arbeit auch belohnt werden. Was du bei uns erwarten kannst:

  • Ein junges, dynamisches, freundliches und motiviertes Team
  • Eine angemessene & leistungsgerechte Bezahlung
  • Ein professionelles und sehr gut ausgestattetes Arbeitsumfeld
  • Flache Hierarchien & schnelle, unkomplizierte Entscheidungswege
  • Flexible Arbeitsbedingungen
  • Kostenfreie Getränke mit Kaffee-Flatrate
  • Vielseitige und verantwortungsvolle Arbeit an interessanten Projekten

Interesse?

Wir haben dein Interesse geweckt? Dann kontaktiere uns einfach per E-Mail unter jobs@flagbit.de. Wir freuen uns auf deine Bewerbung!

Erstellen eines Backend-Moduls: Grundlagen und Konfiguration

Grundlegende Erkenntnisse

Magento ist prinzipiell modular aufgebaut. In Version 1.3 besteht Magento aus zirka 50 Core-Module, deren Funktionalität sich durch weitere Community- oder Local-Extensions erweitern und verändern lässt.

Das Backend ist, was dies angeht eher ein schlechtes Beispiel: Es ist nicht modular aufgebaut, wie man dies vom Frontend her gewohnt ist – die meisten Standard-Interfaces befinden sich im Modul „Adminhtml“. Für den Entwickler hat dies einige Nachteile, wie sich im Laufe der Beitragsserie zeigen wird.

Trotzdem bietet auch das Backend einige Möglichkeiten, bestehende Funktionalitäten anzupassen und zu erweitern. Wie das geht, werden wir in den kommenden Wochen mit einigen kleinen Beiträgen anhand einiger bestehender Module beschreiben. Die Möglichkeiten werden in diesen mit Sicherheit nicht ausgeschöpft – falls wir was Wichtiges vergessen haben sollten, weißt uns bitte drauf hin.

Dieser erste Beitrag beschäftigt sich mit den Teilen der Konfiguration, die für die Erstellung von Backend Interfaces interessant sind.

Die Konfiguration

Wie jedes Modul benötigen auch Backend-Module Konfigurations-Einstellungen, die über die Definitionen der config.xml eingestellt werden. Die allgemeinen Einstellungsmöglichkeiten wie die Definition von Models, Blocks oder Helpern sind nicht Bestandteil dieses Beitrags; viel mehr soll fokussiert auf die speziellen Einstellungen für Backend-Module eingegangen werden.

Der <modules>-Block

Im ersten Block werden allgemeine Informationen zum Modul definiert, wie der Name, die Version und ob das Modul aktiv ist oder nicht:

  <modules>
    <Flagbit_Glossary>
      <active>true</active>
      <codePool>local</codePool>
      <version>0.2.0</version>
    </Flagbit_Glossary>
  </modules>

Der <admin>-Block

Nachdem wir im modules-Block zunächst allgemeine Informationen über das Modul gegeben haben, bietet der zweite Block zwei wichtige allgemeine Einstellungen des Magento-Backends: die Registrierung unseres Admin-Controllers sowie die Definition unserer Adressen.

  <admin>
    <routers>
      <glossary>
        <use>admin</use>
        <args>
          <module>Flagbit_Glossary</module>
          <frontName>glossary</frontName>
        </args>
      </glossary>
    </routers>

Damit ein Modul überhaupt eigene Informationen verarbeiten kann, muss es einen oder mehrere Controller bei den Routern definieren können. (Action-)Controller sind für die Steuerung der Abläufe und Prozesse innerhalb der MVC-Architektur von Magento zuständig. Router wiederum sind Controller, die einen bestimmten Aufruf anhand der Adresse an einen Action Controller übergeben.

Innerhalb des routers-Block verstecken sich folgende Angaben (vgl. Mage_Core_Controller_Varien_Router_Standard :: collectRoutes()):

  • Das XML-Tag <glossary> bestimmt den Namen der aktuellen Route. Auf diese Art und Weise wäre es möglich, bestehende Routen über ein eigenes Modul zu überschreiben.
  • Im Backend ist es natürlich wichtig, dass alle Sicherheitsbestimmungen greifen und die Interfaces nicht aus dem Frontend aufgerufen werden können. Dementsprechend wird hier der Wert „admin“ übergeben.
  • Das Module beschreibt natürlich das aktuelle Modul.
  • Der FrontName wiederum bestimmt, unter welcher URL das eigene Modul aufgerufen werden kann. In unserem Fall wäre dies „http://www.example.com/glossary“.
    <rewrite>
      <Flagbit_Glossary>
        <from>
          <![CDATA[#^/{adminhtml}/glossary/#]]>
        </from>
        <to>/glossary/admin/</to>
      </Flagbit_Glossary>
    </rewrite>
  </admin>

Um das Backend-Modul nun optimal in das Magento-Backend zu integrieren, sollten sich auch die URLs des Moduls an den Admin-Adressen orientieren – die bisherige URL sieht eher wie die im Frontent aus. Hierfür steht der <rewrite>-Block, der alle Aufrufe von „/{adminhtml}/glossary“ auf den AdminController unseres Frontnames weiterleitet. ”{adminhtml}“ ist hierbei als Platzhalter für das die Adresse des Backend zu verstehen – dieser wird von Magento automatisch ausgetauscht. Als Resultat wird dem Nutzer automatisch unser AdminController angezeigt, wenn er den “GlossarController von Adminhtml” aufrufen möchte.

Der <adminhtml>-Block

  <adminhtml>
    <menu>
      <cms>
        <children>
          <glossary translate="title" module="glossary">
            <title>Glossary</title>
            <action>adminhtml/glossary</action>
            <sort_order>50</sort_order>
          </glossary>
        </children>
      </cms>
    </menu>

Der erste Teil des XML-Blocks beschreibt die Einbindung unseres Moduls in das Menü des Backends. Die Hauptmenü-Punkte sind Kindknoten von <menu>; in unserem Fall bauen wir keinen neuen Punkt in der ersten Ebene ein, sondern fügen einen neuen Unterpunkt zu CMS hinzu.

<cms> versteht sich als Referenz auf die Definitionen, die in der config.xml des CMS-Moduls eingefügt wurden – so könnten andere Module wiederum auf die Definitionen von <glossary> zugreifen und diese ändern oder erweitern. Zu beachten ist hierbei auch, dass zwei Module einer Extensions auch eindeutige Keys benötigen!

<title>, <action> und <sort_order> sind an sich selbsterklärend; bei <action> sollte nach Möglichkeit die Adresse angegeben werden, die wir im <rewrite> definiert haben.

    <acl>
      <resources>
        <admin>
          <children>
            <cms>
              <children>
                <glossary translate="title" module="glossary">
                  <title>Glossary</title>
                  <sort_order>50</sort_order>
                </glossary>
              </children>
            </cms>
          </children>
        </admin>
      </resources>
    </acl>
  </adminhtml>

Der <acl>-Bereich ist bezüglich des Aufbaus verwandt mit dem beschriebenen Menü. Er ermöglicht die Rechteverwaltung im Backend von Magento. Logischerweise wird der Glossar auch hier wieder als Kindknoten von CMS definiert.

Als Resultat gibt es in der Rechteverwaltung eine neue Checkbox – beim Generieren des Menüs und Aufruf des Moduls wird überprüft, ob das entsprechende Häkchen gesetzt ist oder eben nicht. Als Hinweis sei erlaubt, dass beim Testen der Rechte ein neuer Login Wunder bewirken kann, da die Rechte beim Login überprüft und in die Session des Nutzers gespeichert werden.

Die gesamte config.xml

Wie die gesamte Konfiguration aussehen kann, zeigt das folgende Listing:

<?xml version="1.0"?>
<config>
  <modules>
    <Flagbit_Glossary>
      <active>true</active>
      <codePool>local</codePool>
      <version>0.2.0</version>
    </Flagbit_Glossary>
  </modules>
  <admin>
    <routers>
      <glossary>
        <use>admin</use>
        <args>
          <module>Flagbit_Glossary</module>
          <frontName>glossary</frontName>
        </args>
      </glossary>
    </routers>
    <rewrite>
      <Flagbit_Glossary>
        <from>
          <![CDATA[#^/{adminhtml}/glossary/#]]>
        </from>
        <to>/glossary/admin/</to>
      </Flagbit_Glossary>
    </rewrite>
  </admin>
  <adminhtml>
    <menu>
      <cms>
        <children>
          <glossary translate="title" module="glossary">
            <title>Glossary</title>
            <action>adminhtml/glossary</action>
            <sort_order>50</sort_order>
          </glossary>
        </children>
      </cms>
    </menu>
    <acl>
      <resources>
        <admin>
          <children>
            <cms>
              <children>
                <glossary translate="title" module="glossary">
                  <title>Glossary</title>
                  <sort_order>50</sort_order>
                </glossary>
              </children>
            </cms>
          </children>
        </admin>
      </resources>
    </acl>
  </adminhtml>
</config>

Fazit

Im ersten Beitrag zur Entwicklung von Backend-Modulen haben wir die Definitionen der Konfiguration kurz unter die Lupe genommen. Mangels Dokumentation fällt deren Interpretation nicht immer leicht – den Platzhalter für {adminhtml} mussten wir uns auch im Quelltext zusammensuchen.

Mit der Konfiguration konnten wir den Grundstein für die Entwicklung von Backend-Modulen legen, indem wir unsere Controller registriert und in das Menü mit eingebunden haben. Viel Funktionalität haben wir damit natürlich noch nicht – in den kommenden Beiträgen werden wir diese Hülle mit Leben füllen.

TypoGento.com online und Artikel in der T3N

Nachdem wir im Oktober einen ersten Vortrag zu TypoGento auf der TYPO3 Convention vorstellen durften, können wir nun zwei weitere Informationsquellen für Interessierte vorstellen.

Zum Einen haben wir nach einigen Monaten Arbeit an der Extension nun auch endlich eine kleine Themenwebseite fertig gestellt. Man sieht ihr zwar noch an, dass die Seite noch nicht ganz fertig ist, aber alle Informationen zum Modul sowie eine (sehr) kurze Dokumentation sind bereits jetzt verfügbar.

Außerdem durften wir einen Artikel in der aktuellen Ausgabe der T3N beisteuern und erklären dort auf 3,5 Seiten die Funktionsweise des Moduls. Die aktuelle Ausgabe gibt es beim ausgewählten Zeitschriftenhandel sowie online unter http://www.t3n.de.

Viel Spaß beim Lesen!

UPDATE: Mittlerweile kann man unter http://t3n.de/magazin/magento-shop-typo3-integrieren-neue-extension-verbindet-221183/ den kompletten Artikel online lesen.

Nächste Einträge »

Page optimized by WP Minify WordPress Plugin