Org.Reddragonit.BpmEngine
2.0.0
dotnet add package Org.Reddragonit.BpmEngine --version 2.0.0
NuGet\Install-Package Org.Reddragonit.BpmEngine -Version 2.0.0
<PackageReference Include="Org.Reddragonit.BpmEngine" Version="2.0.0" />
paket add Org.Reddragonit.BpmEngine --version 2.0.0
#r "nuget: Org.Reddragonit.BpmEngine, 2.0.0"
// Install Org.Reddragonit.BpmEngine as a Cake Addin #addin nuget:?package=Org.Reddragonit.BpmEngine&version=2.0.0 // Install Org.Reddragonit.BpmEngine as a Cake Tool #tool nuget:?package=Org.Reddragonit.BpmEngine&version=2.0.0
BPMEngine
A BPMN Engine written in .net. The engine attempts to read in a bpmn notation xml document defining both the process(s) as well as the diagrams. From here you can then load/unload the state, render the diagram in its current state or animated into a gif. Using the delegates for a process, you intercept and handle task and condition checking by reading additional xml held within flow and task objects.
Current Test Status:
XSD
Adding xmlns:exts="https://raw.githubusercontent.com/roger-castaldo/BPMEngine/master/Extensions" to the bpmn:definitions will make things easier for accessing the defined xsd file for the project.
This references all the extended elements defined below.
Internal Conditions
Using bpmn:extensionElements inside a (bpmn:sequenceFlow,bpmn:process,bpmn:startEvent) you can specify conditions to be analyzed based on process variables and some basic comparisons by using a conditionSet xml tag with the following components inside.
Comparison Components
Tags: isEqualCondition, greaterThanCondition, lessThanCondition, greaterThanOrEqualCondition, lessThanOrEqualCondition Attributes:
- leftVariable : used to indicate the name of the variable to place on the left side of the comparison
- rightVariable : used to indicate the name of the variable to place on the right side of the comparison SubElements:
- left : used to indicate a constant value for the left side of the comparison
- right : used to indicate a constant value for the right side of the comparison Rules: A tag can contain either a leftVariable or left element as well as either a rightVariable or right element
Example: <isEqualCondition leftVariable="username"> <right>bob.loblaw</right> </isEqualCondition>
Negate Component
Used to negate the sub condition Tag: notCondition SubElements: andCondition, orCondition, isEqualCondition, greaterThanCondition, lessThanCondition, greaterThanOrEqualCondition, lessThanOrEqualCondition
Example: <notCondition> <isEqualCondition leftVariable="username"> <right>bob.loblaw</right> </isEqualCondition> </notCondition>
Null Check Component
Used to check if variable is null Tag: isNull Attributes: variable
Example: <isNull variable="username"/>
Comparison Collectors
Tags: andCondition, orCondition Attributes: none SubElements: andCondition, orCondition, notCondition, isEqualCondition, greaterThanCondition, lessThanCondition, greaterThanOrEqualCondition, lessThanOrEqualCondition
Example: <andCondition> <isEqualCondition leftVariable="firstName"> <right>bob</right> </isEqualCondition> <isEqualCondition leftVariable="lastName"> <right>loblaw</right> </isEqualCondition> </andCondition>
Dynamic Internal Code
Executing Script tasks internally with dynamically compiled C#/VB.Net code. Simple place an bpmn:extensionElements inside a script task and supply the following elements inside. These script tags can also be used inside condition sets to return a boolean value for more complex condition checking.
Tags: cSharpScript (for C# code), VBScript (for VB.Net code) SubElements: code, using, dll
Within the script element tag, either place the code (assuming there is no references required) or place the sub elements including 1 code element. To acess the variables for the process at that point, the variable variables is passed into the code, which is an instance of ProcessVariablesContainer. Any changes made to the variables object will be passed back into the system and the process variables updated for that step.
The using tag should contain a namespace reference as its value, the script tag will take care of the formatting in the code, for example: System.Data The dll tag should contain a dll reference in its value, for example: System.Data.dll
Example: <bpmn:scriptTask id="Task_1kqkg76" name="Close Request"> <bpmn:extensionElements id="extTask_1kqkg76"> <VBScript> variables("username") = "bob.loblaw" </VBScript> </bpmn:extensionElements> bpmn:incomingSequenceFlow_0xp0bq2</bpmn:incoming> bpmn:outgoingSequenceFlow_13xe9al</bpmn:outgoing> </bpmn:scriptTask>
The example above will set the variable "username" to "bob.loblaw" when the script task is called.
Javascript Code
Executing Javascript code internally using the variables parameter. This is done by dynamically loading JINT to process javasacript inside .Net. These can be used for both script tasks as well as condition checking.
Tag: Javascript
Within the script element tag, you must supply the javascript code to be run.
Example: <Javascript> variables["username"] = "bob.loblaw" </Javascript>
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.1 is compatible. |
.NET Framework | net461 is compatible. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
-
.NETCoreApp 3.1
- Microsoft.CodeAnalysis.Compilers (>= 4.0.1)
- System.CodeDom (>= 6.0.0)
-
.NETFramework 4.6.1
- Microsoft.CodeAnalysis.Compilers (>= 4.0.1)
- System.CodeDom (>= 6.0.0)
-
net6.0
- Microsoft.CodeAnalysis.Compilers (>= 4.0.1)
- System.CodeDom (>= 6.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
2.0.0 | 1,578 | 6/15/2022 | |
2.0.0-beta6 | 657 | 4/19/2022 | |
2.0.0-beta5 | 629 | 4/6/2022 | |
2.0.0-beta4 | 658 | 4/5/2022 | |
2.0.0-beta3 | 611 | 4/5/2022 | |
2.0.0-beta2 | 661 | 4/1/2022 | |
2.0.0-beta1 | 622 | 4/1/2022 | |
2.0.0-beta | 653 | 3/29/2022 | |
1.12.0 | 979 | 3/2/2022 | |
1.11.1 | 894 | 10/6/2021 | |
1.11.0 | 830 | 10/6/2021 | |
1.10.0 | 828 | 9/3/2021 | |
1.9.16 | 866 | 7/30/2021 | |
1.9.15 | 978 | 3/19/2021 | |
1.9.14 | 937 | 12/15/2020 | |
1.9.13 | 927 | 11/16/2020 | |
1.9.12 | 1,209 | 9/13/2019 | |
1.9.11 | 1,155 | 5/31/2019 | |
1.9.10 | 1,096 | 5/30/2019 | |
1.9.9 | 1,203 | 3/20/2019 | |
1.9.8 | 5,203 | 2/28/2019 | |
1.9.6 | 1,344 | 11/2/2018 | |
1.9.5 | 1,724 | 5/16/2018 | |
1.9.4 | 1,557 | 4/4/2018 | |
1.9.3 | 1,588 | 3/23/2018 |
Major revision to a new library with breaking changes, including the concept of a process instance and creating named parameters for supplying all delegates.