So verwenden Sie das Repository-Muster in einer Laravel-Anwendung
Ein Repository übernimmt eine Art Vermittlerrolle zwischen der Domänen- und der Datenzuordnungsschicht und fungiert als zentrale Schnittstelle für den Zugriff auf Domänenobjekte.
Moderne PHP-Frameworks wie Laravel und Symfony interagieren mit Datenbanken über so genannte ORMs (Object-Relational Mapper; objektrelationale Abbildung). Symfony nutzt Doctrine als Standard-ORM und Laravel verwendet Eloquent.
Beide verfolgen unterschiedliche Ansätze bei der Interaktion mit ihren Datenbanken. Mit Eloquent werden für jede Datenbanktabelle Modelle generiert, die die Grundlage der Interaktion bilden. Doctrine hingegen nutzt das Repository-Muster, bei dem jede Entität über ein entsprechendes Repository verfügt, das über Helferfunktionen die Interaktion mit der Datenbank ermöglicht. Diese Funktionen werden nicht direkt von Laravel bereitgestellt, man kann das Repository-Muster aber in Laravel-Projekten einsetzen.
Ein wesentlicher Vorteil des Repository-Musters ist, dass es uns mit dem Abhängigkeits-Umkehr-Prinzip (Dependency Inversion Principle, DIP) die Abhängigkeit von Abstraktionen statt von konkreten Implementierungen ermöglicht. Dieses Prinzip macht den Code robuster gegen Veränderungen, zum Beispiel wenn erst später entschieden wird, eine Datenquelle zu verwenden, die nicht von Eloquent unterstützt wird.
Es hilft auch, den Code strukturiert zu halten und Dopplungen zu vermeiden, da sich die Datenbanklogik an einem zentralen Ort befindet. In kleinen Projekten kommt dieser Vorteil weniger zum Tragen, erst bei Großprojekten, die über viele Jahre gepflegt werden müssen, zahlt er sich aus.
In diesem Artikel erfahren Sie, wie das Repository-Muster in Laravel-Anwendungen implementiert wird. Dafür werden wir eine API entwerfen, die den Bestelleingang für ein Unternehmen verwaltet.
Voraussetzungen
- Grundkenntnisse in PHP und Laravel
- PHP 7.4
- Global installierter Composer
- cURL
- Git
- jq (optional)
- Laravel-Installationsprogramm
- Zugang zu einer MySQL-Datenbank
Erste Schritte
Erstellen Sie ein neues Laravel-Projekt und wechseln Sie mit den folgenden Befehlen in das Verzeichnis.
Richten Sie die Datenbank ein
In diesem Tutorial nutzen wir MySQL als Datenbank. Aktualisieren Sie dazu wie unten dargestellt die Datenbankparameter in der .env-Datei.
Erstellen Sie zum Abschluss mit Ihrem bevorzugten Datenbankmanagementsystem eine neue Datenbank mit dem Namen order_api
.
Generieren Sie die ersten Daten für die Datenbank
Unsere Anwendung ist für die Verwaltung von Bestellungen gedacht, daher erstellen wir mit dem folgenden Befehl zunächst ein entsprechendes Modell.
Das Argument -a
sagt Artisan, dass wir eine Migrationsdatei , einen Seeder, eine Factory und einen Controller für das Modell Order (Bestellung) erstellen möchten.
Mit dem obigen Befehl werden fünf neue Dateien erstellt:
- Ein Controller in app/Http/Controllers/OrderController.php
- Eine Datenbank-Factory in database/factories/orderFactory.php
- Eine Migrationsdatei in database/migrations/YYYY_MM_DD_HHMMSS_create_orders_table.php
- Ein Modell in app/Models/Order.php
- Eine Seeder-Datei in database/seeders/OrderSeeder.php
Aktualisieren Sie in database/migrations/YYYY_MM_DD_HHMMSS_create_orders_table.php die Funktion up
wie folgt.
Wie in der Migrationsdatei angegeben, enthält die Tabelle order
die folgenden Spalten:
- Eine ID. Sie ist der Primärschlüssel der Tabelle.
- Die Details der Bestellung.
- Name des bzw. der Kundin, die die Bestellung aufgegeben hat.
- Ob die Bestellung abgeschlossen ist oder nicht.
- Wann die Bestellung erstellt und aktualisiert wurde (
created_at
undupdated_at
) basierend auf der Funktiontimestamps
.
Als Nächstes aktualisieren wir OrderFactory
, um einen Dummy zum Füllen der Datenbank zu generieren. Aktualisieren Sie in database/factories/OrderFactory.php die Funktion definition
wie folgt.
Öffnen Sie anschließend database/seeders/OrderSeeder.php und aktualisieren Sie die Funktion run
wie folgt.
Diese Funktion erstellt mit OrderFactory
50 Bestellungen in der Datenbank.
Fügen Sie in src/database/seeders/DatabaseSeeder.php Folgendes zur Funktion run
hinzu.
Damit wird QuoteSeeder
ausgeführt, wenn der db:seed
-Befehl von Artisan ausgeführt wird.
Führen Sie zum Abschluss Ihre Migrationen aus und füllen Sie die Datenbank mit dem folgenden Befehl.
Wenn Sie die Tabelle orders öffnen, sehen Sie die neuen Einträge für Bestellungen.
Erstellen Sie das Repository
Bevor wir ein Repository für das Modell Order
erstellen, brauchen wir noch eine Schnittstelle mit der Deklaration aller Methoden. Unser Controller (und alle künftigen order-Komponenten) soll nicht direkt von der Repository-Klasse, sondern von der Schnittstelle abhängen.
Dadurch wird der Code flexibler, weil sich künftige Änderungen nicht auf den Controller auswirken. Wenn Sie sich irgendwann entscheiden, die Bestellverwaltung an die Anwendung eines Drittanbieters auszulagern, können Sie ein neues Modul passend zur Signatur von OrderRepositoryInterface
entwerfen und die Bindungsdeklarationen austauschen. Der Controller funktioniert trotzdem wie erwartet, ohne dass eine einzige Codezeile im Controller geändert werden muss.
Erstellen Sie im Verzeichnis App einen neuen Ordner mit dem Namen Interfaces. Erstellen Sie anschließend in Interfaces eine neue Datei namens OrderRepositoryInterface.php und fügen Sie darin den folgenden Code ein.
Erstellen Sie dann im Verzeichnis App einen neuen Ordner namens Repositories. Erstellen Sie in diesem Ordner eine neue Datei namens OrderRepository.php und fügen Sie darin den folgenden Code ein.
Abgesehen von der Flexibilität, die die Schnittstelle bietet, hat eine derartige Verkapselung der Abfragen den zusätzlichen Vorteil, dass Sie Abfragen innerhalb der Anwendung nicht duplizieren müssen.
Wenn Sie künftig beschließen, mit der Funktion getAllOrders()
nur Bestellungen abzurufen, die nicht ausgeführt wurden, müssen Sie nur an einer Stelle etwas ändern, statt alle Deklarationen von Order::all()
herauszusuchen und dabei das Risiko einzugehen, dass Sie einige übersehen.
Erstellen Sie die Controller
Nachdem das Repository fertig ist, können Sie jetzt den Code für den Controller hinzufügen. Öffnen Sie app/Http/Controllers/OrderController.php und aktualisieren Sie den Code wie folgt.
Über den Konstruktor fügt der Code die Instanz OrderRepositoryInterface
ein, wobei die entsprechenden Objektmethoden aus der jeweiligen Controller-Methode zur Anwendung kommen.
Im Rahmen der Methode index()
ruft er die im orderRepository
definierte Methode getAllOrders()
auf, um die Liste der Bestellungen abzurufen, und gibt eine Antwort im JSON-Format zurück.
Anschließend ruft die Methode store()
die Methode createOrder()
aus dem orderRepository
auf, um eine neue Bestellung zu erstellen. Damit werden die Details der Bestellung als Array erstellt und anschließend wird eine erfolgreiche Antwort zurückgegeben.
Im Controller wird innerhalb der Methode show()
die eindeutige Id
der Bestellung aus der Route abgerufen und als Parameter an die Methode getOrderById()
übergeben. Damit werden die Details der Bestellung mit der passenden ID aus der Datenbank abgerufen und eine Antwort im JSON-Format zurückgegeben.
Um anschließend die Details einer bereits erstellten Bestellung zu aktualisieren, wird aus dem Repository die Methode updateOrder()
aufgerufen. Dazu sind zwei Parameter nötig: die eindeutige ID der Bestellung und die zu aktualisierenden Details.
Abschließend ruft die Methode destroy()
die eindeutige ID einer bestimmten Bestellung aus der Route ab und löscht sie mit der Methode deleteOrder()
aus dem Repository.
Fügen Sie Routen hinzu
Um jede der im Controller definierten Methoden einer spezifischen Route zuzuordnen, müssen Sie den folgenden Code zu routes/api.php hinzufügen.
Binden Sie Schnittstelle und Implementierung
Der letzte Schritt besteht darin, das OrderRepository
an das OrderRepositoryInterface
im Service Container von Laravel zu binden. Dafür nutzen wir einen Serviceanbieter. Erstellen Sie einen Anbieter über den folgenden Befehl.
Öffnen Sie app/Providers/RepositoryServiceProvider.php und aktualisieren Sie die Funktion register
wie folgt.
Fügen Sie abschließend den neuen Serviceanbieter zum Array providers
in config/app.php hinzu.
Testen Sie die Anwendung
Führen Sie die Anwendung mithilfe des folgenden Befehls aus.
Standardmäßig ist die zugehörige Anwendung unter http://127.0.0.1:8000/ verfügbar. Mit Postman oder cURL können Sie Abfragen an die neu erstellte API stellen.
Führen Sie den folgenden Befehl aus, um den Endpunkt /api/orders
mit cURL zu testen:
Die JSON-Ausgabe in Ihrem Terminal sollte in etwa so aussehen wie das Beispiel unten, das zur besseren Lesbarkeit gekürzt wurde.
Und so verwenden Sie das Repository-Muster in einer Laravel-Anwendung
In diesem Artikel haben Sie das Repository-Muster und dessen Verwendung in einer Laravel-Anwendung kennengelernt. Sie haben auch von einigen Vorteilen für große Projekte erfahren – einer davon ist lose gekoppelter Code, bei dem Sie nach Abstraktionen statt nach konkreten Implementierungen programmieren.
Noch ein abschließender Hinweis: Für kleine Projekte ist dieser Ansatz ziemlich arbeitsintensiv und basiert auf Bausteinen, deren Vorteile sich nicht unbedingt auf den ersten Blick erschließen. Deshalb sollten Sie sich gut überlegen, ob der Umfang Ihres Projekts diese Vorgehensweise rechtfertigt.
Die gesamte Codebasis dieses Tutorials finden Sie auf GitHub. Informieren Sie sich dort gern weiter. Viel Spaß beim Programmieren!
Oluyemi ist Technikfan und kommt eigentlich aus dem Bereich der Telekommunikation. Da er so viel Spaß daran hat, Benutzenden bei ihren alltäglichen Problemen zu helfen, wagte er schließlich den Sprung in die Programmierung. Sein Hauptschwerpunkt liegt seitdem in der Entwicklung von Software für das Internet und mobile Endgeräte.
Oluyemi ist Full-Stack-Entwickler und gibt sein Wissen leidenschaftlich gern an andere weiter. Im Internet finden sich zahlreiche von ihm verfasste technische Artikel und Beiträge in verschiedenen Blogs. Als bekennender Technik-Freak zählt er auch das Austesten neuer Programmiersprachen und Frameworks zu seinen Hobbys.
Verwandte Posts
Ähnliche Ressourcen
Twilio Docs
Von APIs über SDKs bis hin zu Beispiel-Apps
API-Referenzdokumentation, SDKs, Hilfsbibliotheken, Schnellstarts und Tutorials für Ihre Sprache und Plattform.
Ressourcen-Center
Die neuesten E-Books, Branchenberichte und Webinare
Lernen Sie von Customer-Engagement-Experten, um Ihre eigene Kommunikation zu verbessern.
Ahoy
Twilios Entwickler-Community-Hub
Best Practices, Codebeispiele und Inspiration zum Aufbau von Kommunikations- und digitalen Interaktionserlebnissen.