extensibility:plugins-generic
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende Überarbeitung | ||
| extensibility:plugins-generic [2024/08/20 15:54] – [Beispiel] dlatikay | extensibility:plugins-generic [Unbekanntes Datum] (aktuell) – gelöscht - Externe Bearbeitung (Unbekanntes Datum) 127.0.0.1 | ||
|---|---|---|---|
| Zeile 1: | Zeile 1: | ||
| - | ====== Plugins (Standarderweiterungen) ====== | ||
| - | |||
| - | Diese Art von Plugins ermöglicht es, in die Standardlogik aller CAATS-Dienste einzugreifen, | ||
| - | |||
| - | ===== Beschreibung ===== | ||
| - | |||
| - | Die Standardfunktionen und Einsprungpunkte sind: | ||
| - | - Abrufen einzelner Datensätze (vor Datenbankzugriff) | ||
| - | - Abrufen einzelner Datensätze (nach Datenbankzugriff) | ||
| - | - Abrufen einer Liste von Datensätzen (vor Datenbankzugriff) | ||
| - | - Abrufen einer Liste von Datensätzen (nach Datenbankzugriff) | ||
| - | - Neuen Datensatz mit Initialwerten anfordern | ||
| - | - Anlegen (vor Speicherung) | ||
| - | - Anlegen (nach Speicherung) | ||
| - | - Aktualisieren (vor Speicherung) | ||
| - | - Aktualisieren (nach Speicherung) | ||
| - | - Löschen (vor Speicherung) | ||
| - | |||
| - | Wird eine dieser Standardfunktionen durch ein Plugin ergänzt, so steht es dem Autor des Plugins frei, die übergebenen Daten zu verwerfen, beizubehalten, | ||
| - | |||
| - | Im Falle des Abrufens einer Liste von Datensätzen (Punkt 3) steht es dem Autor des Plugins außerdem frei, die übergebenen Filter-, Sortierungs- und Gruppierungskriterien vor dem Ausführen des Datenbankzugriffes zu ändern. | ||
| - | |||
| - | ===== Beispiel ===== | ||
| - | |||
| - | Dieses Beispiel ersetzt den Vornamen aller neu angelegten Klienten durch den Vornamen " | ||
| - | |||
| - | <file csharp generic_plugin_example.cs> | ||
| - | using Grpc.Core; | ||
| - | using System; | ||
| - | using System.Security.Cryptography; | ||
| - | using System.Threading.Tasks; | ||
| - | |||
| - | using Caats.Infrastructure.Authorization; | ||
| - | using Caats.Infrastructure.Constants; | ||
| - | using Caats.Infrastructure.Helper; | ||
| - | using Caats.Proto; | ||
| - | |||
| - | using Caats.Services.PersonAPI.Infrastructure; | ||
| - | using Caats.Services.PersonAPI.Repositories; | ||
| - | |||
| - | namespace Caats.Service.Infrastructure.Extensibility; | ||
| - | |||
| - | [PluginServiceDto(typeof(PersonDto))] | ||
| - | public class MyTestCaatsPersonPlugin : PluginBase | ||
| - | { | ||
| - | private readonly IPersonRepository _repository; | ||
| - | |||
| - | public MyTestCaatsPersonPlugin(IPersonRepository repository) | ||
| - | { | ||
| - | _repository = repository; | ||
| - | } | ||
| - | |||
| - | public override PluginDto Ident() => new() { }; | ||
| - | |||
| - | public async override Task< | ||
| - | { | ||
| - | var candidate = RequestMsgHelper.GetSingleOrDefault< | ||
| - | |||
| - | candidate.GivenName = "Alle heißen Franz"; | ||
| - | |||
| - | var modified = RequestMsgHelper.CreateWithSingle(candidate); | ||
| - | |||
| - | modified.PartitionIndex = request.PartitionIndex; | ||
| - | |||
| - | return (modified, null); | ||
| - | } | ||
| - | }</ | ||
| - | |||
| - | |||
| - | ===== Fehlercodes und Lösungen ===== | ||
| - | |||
| - | Beim Programmieren von standarderweiternden Plugins können - abseits von den Warnungen und Fehlermeldungen des C# Compilers - folgende CAATS-spezifische Fehlercodes vorkommen: | ||
| - | |||
| - | ^ Fehlercode | ||
| - | | CAATS0001 | No suitable public type for installable plugin | Definiern Sie in Ihrem Skript eine öffentliche Klasse des verlangten Basistyps | | ||
| - | | CAATS0003 | Installable plugin exposes more than one plugin type | Reduzieren Sie die Anzahl der öffentlichen Klassen des angegebenen Basistyps in Ihrem Skript auf 1 | | ||
extensibility/plugins-generic.1724169254.txt.gz · Zuletzt geändert: von dlatikay
