- 16 Oct 2024
- 7 Minutes to read
- DarkLight
- PDF
Creating a Signer Workflow
- Updated on 16 Oct 2024
- 7 Minutes to read
- DarkLight
- PDF
The content discusses how to control the flow of the Signer Experience in OneSpan Sign by setting the order in which multiple signers participate. It explains creating and editing signer workflows, changing signing orders, and updating role workflows using Java SDK, .NET SDK, REST API, and APEX SDK. The process involves creating transactions with multiple signers, specifying the order in which they sign, and viewing the results in OneSpan Sign. The content provides code samples and instructions for managing signer workflows effectively.
Java SDK.NET SDKREST APIAPEX SDK
Java SDK
To download the full code sample see our Code Share site.
When creating a transaction, you may have multiple signers required to sign several documents. Accordingly, you may wish to control the flow of the Signer Experience. With OneSpan Sign, you can set the order in which multiple signers participate, or the order in which multiple documents are signed by a signer. The signer workflow determines the order in which multiple signers can participate in the Signer Experience. For example, a signer with a signing order 1 means that they will sign first.
Creating a Signer Workflow
In this example, there are four signers, where each signer is required to sign in order. For example, the second signer will receive a notification to sign the document only after the first signer has completed signing. The following code will do this:
.withSigner(newSignerWithEmail("signer1@xyz.com")
.withFirstName("FirstNameSigner1")
.withLastName("LastNameSigner1")
.signingOrder(1))
.withSigner(newSignerWithEmail("signer2@xyz.com")
.withFirstName("FirstNameSigner2")
.withLastName("LastNameSigner2")
.signingOrder(2))
.withSigner(newSignerWithEmail("signer3@xyz.com")
.withFirstName("FirstNameSigner3")
.withLastName("LastNameSigner3")
.signingOrder(3))
.withSigner(newSignerWithEmail("signer4@xyz.com")
.withFirstName("FirstNameSigner4")
.withLastName("LastNameSigner4")
.signingOrder(4))
Editing your Signer Workflow
After you have created your transaction, you may wish to edit the signing order. In this example, the signing order of the first two signers are changed.
The following code will do this:
DocumentPackage afterReorder = eslClient.getPackage(packageId);
afterReorder.getSigner("John.Smith@email.com").setSigningOrder(2);
afterReorder.getSigner("Patty.Galant@email.com").setSigningOrder(1);
eslClient.getPackageService().orderSigners(afterReorder);
If you've already sent your transaction, you will need to change its status to DRAFT before you can update the signer workflow.
Results
After running your code, if you login to OneSpan Sign and navigate to your transaction, you will see your signer order.
.NET SDK
To download the full code sample see our Code Share site. If you're unable to use FastTrack, contact our Support Team to have it enabled for your account.
When creating a transaction, you may have multiple signers required to sign several documents. Accordingly, you may wish to control the flow of the Signer Experience. With OneSpan Sign, you can set the order in which multiple signers participate, or the order in which multiple documents are signed by a signer. The signer workflow determines the order in which multiple signers can participate in the Signer Experience. For example, a signer with a signing order 1 means that they will sign first.
In this example, there are four signers, where each signer is required to sign in order. For example, the second signer will receive a notification to sign the document only after the first signer has completed signing. The following code will do this:
Creating a Signer Workflow
In this example, there are four signers, where each signer is required to sign in order. For example, the second signer will receive a notification to sign the document only after the first signer has completed signing. The following code will do this:
.WithSigner(
SignerBuilder.NewSignerWithEmail("signer1@xyz.com")
.WithFirstName("FirstNameSigner1")
.WithLastName("LastNameSigner1")
.SigningOrder(1)
)
.WithSigner(
SignerBuilder.NewSignerWithEmail("signer2@xyz.com")
.WithFirstName("FirstNameSigner2")
.WithLastName("LastNameSigner2")
.SigningOrder(2)
)
.WithSigner(
SignerBuilder.NewSignerWithEmail("signer3@xyz.com")
.WithFirstName("FirstNameSigner3")
.WithLastName("LastNameSigner3")
.SigningOrder(3)
)
.WithSigner(
SignerBuilder.NewSignerWithEmail("signer4@xyz.com")
.WithFirstName("FirstNameSigner4")
.WithLastName("LastNameSigner4")
.SigningOrder(4)
)
Editing your Signer Workflow
After you have created your transaction, you may wish to edit the signing order. In this example, the signing order of the first two signers are changed.
afterReorder = eslClient.GetPackage(packageId);
afterReorder.GetSigner(email2).SigningOrder = 1;
afterReorder.GetSigner(email1).SigningOrder = 2;
eslClient.PackageService.OrderSigners(afterReorder);
If you've already sent your transaction, you will need to change its status to DRAFT before you can update the signer workflow.
Results
After running your code, if you login to OneSpan Sign and navigate to your transaction, you will see your signer order.
REST API
To download the full code sample see our Code Share site.
When creating a transaction, you may have multiple signers required to sign several documents. Accordingly, you may wish to control the flow of the Signer Experience. With OneSpan Sign, you can set the order in which multiple signers participate, or the order in which multiple documents are signed by a signer. The signer workflow determines the order in which multiple signers can participate in the Signer Experience. For example, a signer with a signing order 1 means that they will sign first.
Creating a Signer Workflow
In this example, there are four signers, where each signer is required to sign in order. For example, the second signer will receive a notification to sign the document only after the first signer has completed signing. The following code will do this:
HTTP Request
POST /api/packages
HTTP Headers
Accept: application/jsonContent-Type:
application/json
Authorization: Basic api_key
Request Payload
{
"roles": [
{
"id": "role1",
"index": 1,
"type": "SIGNER",
"signers": [
{
"email": "signer1@xyz.com",
"firstName": "FirstNameSigner1",
"lastName": "LastNameSigner1"
}
],
"name": "signer1"
},
{
"id": "role2",
"index": 2,
"type": "SIGNER",
"signers": [
{
"email": "signer2@xyz.com",
"firstName": "FirstNameSigner2",
"lastName": "LastNameSigner2"
}
],
"name": "signer2"
},
{
"id": "role3",
"index": 3,
"type": "SIGNER",
"signers": [
{
"email": "signer3@xyz.com",
"firstName": "FirstNameSigner3",
"lastName": "LastNameSigner3"
}
],
"name": "signer3"
},
{
"id": "role4",
"index": 4,
"type": "SIGNER",
"signers": [
{
"email": "signer4@xyz.com",
"firstName": "FirstNameSigner4",
"lastName": "LastNameSigner4"
}
],
"name": "signer4"
}
]
}
For a complete description of each field, see the Request Payload table below.
Response Payload
{
"id": "9sKhW-h-qS9m6Ho3zRv3n2a-rkI="
}
Editing the Role Workflow
To update the role workflow, you will need to make a PUT request to:
HTTP Request
PUT /api/packages/{packageId}/roles
HTTP Headers
Accept: application/json
Content-Type: application/json
Authorization: Basic api_key
Request Payload
[
{
"id": "OGCBUbLGa7gR",
"index": 0
},
{
"id": "CnvwToUWLPgW",
"index": 1
}
]
Editing your Signer Workflow
After you have created your transaction, you may wish to edit the signing order. In this example, the signing order of the first two signers are changed.
If you've already sent your transaction, you will need to change its status to DRAFT before you can update the signer workflow.
Results
After running your code, if you login to OneSpan Sign and navigate to your transaction, you will see your signer order.
Request Payload Table
Property | Type | Editable | Required | Default | Sample Values |
---|---|---|---|---|---|
roles | |||||
id | string | Yes | No | n/a | role1 |
index | integer | Yes | No | 0 | 1 / 2 / 3 ... |
type | string | Yes | No | SIGNER | SIGNER / SENDER |
signers | |||||
name | string | Yes | No | n/a | signer1 |
string | Yes | No | n/a | signer1@xyz.com | |
firstName | string | Yes | No | n/a | FirstNameSigner1 |
lastName | string | Yes | No | n/a | LastNameSigner1 |
APEX SDK
To download the full code sample see our Code Share site.
When creating a transaction, you may have multiple signers required to sign several documents. Accordingly, you may wish to control the flow of the Signer Experience. With OneSpan Sign, you can set the order in which multiple signers participate, or the order in which multiple documents are signed by a signer. The signer workflow determines the order in which multiple signers can participate in the Signer Experience. For example, a signer with a signing order 1 means that they will sign first.
Creating a Signer Workflow
In this example, there are four signers, where each signer is required to sign in order. For example, the second signer will receive a notification to sign the document only after the first signer has completed signing. The following code will do this:
// Method1: add signing order when creating role
ESignLiveAPIObjects.Role role1 = new ESignLiveAPIObjects.Role();
role1.id = 'signer1';
role1.index = 1;
role1.signers = sdk.createRolesSigner('FirstNameSigner1', 'LastNameSigner1', 'signer1@xyz.com', 'Applicant', 'xxx Company');
sdk.helper.createRole(packageId, role1);
ESignLiveAPIObjects.Role role2 = new ESignLiveAPIObjects.Role();
role2.id = 'signer2';
role2.index = 2;
role2.signers = sdk.createRolesSigner('FirstNameSigner2', 'LastNameSigner2', 'signer2@xyz.com', 'Director', 'ABC Bank');
sdk.helper.createRole(packageId, role2);
ESignLiveAPIObjects.Role role3 = new ESignLiveAPIObjects.Role();
role3.id = 'signer3';
role3.index = 3;
role3.signers = sdk.createRolesSigner('FirstNameSigner3', 'LastNameSigner3', 'signer3@xyz.com', 'Applicant', 'xxx Company');
sdk.helper.createRole(packageId, role3);
ESignLiveAPIObjects.Role role4 = new ESignLiveAPIObjects.Role();
role4.id = 'signer4';
role4.index = 4;
role4.signers = sdk.createRolesSigner('FirstNameSigner4', 'LastNameSigner4', 'signer4@xyz.com', 'Director', 'ABC Bank');
sdk.helper.createRole(packageId, role4);
Editing your Signer Workflow
After you have created your transaction, you may wish to edit the signing order. In this example, the signing order of the first two signers are changed.
sdk.setSigningOrder('packageId', 'signer1', 2);
sdk.setSigningOrder('packageId', 'signer2', 1);
If you've already sent your transaction, you will need to change its status to DRAFT before you can update the signer workflow.
Results
After running your code, if you login to OneSpan Sign and navigate to your transaction, you will see your signer order.