-
Notifications
You must be signed in to change notification settings - Fork 1
IOrganizationService Extensions
Set of extension methods for IOrganizationService base class. Most of these are simple overrides of existing methods which take EntityReference or Entity instead of separate Id
and LogicalName
parameters. But you also can take some advantage of alternative keys support or working with large datasets.
Associate & Disassociate methods override. Take EntityReference (instead of separate Id + LogicalName) input parameter.
Alternative keys are supported since v 1.0.43
public void Associate(EntityReference primaryEntity, Relationship relationship, EntityReferenceCollection relatedEntities);
public void Associate(EntityReference primaryEntity, Relationship relationship, IList<EntityReference> relatedEntities);
public void Associate(EntityReference primaryEntity, String relationshipName, EntityReferenceCollection relatedEntities);
public void Associate(EntityReference primaryEntity, String relationshipName, IList<EntityReference> relatedEntities);
public void Disassociate(EntityReference primaryEntity, Relationship relationship, EntityReferenceCollection relatedEntities);
public void Disassociate(EntityReference primaryEntity, Relationship relationship, IList<EntityReference> relatedEntities);
public void Disassociate(EntityReference primaryEntity, String relationshipName, EntityReferenceCollection relatedEntities);
public void Disassociate(EntityReference primaryEntity, String relationshipName, IList<EntityReference> relatedEntities);
Delete method override. Take EntityReference (instead of separate Id + LogicalName) input parameter.
Alternative keys are supported since v 1.0.29
public void Delete(EntityReference reference);
public void Delete(Entity entity);
Delete method override. Deletes using Alternative keys instead of Id. This one use Execute under the hood
public void Delete(string logicalName, KeyAttributeCollection keyAttributeCollection);
public void Delete(string logicalName, string keyName, object keyValue);
Introduced in version 1.0.38
Generic Execute methods override. Returns response as the specified type. Requires the same amount of typing as any other form of casting. Useless.
public T Execute<T>(OrganizationRequest request) where T : OrganizationResponse;
Introduced in version 1.5.0 deprecated in version 2.2.0
Execute batch of requests using ExecuteMultipleRequest
while taking care of butch size
Warning: NEVER use this extension as well as
ExecuteMultipleRequest
itself in Plugin code. It can lead to deadlocks and performance issues
In other cases it should significantly improve performance compared to the ordinary for
or Parallel.For
loops
public IEnumerable<ExecuteMultipleResponse> Execute(IEnumerable<OrganizationRequest> requests, int batchSize = 1000, ExecuteMultipleSettings settings = null);
This is experimental feature:
You can use ExecuteMultipleResponse.GetRequests()
or ExecuteMultipleResponse.GetRequest(ExecuteMultipleResponseItem item)
to access actual OrganizationRequest
objects used to perform the operation. It may be useful to understand status of each particular request
Retrieve method override. Take EntityReference (instead of separate Id + LogicalName) input parameter.
Alternative keys are supported since v 1.0.29
public Entity Retrieve(EntityReference reference, ColumnSet columnSet);
public Entity Retrieve(EntityReference reference, params String[] columns);
Generic version of Retrieve.
public T Retrieve<T>(EntityReference reference, ColumnSet columnSet) where T : Entity;
public T Retrieve<T>(EntityReference reference, params String[] columns) where T : Entity;
Retrieve method override. Take EntityReference instead of Id. This one use Execute under the hood
public Entity Retrieve(string logicalName, KeyAttributeCollection keyAttributeCollection, ColumnSet columnSet);
public Entity Retrieve(string logicalName, string keyName, object keyValue, ColumnSet columnSet);
public Entity Retrieve(string logicalName, string keyName, object keyValue, params string[] columns);
Generic version of by Alternative key. This one use Execute under the hood
public T Retrieve<T>(string logicalName, string keyName, string keyValue, ColumnSet columnSet) where T : Entity;
public T Retrieve<T>(string logicalName, string keyName, string keyValue, params String[] columns) where T : Entity
Introduced in version 1.0.38
RetrieveMultiple methods override. Returns all pages using callback or 'yield' iterator. This implementation should be very cost effective as new pages are loaded on demand (lazy loadind). You also can use callback function to access original EntityCollection properties. Callback function is executed on each page load.
Warning: Callback is executed only then you use iterator.
public IEnumerable<Entity> RetrieveMultiple(QueryBase query, Action<EntityCollection> callback = null);
public IEnumerable<Entity> RetrieveMultiple(FetchExpression query, Action<EntityCollection> callback = null);
Introduced in version 1.0.38
public IEnumerable<Entity> RetrieveMultiple(string fetchXml, Action<EntityCollection> callback = null);
public EntityCollection RetrieveMultiple(string fetchXml);
Introduced in version 1.0.42
A shortcut for Upsert message
public EntityReference Upsert(Entity entity);
Introduced in version 1.2
Update method override. Take ConcurrencyBehavior enum as second parameter.
public void Update(Entity entity, ConcurrencyBehavior concurrencyBehavior);
Introduced in 2.2.0
Execute batch of requests using ExecuteMultipleRequest
while taking care of butch size
Warning: NEVER use this extension as well as
ExecuteMultipleRequest
itself in Plugin code. It can lead to deadlocks and performance issues
In other cases it should significantly improve performance compared to the ordinary for
or Parallel.For
loops
public IEnumerable<ExecuteMultipleOperationResponse> Execute(IEnumerable<OrganizationRequest> requests, int batchSize = 100, ExecuteMultipleSettings settings = null, Action<OrganizationRequestCollection, ExecuteMultipleResponse> callback = null)
Introduced in 2.2.0
Runs query and executes action for each retrieved Entity using ExecuteMultipleRequest
Warning: NEVER use this extension as well as
ExecuteMultipleRequest
itself in Plugin code. It can lead to deadlocks and performance issues
In other cases it should significantly improve performance compared to the ordinary for
or Parallel.For
loops
Warning: this method will run immediately after the call and may take a lot of time to complete depending on the amount of data and particular
OrganizationRequest
performance. You can use CancellationToken to cancel operation at any time.
public void Execute(QueryBase query, Func<Entity, OrganizationRequest> toRequest, ExecuteMultipleSettings settings = null, int batchSize = 100, Action<ExecuteMultipleOperationResponse> onResponse = null, Action<ExecuteMultipleProgress> onProgress = null, CancellationToken cancellationToken = default)