Wie ich gestern bereits gepostet habe, hat das Responseobjekt Vollzugriff auf die gesamte Konfiguration. Das ist wichtig, damit Attribute auch persistent geändert werden können (Content Management).
Nun kommt wieder OOP ins Spiel und so haben wir: Sämtliche Konfigurationsdaten stecken in einer Instanz der Klasse Config (soweit bist Du ja auch schon).
Du musst hier aufpassen, dass diese Daten keine Klassenvariablen sind sondern tatsächlich nur in der Instanz vorliegen. Sonst kann es passieren, dass eine Instanz auf Daten zugreift, die während der Laufzeit von einer anderen Instanz geändert worden sind. Und genau dasselbe Problem hättest Du auchmit Globalen Variablen.
Ein schönes praktisches Beispiel: Der Benutzer submittet ein Formular und löst damit einen Zustandsübergang aus. Die Instanz welche fürs Ausliefern der Response zuständig ist, liest aus der Config, welches Template für die Response zu laden ist. Eine andere Instanz hat jedoch zur Laufzeit den Dateinamen geändert. So wird für die Response das falsche Template geladen.
Sowas kommt sicher selten vor, aber das Beispiel dient ja nur dem Verständnis. Ich habe jedoch oft genug erlebt, was passiert wenn sich mehrere Instanzen diegleiche DB-Connection teilen: Verlorene Warenkörbe und verärgerte Kunden.