Benutzerdefinierte Dataverse-Logik umgehen
Es gibt Zeiten, in denen Sie in der Lage sein wollen, Datenoperationen durchzuführen, ohne dass eine benutzerdefinierte Geschäftslogik in Dataverse angewendet wird. Diese Szenarien umfassen normalerweise Massendatenvorgänge, bei denen eine große Anzahl von Datensätzen erstellt, aktualisiert oder gelöscht wird.
Da es keine Möglichkeit gibt, Dataverse anzuweisen, die Geschäftslogik nicht aufzurufen, müssen Sie die einzelnen benutzerdefinierten Plug-Ins und Workflows, die die Geschäftslogik enthalten, suchen und deaktivieren. Das Deaktivieren von Plug-Ins und Workflows bedeutet, dass die Logik für alle Benutzer deaktiviert wird, während diese Plug-Ins und Workflows deaktiviert werden. Es bedeutet auch, dass Sie darauf achten müssen, nur die richtigen Plug-Ins und Workflows zu deaktivieren, und daran denken müssen, sie wieder zu aktivieren, wenn Sie fertig sind.
Anstelle dieses manuellen Prozesses können Sie als Entwickler einer Clientanwendung oder eines Plug-Ins spezielle optionale Parameter mit Ihren Anforderungen übergeben, um zwei Arten benutzerdefinierter Geschäftslogik zu steuern, wie in der folgenden Tabelle beschrieben:
Logiktyp | Wann sollte umgangen werden? |
---|---|
Synchrone Logik | Damit Massendatenvorgänge so schnell wie möglich abgeschlossen werden können. Umgehen Sie die synchrone Logik, wenn bekannt ist, dass die Daten, die Sie ändern, den Anforderungen der Organisation entsprechen, oder Sie planen, diese Logik auf andere Weise zu erreichen. Umgehen Sie die gesamte benutzerdefinierte synchrone Logik, sodass jeder Vorgang schneller abgeschlossen werden kann, wodurch die Gesamtzeit des Massenvorgangs verkürzt wird. |
Asynchrone Logik | Wenn eine große Anzahl von Systemaufträgen zur Verarbeitung asynchroner Logik erstellt wird, entsteht eine Verzögerung in Dataverse, welche die Leistung beeinträchtigen kann. Sie können dieses Leistungsproblem mildern, indem Sie beim Ausführen von Massenvorgängen die asynchrone Logik nicht auslösen. |
Anmerkung
Power Automate Flows stellen einen anderen Typ asynchroner Logik dar, der separat verwaltet werden kann. Siehe Power Automate-Flows umgehen
Optionale Parameter
Verwenden Sie diese optionalen Parameter, um die Geschäftslogik zu steuern, die in Dataverse ausgeführt wird:
Optionaler Parameter | Beschreibung |
---|---|
BypassBusinessLogicExecution |
Übergeben Sie die Werte CustomSync , CustomAsync oder CustomSync,CustomAsync für diesen optionalen Parameter, um die synchrone Logik, die asynchrone Logik oder beide zu umgehen. |
BypassBusinessLogicExecutionStepIds |
Übergeben Sie eine durch Kommas getrennte Liste von Plug-In-Schrittregistrierungen, um nur die angegebenen Plug-In-Schritte zu umgehen. |
BypassCustomPluginExecution |
Umgehen Sie nur die synchrone Logik. Dieser optionale Parameter wird unterstützt, aber nicht empfohlen. Verwenden Sie BypassBusinessLogicExecution mit dem CustomSync -Wert, um dasselbe Ergebnis zu erhalten. |
BypassBusinessLogicExecution
Der optionale BypassBusinessLogicExecution
-Parameter funktioniert ähnlich wie der optionale Parameter BypassCustomPluginExecution
, außer dass Sie wählen können, ob die synchrone Logik, die asynchrone Logik oder beides umgangen werden soll.
Dieser optionale Parameter zielt auf die benutzerdefinierte Geschäftslogik, die für Ihr Unternehmen angewendet wurde. Wenn Sie Anforderungen senden, die die benutzerdefinierte Geschäftslogik umgehen, werden alle benutzerdefinierten Plug-Ins und Workflows deaktiviert, außer:
- Plug-Ins, die Teil des Microsoft Dataverse-Kernsystems oder Teil einer Lösung sind, bei der Microsoft der Herausgeber ist.
- Workflows, die in einer Lösung enthalten sind, bei der Microsoft der Herausgeber ist.
System-Plug-ins definieren die Kernverhaltensweisen für bestimmte Entitäten. Ohne diese Plug-Ins würden Sie auf Dateninkonsistenzen stoßen, die möglicherweise nicht leicht zu beheben sind.
Von Microsoft ausgelieferte Lösungen, die Dataverse verwenden, wie z. B. Microsoft Dynamics 365 Customer Service oder Dynamics 365 Sales enthalten auch kritische Geschäftslogik, die mit dieser Option nicht umgangen werden kann.
Wichtig
Sie haben möglicherweise Lösungen von anderen unabhängigen Software-Anbietern (ISVs) erworben und installiert, die ihre eigene Geschäftslogik enthalten. Die Logik, die von diesen Lösungen angewendet wird, wird umgangen. Sie sollten sich mit diesen ISVs in Verbindung setzen, bevor Sie diese Option verwenden, um zu verstehen, welche Auswirkungen es haben kann, wenn Sie diese Option mit Daten verwenden, die deren Lösungen nutzen.
In der folgenden Tabelle wird beschrieben, wann die Parameterwerte mit BypassBusinessLogicExecution
verwendet werden sollen.
Parameter | Beschreibung |
---|---|
CustomSync |
Umgehen Sie nur die synchrone benutzerdefinierte Logik. Die für die synchrone Logik erforderliche Rechenzeit addiert sich zur Gesamtzeit, die zum Ausführen jeder Datenoperation erforderlich ist. Verwenden Sie diese Option, um die zum Abschließen von Massenvorgängen erforderliche Zeit zu verkürzen. |
CustomAsync |
Umgehen Sie nur die asynchrone benutzerdefinierte Logik, ausgenommen Power Automate-Flows. Dataverse wendet asynchrone Logik an, nachdem ein Vorgang abgeschlossen ist. Wenn eine große Anzahl von Operationen asynchrone Logik auslöst, erfordert Dataverse mehr Ressourcen, um die benutzerdefinierte Logik zu verarbeiten, und dieser Ressourcenverbrauch kann sich auf die Leistung auswirken. Verwenden Sie diese Option, um allgemeine Leistungsprobleme zu vermeiden, die auftreten können, wenn eine große Anzahl von Vorgängen asynchrone Logik auslöst. |
CustomSync,CustomAsync |
Umgehen Sie synchrone und asynchrone benutzerdefinierte Logik, ausgenommen Power Automate-Flows. |
Voraussetzungen für die Verwendung des optionalen BypassBusinessLogicExecution
-Parameters
- Sie müssen die Anforderungen mit dem optionalen Parameter
BypassBusinessLogicExecution
senden. - Der Benutzer, der die Anfragen sendet, muss die Berechtigung
prvBypassCustomBusinessLogic
haben. Standardmäßig haben nur Benutzer mit der Sicherheitsrolle "Systemadministrator" diese Berechtigung. Erfahren Sie, wie Sie dieprvBypassCustomBusinessLogic
-Berechtigung einer anderen Rolle hinzufügen
Wie nutze ich den optionalen BypassBusinessLogicExecution
-Parameter?
Sie können diese Option entweder mit dem SDK für .NET oder der Web-API verwenden.
Das folgende Beispiel legt den optionalen Parameter BypassBusinessLogicExecution
für synchrone und asynchrone benutzerdefinierte Logik beim Erstellen eines neuen Kontodatensatzes mit dem SDK für .NET CreateRequest-Klasse fest.
static void DemonstrateBypassBusinessLogicExecution(IOrganizationService service)
{
Entity account = new("account");
account["name"] = "Sample Account";
CreateRequest request = new()
{
Target = account
};
request.Parameters.Add("BypassBusinessLogicExecution", "CustomSync,CustomAsync");
service.Execute(request);
}
BypassBusinessLogicExecutionStepIds
Verwenden Sie den optionalen BypassBusinessLogicExecutionStepIds
-Parameter, um angegebene registrierte Plug-In-Schritte anstelle der gesamten synchronen und asynchronen benutzerdefinierten Logik zu umgehen. Übergeben Sie mit diesem Parameter die GUID-Werte der registrierten Plug-In-Schrittregistrierungen. Wenn die übergebene Schritt-ID in der angegebenen Anforderung nicht ausgeführt wird, wird sie ignoriert.
Wie verwende ich die Option „BypassBusinessLogicExecutionStepIds“?
Sie können diese Option entweder mit dem SDK für .NET oder der Web-API verwenden.
Das folgende Beispiel bestimmt den optionalen BypassBusinessLogicExecutionStepIds
-Parameter beim Erstellen eines neuen Kontodatensatzes mithilfe der CreateRequest-Klasse.
static void DemonstrateBypassBusinessLogicExecutionStepIds(IOrganizationService service)
{
Entity account = new("account");
account["name"] = "Sample Account";
CreateRequest request = new()
{
Target = account
};
request.Parameters.Add("BypassBusinessLogicExecutionStepIds", "45e0c603-0d0b-466e-a286-d7fc1cda8361,d5370603-e4b9-4b92-b765-5966492a4fd7");
service.Execute(request);
}
Identifizieren Sie die Schritte, die Sie umgehen möchten
Es gibt mehrere Möglichkeiten, die GUID-Werte der Plug-In-Schrittregistrierung zu finden.
Das Plug-in-Registrierungstool verwenden
Wählen Sie im Menü Ansicht die Option Nach Entität anzeigen aus.
Wählen Sie die Entität und Nachricht aus
Wählen Sie den Schritt.
Im Detailbereich wird auf der Registerkarte Eigenschaften die StepId angezeigt. Kopieren Sie den Wert von dort.
Weitere Informationen zum Plug-In-Registrierungstool
Ihre Umgebung mit Web-Api abfragen
Verwenden Sie eine Abfrage wie die folgende, um die festgelegten Plug-In-Schrittregistrierungen für eine bestimmte Tabelle und Nachricht abzurufen. Das folgende Beispiel gibt die account
-Tabelle unter Verwendung des logischen Tabellennamens an. Create
ist der Name der Nachricht. Ersetzen Sie diese Werte durch die Tabelle und Nachricht, die Sie benötigen.
Anfordern
GET [Organization URI]/api/data/v9.2/sdkmessagefilters?$select=sdkmessagefilterid
&$filter=primaryobjecttypecode eq 'account'
and sdkmessageid/name eq 'Create'
&$expand=sdkmessagefilterid_sdkmessageprocessingstep($select=name;
$filter=statecode eq 0
and customizationlevel eq 1
and iscustomizable/Value eq true)
Accept: application/json
OData-MaxVersion: 4.0
OData-Version: 4.0
Response
Suchen Sie in der Antwort nach den sdkmessageprocessingstepid
-Werten. Verwenden Sie den Wert name
, um das Plug-In zu identifizieren, das Sie umgehen möchten.
In diesem Fall gibt es nur eines: 4ab978b0-1d77-ec11-8d21-000d3a554d57
{
"@odata.context": "[Organization URI]/api/data/v9.2/$metadata#sdkmessagefilters(sdkmessagefilterid,sdkmessagefilterid_sdkmessageprocessingstep(name))",
"value": [
{
"@odata.etag": "W/\"31434372\"",
"sdkmessagefilterid": "c2c5bb1b-ea3e-db11-86a7-000a3a5473e8",
"sdkmessagefilterid_sdkmessageprocessingstep": [
{
"@odata.etag": "W/\"115803276\"",
"name": "BasicPlugin.FollowupPlugin: Create of account",
"_sdkmessagefilterid_value": "c2c5bb1b-ea3e-db11-86a7-000a3a5473e8",
"sdkmessageprocessingstepid": "4ab978b0-1d77-ec11-8d21-000d3a554d57"
}
],
"sdkmessagefilterid_sdkmessageprocessingstep@odata.nextLink": "[Organization URI]/api/data/v9.2/sdkmessagefilters(c2c5bb1b-ea3e-db11-86a7-000a3a5473e8)/sdkmessagefilterid_sdkmessageprocessingstep?$select=name&$filter=statecode%20eq%200%20and%20customizationlevel%20eq%201%20and%20iscustomizable/Value%20eq%20true"
}
]
}
Weitere Informationen zum Abfragen von Daten mit der Web-API
Ihre Umgebung mit FetchXml abfragen
Verwenden Sie eine Abfrage wie die folgende, um die festgelegten Plug-In-Schrittregistrierungen für eine bestimmte Tabelle und Nachricht abzurufen. Das folgende Beispiel gibt 1
an, um die account
-Tabelle darzustellen, unter Verwendung des Tabellenobjekttypcodes.
Anmerkung
Bei Tabellen, deren Objekttypcode größer als 10000
ist, ist der Wert nicht in jeder Umgebung derselbe, da diesem Wert beim Erstellen der Tabelle ein inkrementeller Wert zugewiesen wird.
Wenn Sie den logischen Namen der Tabelle kennen, können Sie den Objekttypcode mithilfe einer Web-API-Anforderung abrufen. Diese Anforderung gibt den Wert 1
zurück, den Objekttypcode für die account
-Tabelle.
GET [Organization URI]/api/data/v9.2/EntityDefinitions(LogicalName='account')/ObjectTypeCode/$value
Create
ist der Name der Nachricht. Ersetzen Sie diese Werte durch die Tabelle und Nachricht, die Sie benötigen.
Verwenden Sie diese FetchXml-Abfrage, um step.sdkmessageprocessingstepid
-Werte zurückzugeben, die Sie mit dem optionalen Parameter BypassBusinessLogicExecutionStepIds
verwenden können.
<fetch>
<entity name='sdkmessagefilter'>
<filter>
<condition attribute='primaryobjecttypecode'
operator='eq'
value='1' />
</filter>
<link-entity name='sdkmessage'
from='sdkmessageid'
to='sdkmessageid'
link-type='inner'
alias='message'>
<filter>
<condition attribute='name'
operator='eq'
value='Create' />
</filter>
</link-entity>
<link-entity name='sdkmessageprocessingstep'
from='sdkmessagefilterid'
to='sdkmessagefilterid'
link-type='inner'
alias='step'>
<attribute name='name' />
<filter>
<condition attribute='statecode'
operator='eq'
value='0' />
<condition attribute='customizationlevel'
operator='eq'
value='1' />
<condition attribute='iscustomizable'
operator='eq'
value='1' />
</filter>
</link-entity>
</entity>
</fetch>
Weitere Informationen zum Abfragen von Daten mit FetchXml
Beschränken auf die Anzahl von Schritten
Um sicherzustellen, dass die Parametergröße nicht zu groß wird, beträgt die Standardbegrenzung für die Anzahl der Schritte, die Sie übergeben können, drei. Die Begrenzung wird mithilfe von Daten in der Spalte „OrgDbOrgSettings“ der Organisationstabelle gesteuert. Verwenden Sie das OrgDBOrgSettings-Tool für Microsoft Dynamics CRM oder die OrgDbOrgSettings-App, um den BypassBusinessLogicExecutionStepIdsLimit
-Wert zu ändern.
Die maximal empfohlene Größe für diese Begrenzung beträgt 10 Schritte.
BypassCustomPluginExecution
Verwenden Sie den optionalen Parameter BypassCustomPluginExecution
, um benutzerdefinierte synchrone Logik zu umgehen.
Anmerkung
Dies war der erste optionale Parameter, der eine Einschränkung der Geschäftslogik ermöglichte. Er wird weiterhin unterstützt, wir empfehlen jedoch, BypassBusinessLogicExecution
mit dem CustomSync
-Wert zu verwenden, um dasselbe Ergebnis zu erzielen.
Verwenden Sie diesen optionalen Parameter auf die gleiche Weise wie BypassBusinessLogicExecution
, mit dem Unterschied, dass er eine andere Berechtigung erfordert: prvBypassCustomPlugins
Wie verwende ich die Option BypassCustomPluginExecution?
Sie können diese Option entweder mit dem SDK für .NET oder der Web-API verwenden.
Es gibt zwei Möglichkeiten, diesen optionalen Parameter mit dem SDK für .NET zu verwenden.
Legen Sie den Wert als optionalen Parameter fest
Das folgende Beispiel bestimmt den optionalen BypassCustomPluginExecution
-Parameter beim Erstellen eines neuen Kontodatensatzes mithilfe der CreateRequest-Klasse.
static void DemonstrateBypassCustomPluginExecution(IOrganizationService service)
{
Entity account = new("account");
account["name"] = "Sample Account";
CreateRequest request = new()
{
Target = account
};
request.Parameters.Add("BypassCustomPluginExecution", true);
service.Execute(request);
}
Sie können diese Methode für Datenvorgänge verwenden, die Sie in Ihren Plug-Ins initiieren, wenn der aufrufende Benutzer das prvBypassCustomPlugins
-Recht besitzt.
Legen Sie die CrmServiceClient.BypassPluginExecution-Eigenschaft fest
Das folgende Beispiel setzt die CrmServiceClient.BypassPluginExecution-Eigenschaft beim Erstellen eines neuen Kontodatensatzes:
var service = new CrmServiceClient(connectionString);
service.BypassPluginExecution = true;
var account = new Entity("account");
account["name"] = "Sample Account";
service.Create(account);
Da diese Einstellung auf den Dienst angewendet wird, bleibt sie für alle Anforderungen gesetzt, die über den Dienst gesendet werden, bis sie auf false
gesetzt wird.
Lesen Sie die folgenden wichtigen Informationen zur Verwendung einer Verbindungszeichenfolge im Anwendungscode.
Wichtig
Microsoft empfiehlt, den sichersten verfügbaren Authentifizierungsflow zu verwenden. Der in diesem Artikel beschriebene Authentifizierungsablauf erfordert ein sehr hohes Maß an Vertrauen in die Anwendung und birgt Risiken, die in anderen Flows nicht vorhanden sind. Sie sollten diesen Flow nur verwenden, wenn andere, sicherere Flows, z. B. verwaltete Identitäten, nicht funktionsfähig sind.
Anmerkung
Diese Eigenschaft ist nicht im Dataverse.Client.ServiceClient, aber in den Dataverse.Client.Extensions.CRUDExtentions-Methoden verfügbar.
Einer anderen Rolle die erforderlichen Berechtigungen hinzufügen
Die in diesem Artikel beschriebenen optionalen Parameter erfordern Berechtigungen, die nur zur Systemadministrierenden-Sicherheitsrolle hinzugefügt werden. Diese Berechtigungen sind im Sicherheitsrollen-Designer nicht zum Hinzufügen zu anderen Sicherheitsrollen verfügbar. Wenn Sie dieses Recht einer anderen Sicherheitsrolle erteilen müssen, müssen Sie die API verwenden. Sie könnten dieses Recht z. B. einem Benutzer mit der Sicherheitsrolle „Systemanpasser“ gewähren.
Um das Recht einer anderen Sicherheitsrolle hinzuzufügen, benötigen Sie die ID des Rechts.
Name | Kennung | Optionale Parameter |
---|---|---|
prvBypassCustomBusinessLogic |
0ea552b0-a491-4470-9a1b-82068deccf66 |
BypassBusinessLogicExecution BypassBusinessLogicExecutionStepIds |
prvBypassCustomPlugins |
148a9eaf-d0c4-4196-9852-c3a38e35f6a1 |
BypassCustomPluginExecution |
Diese ID-Werte sind für alle Dataverse-Umgebungen gleich.
Ordnen Sie das prvBypassCustomBusinessLogic
-Recht einer Sicherheitsrolle mit AddPrivilegesRoleRequest zu.
static void AddprvBypassCustomPluginsToRole(IOrganizationService service, Guid roleId)
{
var request = new AddPrivilegesRoleRequest
{
RoleId = roleId,
Privileges = new[]{
new RolePrivilege{
PrivilegeId = new Guid("0ea552b0-a491-4470-9a1b-82068deccf66"),
Depth = PrivilegeDepth.Global
}
}
};
service.Execute(request);
}
Häufig gestellte Fragen zum Umgehen von Geschäftslogik (FAQ)
Nachfolgend finden Sie häufig gestellte Fragen zur Verwendung optionaler Parameter zum Umgehen synchroner Geschäftslogik.
Umgehen diese optionalen Parameter Plug-Ins für Datenoperationen durch Microsoft-Plug-Ins?
Nein. Wenn ein Plug-In oder Workflow in einer Microsoft-Lösung Operationen auf anderen Datensätzen durchführt, wird die Logik für diese Operationen nicht umgangen. Es werden nur die Plug-Ins oder Workflows umgangen, die für den spezifischen Vorgang gelten.
Kann ich diese optionalen Parameter für Datenoperationen verwenden, die ich innerhalb eines Plug-Ins durchführe?
Ja, aber nur, wenn das Plug-In im Kontext von Benutzenden läuft, welche die erforderliche Berechtigung haben. Für Plug-Ins setzen Sie den optionalen Parameter auf die von der OrganizationRequest-Klasse abgeleitete Klasse. Sie können die Klassen CrmServiceClient oder ServiceClient nicht in einem Plug-In verwenden.