Signature
Ask contacts to sign documents from your flow
The signature element enables you to propose documents to be signed using an external e-signature provider (default is Connective)
In order to kick-start the addition of a signature element, I invite you to have a look at our signature element:
{
"type": "signature",
"key": "signatures.documents_to_sign",
"title": "Documents to sign",
"name": "Signed-documents",
"items": [
{
"uri": "https://mydomain.com/Document_to_sign_01.pdf",
"name": "User friendly name",
"fill": {
"first_name": "{user.given_name}",
"last_name": "{user.last_name}",
"location": "{data.address_city}",
"today": { ":format-date": "now", ":pattern": "Y-M-D" },
"some_checkbox": false
},
"signatures": [
{ "field": "SIG001" },
{ "page": 1, "top": 300, "left": 50 }
]
},
{
"uri": "https://mydomain.com/Document_to_sign_02.pdf",
"name": "Second document"
}
],
"merge": true,
"method": "email",
"required": true
}
Options
In this chapter we will focus on the different options related to our Signature element.
Specifying the name of the signature package (name
)
name
)This will be displayed to the user during the signature process and will be used as the name of the signed file (".pdf"). If no value is provided, the title
option will be used as default. If neither name
nor title
are specified, "Documents"
will be used as fallback.
{"name": "Signed-documents"}
Specifying the files to sign (items
)
items
)This will be a list of documents to be signed. It can be generated in one of two ways: from a URI or using files uploaded in a Penbox form.
Signing a file from a URI (item.uri
)
item.uri
)Using a PDF or IMAGE (png / jpeg) file located on a publicly available HTTP endpoint.
{
"type": "signature",
// ...
"items": [
{
"uri": "https://testingpenbox.s3.amazonaws.com/file_resources/files/Document_to_sign.pdf"
}
// ... more items
]
}
Signing a Penbox file (item.attachment
)
item.attachment
)Specify a (list of) file(s) to sign from a "file upload" element from a Penbox form.
Note: Only PDF and IMAGES are supported here so make sure that the file element has an
"accept"
option as described in the section bellow. Invalid files will be ignored.
{
"type": "signature",
// ...
"items": [
// If the file was uploaded when creating the request, use "option."
{
"attachments": "{ options.files_to_sign }",
},
// If the file was uploaded while filling the form, use "data."
{
"attachments": "{ data.files_to_sign }",
},
// ... more items
]
}
Specifying signature locations (item.signatures
)
item.signatures
)When the item to sign is defined using a "uri"
, the locations of the signatures within that document can also be specified.
{
"type": "signature",
// ...
"items": [
{
"uri": "https://testingpenbox.s3.amazonaws.com/file_resources/files/Document_to_sign.pdf",
// Optionnal: allows defining the locations of the signatures in the document.
"signatures": [
// A signature location can be described using its exact coordinates
{ "page": 1, "top": 300, "left": 50 },
// A signature location can be described using a PDF FORM field of type "signature"
{ "field": "PDF_FORM_SIGNATURE_FIELD_A" },
// A signature location can be described using a (list of) text strings to find on the page.
// The signature will be place right bellow the first field matching any of the provided "hint".
{ "hint": ["Sign here", "Please apply you signature bellow" ] },
]
}
]
}
Tip: Any "hash" specified in an HTTP(S)
uri
will be interpreted as an PDF FORM field of type "signature" to sign. The following:{ "uri": "https://example.com/my.pdf#PDF_FORM_SIGNATURE_FIELD_A" }
Will result in:
{ "uri": "https://example.com/my.pdf", "signatures": [ { "field": "PDF_FORM_SIGNATURE_FIELD_A" } ] }
It is not possible to specify the signature locations in the case of attachment
items (because it is not possible to know in advance what files will be uploaded by users). It is however possible to enable signature detection in the uploaded attachments using the find-signatures
meta described bellow.
If no item contains a signature location, a default "signature page" will be added to the file to be signed. The signature page to use will depend on the language of the generated document and is not configurable.
Specifying an item name (item.name
)
item.name
)When the item is described using a uri
, a custom name
can also be provided. This will be displayed to the user so that he knows what he is about to sign.
{
"uri": "https://example.com/013c534b-3b44-4e09-9c3b-043fdbdb31a6.pdf",
"name": "User friendly name"
}
Filling a PDF file dynamically (item.fill
)
item.fill
)Each item can also be sent with information to fill. This will only work if the item is a PDF file that contains a PDF Form. Each of the FORM field in the PDF will be replaced with the respective value specified in the fill
option.
{
"attachments or uri": "...",
// ...
"fill": {
// Depending on the type of the PDF FORM field, the behaviour will differ:
// Text fields will be filled with the string representation of the value
"TEXT_FIELD": "Any text value",
"TEXT_FIELD": "", // Text box will be cleared/emptied
"TEXT_FIELD": null, // This will result in "<void>" (localized) being printed
"TEXT_FIELD": { ":format-date": "now", ":pattern": "Y-M-D" }, // "2023-04-17"
// Checkboxes will be checked/unchekced according to the "truhiness" of the value
"CHECKBOX_FIELD": false, // true for "checked", false for "unchecked"
// Fields where one of multiple value should be selected can be used too. Note that only available values are allowed.
"OPTION_FIELD": "option_1",
"RADIO_FIELD": "option_1",
"DROPDOWN_FIELD": "option_1",
// Button fields will be "filled" with the image specified at the given URI
"BUTTON_FIELD": "https://example.com/image.png",
"BUTTON_FIELD": "",
}
}
Merging all items into a single file ("merge"
)
"merge"
)By default, all items will be merged into 1 PDF before sending for signature to the provider.
{
"type": "signature",
// ...
"merge": false // defaults to true
}
Specifying a signature method ("method"
)
"method"
)Current supported methods is one of the email
, sms
, handwritten
, id-card
{
"type": "signature",
// ...
"method": "sms" // "sms" is the default
}
Note: All methods require that the
user.email
key was properly filled. The"sms"
signing method also requires that theuser.phone
key was provided.
Specifying the language of the file (locale
)
locale
)Some operations require to know which is the language of the document being signed:
- Filling fields with
null
(<void>
in english,<Néant>
in french, etc.) or numbers (1,000.23
in english,1 000,23
in french, etc.) - Automatic detection of the signatures in the document
- If no signature locations are detected, adding a signature page in any of the items (or individual items when
merge
is false)
This will default the the value of user.locale
. If you need to force the language to some other value (e.g. if all the documents to sign are in english), use the locale
option:
{
"type": "signature",
// ...
"locale": "en"
}
Adding Files from the options
We can easily add in the options an element that will collect the PDF to be send for signature using a file element
{
"key": "options.files_to_sign",
"type": "file",
"title": "Fiels to sign",
"accept": "application/pdf,.pdf,image/png,.png,image/jpeg,.jpg,.jpeg",
"multiple": true
},
The find-signature
meta
find-signature
metaIn order to enable the ability to specify the signature location manually when uploading a file (upon request creation only), the file
element must contain the following meta
option:
{
"type": "file",
// ...
"meta": {
"find-signatures": true
}
}
This meta
option can also contain options allowing to automatically find the signatures upon upload. To do so, you should specify a hint
that is a an array of string after which a signature location will be automatically added. The hint will generate a "match" if, and only if, the full text box in the PDF matches the entire string of the hint. If you need a more powerful mechanism, regular expressions can also be used.
{
"type": "file",
// ...
"meta": {
"find-signatures": {
"hint": [
"Signature,",
"Sign here:",
"I agree to these terms",
"/^regular expression(s)? (is|are) supported here$/i"
]
}
}
}
And if you want to force that at least one signature location was automatically found, you can use the required
option:
{
"type": "file",
// ...
"meta": {
"find-signatures": {
"required": true
}
}
}
All the locations automatically found using this option can be adjusted in the user interface after the file was uploaded.
Updated over 1 year ago