ModuleStudio erlaubt die Nutzung unterschiedlicher Doctrine-Erweiterungen, indem diese im jeweiligen Anwendungsmodell aktiviert und ggf. konfiguriert werden. Neben Baumstrukturen (tree / nested set), lesbaren Permalinks (sluggable) oder Übersetzungen zur Umsetzung mehrsprachiger Daten (translatable) sowie weiteren Funktionen steht hier auch die Möglichkeit zur Verfügung, die Änderungen an Datensätzen in Form einer Revisionierung aufzuzeichnen. Dieser Beitrag gibt einen Überblick über die damit einhergehenden Features. Als gemeinsame Basis der im Folgenden beschriebenen Funktionen kommt die Loggable-Extension für Doctrine zum Einsatz.
Für jeden Datensatz lässt sich eine Liste aller Änderungen, die sogenannte Historie aufrufen (siehe ersten Screenshot). Diese Historie zeigt alle Versionen absteigend untereinander und es lässt sich jeweils die Liste der geänderten Werte einblenden. Ferner ist es möglich, die Detailansicht der jeweiligen Version in einem Fensterchen aufzurufen - das geht auch für mehrere Versionen gleichzeitig, so dass sich mehrere Fenster nebeneinander stellen und vergleichen lassen.
Es ist ferner möglich, zwei Versionen mittels Checkboxen auszuwählen und eine Vergleichsansicht aufzurufen (zu sehen im zweiten Screenshot). Hierbei werden die Änderungen in roter und grüner Farbe hervorgehoben, ähnlich den diff-Ansichten auf GitHub.
Die Historienansicht erlaubt es auch, beliebige Versionen wiederherzustellen. Dies bewirkt, dass der entsprechende Datensatz wieder die dazugehörigen Werte erhält. Das Resultat wird wiederum als neue Version gespeichert, so dass der Verlauf nicht beeinträchtigt wird. Eine Sonderform dieser Funktion ist eine spezielle Seite, die Zugriff auf gelöschte Datensätze erlaubt und eine Wiederherstellung “undelete” ermöglicht. Ähnlich dem Papierkorb in Windows lassen sich also gelöschte Daten wieder aus der Versenkung holen.
In den Grundeinstellungen der generierten Anwendung gibt es einen Reiter, der die Konfiguration der Versionierung erlaubt. Per Standard ist die Historie nicht begrenzt; es ist aber möglich, wie im dritten Screenshot gezeigt wird, eine Limitierung über entweder die Anzahl der Versionen oder über einen Zeitraum einzustellen. Im Beispiel würden Projekte nur maximal die letzten 25 Versionen speichern, wohingegen die Historie von Aufgaben für 18 Monate aufgehoben werden. Ein zu beachtender Aspekt hierbei ist, dass die veralteten Versionen nicht einfach weggelöscht werden: statt dessen werden sie zusammengefasst bzw. konsolidiert, so dass weiterhin eine Wiederherstellung möglich ist.
Auch für das Zusammenspiel der Versionierung mit anderen möglichen Erweiterungen steckt Funktionalität im Generator. Wird beispielsweise eine Baumstruktur verwendet, so wird bei der Wiederherstellung gelöschter Daten geprüft, ob der vorherige Elterneintrag noch existiert. Falls dies nicht der Fall ist, wird der Eintrag auf der Hauptebene, also ohne Elterneintrag, wiederhergestellt, um ungültige Zuordnungen zu vermeiden.