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 14:15] – adm-dlatikay | extensibility:plugins-generic [2024/08/20 16:27] (aktuell) – [Fehlercodes und Lösungen] dlatikay | ||
---|---|---|---|
Zeile 2: | Zeile 2: | ||
Diese Art von Plugins ermöglicht es, in die Standardlogik aller CAATS-Dienste einzugreifen, | Diese Art von Plugins ermöglicht es, in die Standardlogik aller CAATS-Dienste einzugreifen, | ||
+ | |||
+ | ===== Beschreibung ===== | ||
Die Standardfunktionen und Einsprungpunkte sind: | Die Standardfunktionen und Einsprungpunkte sind: | ||
Zeile 11: | Zeile 13: | ||
- Anlegen (vor Speicherung) | - Anlegen (vor Speicherung) | ||
- Anlegen (nach Speicherung) | - Anlegen (nach Speicherung) | ||
- | - Aktualisieren (vor Speichrung) | + | - Aktualisieren (vor Speicherung) |
- Aktualisieren (nach Speicherung) | - Aktualisieren (nach Speicherung) | ||
- Löschen (vor 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, | 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. | 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 \\ //Each kind of plugin must use a well-known namespace and interface/ | ||
+ | | CAATS0003 | Installable plugin exposes more than one plugin type \\ //Each plugin script must export exactly one main class that satisfies the automator' | ||
extensibility/plugins-generic.1724163332.txt.gz · Zuletzt geändert: 2024/08/20 14:15 von adm-dlatikay