Creating a Session Order
Below is an example request to create a customer order:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"internal_id": "((internal_order_id))", "participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "John"}]}'
A successful request will generate the following response:
{
"success":1,
"link_to_order":"https://notarylive.com/notarize/request-form?guest=true&oid={unique_order_identifier}"
}
If this email is already associated with a non-guest customer in our system, the returned url will reflect this:
{
"success":1,
"link_to_order":"https://notarylive.com/notarize/request-form?guest=false&oid={unique_order_identifier}"
}
If that user is not a guest, they will be required to login to their account to proceed with this order. All webhooks, confirmation page links and status emails will still trigger for non-guest users.
Validation Failures
Invalid credentials will return a 401 response with the message: HTTP/1.0 401 Unauthorized
Invalid or missing payload data will return a 400 HTTP response with a JSON body containing success =
0
as well as an array of errors
containing both a standardized error code, as well as a
human-readable description of what caused the error:
If you continue having issues, please take a look at our troubleshooting guide.
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"internal_id":"internal_order_id","participants":[{"email":"john.doe@notarylive.com","last_name":"Doe","first_name":"Johnny"}]}'
{
"success": 0,
"errors": [
{
"code": "validation_failed",
"message": "At least 1 participant of type 'signer' is required."
},
{
"code": "validation_failed",
"message": "The participants.0.type field is required."
}
]
}
Attaching Documents
via Document URL
To upload a document to notarize, pass in a comma-separated list of document urls as shown below:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-u 'api_test_user:api_test_key' \
-H 'Content-Type: application/json' \
-d $'{"internal_id": "((internal_order_id))", "participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "Johnny"}], "document_urls": ["https://pdfobject.com/pdf/sample.pdf", "https://www.w3.org/WAI/ER/tests/xhtml/testfiles/resources/pdf/dummy.pdf"]}'
Each file will be attached as a separate document and all identity verification and notarization steps will occur with these documents within the same live session with the notary public.
via Direct File Upload
In the direct file upload approach, the file must exist on the same server infrastructure as where the API request is originating from. You will then reference the full file path to the document within the API call:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-u 'api_test_user:api_test_key' \
-H 'Content-Type: multipart/form-data' \
-F "document_files[0]=@/path/to/document_1.pdf" \
-F "document_files[1]=@/path/to/document_2.pdf" \
-F "participants[0][first_name]=Johnny" \
-F "participants[0][last_name]=Doe" \
-F "participants[0][email]=john.doe@notarylive.com" \
-F "participants[0][type]=signer" \
-F "internal_id=internal_order_id"
Please note: The API will fail with an error message if the file does not exist or the full file path is not specified correctly.
Please note: API calls including large documents or multiple documents will take longer to process than API calls with smaller filesize documents.
Adding Participants
You can add signers and witnesses to the request in the Session Order API by using the participants
parameter. The participants
parameter accepts an array of objects representing participants, the first
signer will always be treated as the primary signer. Each participant object must contain the following
parameters:
first_name
- The first name of the participantlast_name
- The last name of the participantemail
- The email address of the participanttype
- The type of the participant
For more information on the validation rules for participant names and emails, please click here.
You can add multiple signers types to the request in this manner:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"internal_id":"((internal_order_id))","participants":[{"email":"john.doe@notarylive.com","last_name":"Doe","type":"signer","first_name":"Johnny"},{"email":"jane.doe@notarylive.com","last_name":"Doe","type":"signer","first_name":"Jane"}]}'
You can use this same technique to add witnesses to the request.
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"internal_id":"((internal_order_id))","participants":[{"email":"john.doe@notarylive.com","last_name":"Doe","type":"signer","first_name":"Johnny"},{"email":"jane.doe@notarylive.com","last_name":"Doe","type":"witness","first_name":"Jane"}]}'
Please note: Each additional signer or witness you add to the request increases the price of the order by $5 dollars. All signers and witnesses must have a unique email address, and the API request will fail with a validation error if participants share email addresses.
Choosing Who Pays
By default, the person notarizing the document will need to pay for the notarial session. If you would like to
pay for the session instead of the end user, you may do so by setting the charge_to
API parameter
to my_account
, as shown below:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"charge_to":"my_account","internal_id":"((internal_order_id))","participants":[{"email":"john.doe@notarylive.com","last_name":"Doe","type":"signer","first_name":"Johnny"}]}'
Please note: Charging orders to your account is only available to Business Premier level
accounts with a working payment profile saved to the system. Using the charge_to=my_account
parameter on an unqualified account will cause the Create Session Order API call to fail. Only orders which
complete the notarial event successfully will be charged to your account. Billing for these orders occurs at the
end of the month and will be reflected in your monthly invoice.
Please note: Using the test credentials (-u 'api_test_user:api_test_key'
) in combination
with charge_to=my_account
will result in an error as this account can't be used as a funding
source.
Please contact us at support@notarylive.com if you would like to set
up a Business Premier account and use the charge_to
API parameter.
Using Templates
Order templates allow you to reuse the same type of document for multiple orders, but with dynamic fields that are unique to the information about that specific customer. You can create templates from the dashboard and use the template ID while creating an order.
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"template_id": "((template_id))","internal_id":"((internal_order_id))","participants":[{"email":"john.doe@notarylive.com","last_name":"Doe","type":"signer","first_name":"Johnny"}]}'
Please note: If you provide template_id
you can still provide
document_urls
or document_files
to include additional non-templated documents.
This will append the templated documents to the end of the list.
Document Dynamic Fields
When using an api template, you can also provide values for templated fields. These fields are placeholders
in the document that are replaced with the values you provide. You can provide these values using the
templated_documents_fields
parameter.
Let's say you have an api template with the first_name
, last_name
, and country
fields on the document. first_name
and last_name
being on the first page
and country
being on the second page. You can provide the values for these fields as shown below:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{ \
"templated_documents_fields":[ \
{ \
"file_id":"((file_id))", \
"fields":[ \
[ \
["first_name","Johnny"], \
["last_name","Doe"] \
], \
[ \
["country","USA"] \
] \
] \
} \
], \
"template_id":"((template_id))", \
"internal_id":"((internal_order_id))", \
"participants":[ \
{ \
"email":"john.doe@notarylive.com", \
"last_name":"Doe", \
"type":"signer", \
"first_name":"Johnny" \
} \
] \
}'
Once the order is created, the first_name
, last_name
and country
fields
will be replaced in this example. The fields you create in your template will be replaced with the values you
provide in the API call as long as they're found in the document.
The field names should be unique within the document. If you provide the same field name multiple times, the first value provided will be used. If you provide a value for a field that doesn't exist in the document, it will be ignored.
Please note: The file_id
is the ID of the document in the template. You can get the
file_id
from the template details page in the dashboard.
Please note: Currently, applying templates and using templated fields are limited to templates
with the type api
. You can create an api
template from the dashboard.
Editing Participants During the Session
Two API parameters control what your clients are able to edit during the session, client_can_change_names
and client_can_add_or_remove_participants
. Additional info regarding these parameters can be found in the validation rules.
If you have additional requirements for forms of identification, please reach out to us at support@notarylive.com for help crafting custom solutions.
Choosing how you receive files back
By default, NotaryLive will send the notarized documents back to you as a url link to a remote file within the body of a webhook event. If you would rather receive the file itself in the webhook event, you will need to set the receive_files_as_attachments parameter in your initial API call to 1. Below is an example of what that would look like:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"receive_files_as_attachments": 1, "internal_id": "((internal_order_id))", "participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "John"}]}'
Please note: NotaryLive webhook events by default are sent as Content-Type: application/json. However, when receive_files_as_attachments is 1, NotaryLive webhooks will always be sent with Content-Type: multipart/form-data. The shape of the response will also change slightly between the two versions. Below are example webhook responses with receive_files_as_attachments enabled and disabled:
receive_files_as_attachments disabled:
{
"event": "documents_notarized",
"nl_order_id": "1s1129",
"their_order_id": "((internal_order_id))",
"customer_email": "john.doe@notarylive.com",
"links_to_documents": [
"https://notary-session-files.../document1.pdf",
"https://notary-session-files.../document2.pdf"
],
"order_price": 25,
"number_of_participants_together": 1,
"participants": [
{
"email":"john.doe@notarylive.com",
"first_name":"John",
"last_name":"Doe",
"type":"signer"
}
],
"total_doc_page_count": 10
}
receive_files_as_attachments enabled:
{
"response": {"event":"documents_notarized","nl_order_id":"1s1130","their_order_id":"((internal_order_id))","customer_email":"john.doe@notarylive.com","order_price":25,"number_of_participants_together":1,"participants":[{"email":"john.doe@notarylive.com","first_name":"John","last_name":"Doe","type":"signer"}],"total_doc_page_count":2}"
}
When receive_files_as_attachments is enabled, the files will be attached to the webhook POST in the following file format:
document-1
document-2
document-3
etc
Please note: The original filenames of your documents are preserved after notarization. The document-1, etc format is only used for fetching the resultant files from the webhook.
In addition to the notarized documents, enabling receive_files_as_attachments will also attach the audit trail for that order in .csv format.
The audit trail will be attached to the webhook POST in the following file format:
audit-trail
The actual filename will be audit-trail-{nl_order_number}.csv. The file will consist of order details including time of notarization, signer name and email, etc.
Receiving IDs Back
You can also receive IDs back as files in the webhook event using receive_files_as_attachments.
In order to use this feature, you must:
- be approved for this feature by NotaryLive (contact us at support@notarylive.com)
- be in production mode
- enable receive_files_as_attachments
Once the above requirements are met, the IDs for each participant will be attached to the webhook POST in the following file format:
participant-1-id-front
participant-1-id-back
participant-2-id-front
participant-2-id-back
etc
If the participant supplied a passport, the participant-{number}-id-back file will not exist and will not be sent in the webhook.
Please consult the documentation for your server-side language of choice on how to download and store the file from the HTTP POST when receive_files_as_attachments is enabled.
Keeping Track of Different Documents in the Notarization Lifecycle
When multiple documents must be notarized at the same time, it is crucial to have a system in place to identify which document is which in an automated way. To accomplish this, we recommend using the document_ids API parameter, like so:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-u 'api_test_user:api_test_key' \
-H 'Content-Type: application/json' \
-d $'{"internal_id": "((internal_order_id))", "participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "Johnny"}], "document_urls": ["https://pdfobject.com/pdf/sample.pdf", "https://www.w3.org/WAI/ER/tests/xhtml/testfiles/resources/pdf/dummy.pdf"],"document_ids": ["deed-of-trust", "grant-deed"]}'
The document_ids parameter works by matching the exact order of either the document_urls or the document_files you've supplied. In the example above, this means that https://pdfobject.com/pdf/sample.pdf is marked in our system as document_id deed-of-trust, and we will keep track of that identifier throughout the lifecycle of the document. Once the session has been notarized, we will send the documents_notarized webhook event like so:
{
"event": "documents_notarized",
"nl_order_id": "1s1129",
"their_order_id": "((internal_order_id))",
"customer_email": "john.doe@notarylive.com",
"links_to_documents": [
"https://notary-session-files.../document1.pdf",
"https://notary-session-files.../document2.pdf"
],
"document_ids":[
"deed-of-trust",
"grant-deed"
],
"order_price": 25,
"number_of_participants_together": 1,
"participants": [
{
"email":"john.doe@notarylive.com",
"first_name":"John",
"last_name":"Doe",
"type":"signer"
}
],
"total_doc_page_count": 10
}
It will then be the responsibility of your system that receives the webhook to tie together that the first entry in document_ids is "deed-of-trust", which is the first entry in the links_to_documents array.
Adding Dynamic Fields To Any Document
You can add dynamic fields (what we refer to as tags) to your documents for your customer to fill in using the document_tags
parameter.
For instance, if you would like your customer to sign in a specific spot on your document; you can submit the x,y location for a signature
tag in your api call.
Then, when your customer is in a session with the notary, they can click on that tag and it will automatically add their signature.
Let's say you have the url for a document that is two pages long, and you'd like to add a text
tag pre-filled with your customer's name,
a textbox
tag asking for the customer address, a signature
tag, and a set of radio_button
(s) to the first page,
as well as a note
tag to the second page.
You can add these tags to your document as shown below:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-H 'Content-Type: application/json' \
-u 'api_test_user:api_test_key' \
-d $'{"internal_id": "((internal_order_id))",
"participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "Johnny"}],
"document_urls": ["https://notarylive.com/affidavit-of-identity"],
"document_ids": ["affidavit-of-identity-01"],
"document_tags": [
[
[
{
"type": "text",
"x": 225,
"y": 185,
"text_content": "Johnny Doe"
},
{
"type": "textbox",
"x": 120,
"y": 260,
"width": 400,
"height": 30,
"participant_email": "john.doe@notarylive.com",
"placeholder": "Enter your full address (Street, City, State, Zip Code)"
},
{
"type": "radio_button",
"x": 119,
"y": 354,
"participant_email": "john.doe@notarylive.com",
"radio_buttons": [
{
"x": 0,
"y": 0
},
{
"x": 0,
"y": 29
},
{
"x": 0,
"y": 58
},
{
"x": 0,
"y": 87
}
]
},
{
"type": "signature",
"x": 160,
"y": 630,
"participant_email": "john.doe@notarylive.com"
}
],
[
{
"type": "note",
"x": 10,
"y": 10,
"notes": ["DO NOT EDIT THIS PAGE", "For notary use only"]
}
]
]
]}'
Please note:
document_tags
is a 3-level nested array structured as [documents][pages][tags].
The outer array corresponds to the documents (in the same order as document_ids and document_files/document_urls).
The middle array corresponds to the pages within that document.
The inner array contains the list of tag objects for that specific page.
Please note: document_ids
AND either document_urls
or document_files
are required to use the document_tags
parameter.
If you are uploading document_files
instead, you can use document_tags
as shown below:
curl -X POST -k "https://notarylive.com/api/v3/order/create" \
-u 'api_test_user:api_test_key' \
-H 'Content-Type: multipart/form-data' \
-F "document_files[0]=@/path/to/document_1.pdf" \
-F "document_files[1]=@/path/to/document_2.pdf" \
-F "document_ids[0]=A01" \
-F "document_ids[1]=A02" \
-F "participants[0][first_name]=Johnny" \
-F "participants[0][last_name]=Doe" \
-F "participants[0][email]=john.doe@notarylive.com" \
-F "participants[0][type]=signer" \
-F "internal_id=internal_order_id" \
-F 'document_tags=[
[
[
{
"type": "signature",
"x": 119.02,
"y": 600.52,
"participant_email": "john.doe@notarylive.com"
},
{
"type": "note",
"x": 10,
"y": 10,
"notes": ["Remind the notary about this"]
},
{
"type": "textbox",
"x": 30,
"y": 100,
"width": 400,
"participant_email": "john.doe@notarylive.com",
"placeholder": "Full name here"
}
],
[
{
"type": "initials",
"x": 50,
"y": 50,
"participant_email": "john.doe@notarylive.com"
}
]
],
[
[],
[
{
"type": "signature",
"x": 119.02,
"y": 127.52,
"width": 300,
"height": 40,
"participant_email": "john.doe@notarylive.com"
},
{
"type": "checkbox",
"x": 10,
"y": 10,
"participant_email": "john.doe@notarylive.com",
"checkboxes": [
{
"x": 0,
"y": 0
},
{
"x": 0,
"y": 20
}
]
}
]
]
]'
The following are the possible tag types that you can customize and add to your document:
signature |
Required: x position, y position, and participant_email Optional: width, height Customer can add their signature to this tag. |
initials |
Required: x position, y position, and participant_email Optional: width, height Customer can add their initials to this tag. |
textbox |
Required: x position, y position, and participant_email Optional: width, height You can add placeholder text to request customer to add specific text to this tag. For instance, if you set a textbox tag with "placeholder": "address here", the customer will see the textbox with the text "address here", to which they'll replace with their own address. |
note |
Required: x position, y position You can add notes to this tag if you'd like to provide any additional info to the customer/notary. Notes will only be visible in the session as helpful information, and will not appear on the final document. |
checkbox |
Required: x position, y position, participant_email, and checkboxes array A checkbox/set of checkboxes are created that the customer can check off during the session. checkboxes is an array of objects, each with required x and y positions. Look at above sample call for details. The x and y coordinates of each object in checkboxes are relative to the parent checkbox tag's positioning. |
radio_button |
Required: x position, y position, participant_email, and radio_buttons array A set of radio buttons are created that the customer can select during the session. radio_buttons is an array of objects, each with required x and y positions. Look at above sample call for details. The x and y coordinates of each object in radio_buttons are relative to the parent radio_button tag's positioning. |
text |
Required: x position, y position, and text_content Optional: width, height You can add an editable text tag to the document; the text_content will show up on the final notarized document. |
Attaching Instructions For The Notary
Sessions notes are not required, but if you feel the notary should be aware of special information unique to a particular signing or in compliance with your business needs, you can pass guidance along to the notary in the instructions parameter. The instructions support simple markup formatting for better readability:
##text##
- Makes text bold- item
- Creates a bullet point\n
- Adds a line break
Below is an example of how to supply formatted instructions:
curl -X POST "https://notarylive.com/api/v3/order/create" \
-u 'api_test_user:api_test_key' \
-H 'Content-Type: application/json' \
-d '{"internal_id": "((internal_order_id))", "instructions":"##Important Steps##\n- Verify the Signer'\''s Identity\n- Ask for valid identification (e.g., government-issued photo ID)\n- Administer an Oath or Affirmation\n\n##Customer Support##\n- Customers can reach out to support@example.com for assistance", "participants": [{"email": "john.doe@notarylive.com", "last_name": "Doe", "type": "signer", "first_name": "Johnny"}], "document_urls": ["https://pdfobject.com/pdf/sample.pdf"]}'
The notary will see a flashing red message while with the customer, notifying them that there are special instructions for this session:

And your note to the notary will then be rendered onscreen like so:

Webhook Events
The following webhook events are sent during the order lifecycle:
Event Name | JSON Payload |
order_created |
|
customer_paid |
|
passed_identity_verification |
|
order_canceled |
|
kba_locked_out |
Please note: The "customer_email" in this event shows the email of the signer that failed the Knowledge-Based-Assessment (KBA). If the signer uses a verifier and the verifier fails the KBA, "verifier_email" will refer to the verifier, and "customer_email" will refer to the signer.
|
ready_to_reattempt_kba |
Please note: This event will only be sent if disable_kba_retake_email is set to 1
|
documents_notarized |
|
video_ready_for_download |
|
Please note: the links_to_documents
will only be accessible for 30 minutes
when you move to the production API. Please have a plan in place to download and store this document on your own
infrastructure if you plan on needing access to this document for more than 30 minutes. If you would rather receive the files back directly, instead of as remote urls, please click here.
You can trigger the expiration of an order immediately after it's creation. This is helpful in order to test your system's response to the order_canceled webhook event. In order to immediately expire a created order, please set the primary signer's first name to NLexpireOrder. Please note! the NLexpireOrder technique will only work with production API credentials.
Webhook Security
All webhook messages sent by NotaryLive are sent over HTTPS to ensure messages are encrypted in transit.
While HMAC verification is a common security measure, integrating partners have had difficulty replicating the HMAC signature, especially when webhooks include attached media or when the Content-Type
isn't application/json
. For this reason, NotaryLive does not support HMAC signing for webhooks.
Instead, we recommend treating webhooks as simple notifications that the session order status has changed. The server receiving the webhook can then followup with an API call to our other endpoints such as the Order Status API, the Video Retrieval API or the ID Retrieval API to fetch the files and information necessary to update the record in your system.
Absentee Participants
If a signer or witness is unable to attend the notarization at the same time as the rest of the participants, the primary signer can mark this participant as absentee. The absentee participant will receive a followup session to notarize after the original session has been completed.

In order for your system to tie these two sessions together, the documents_notarized webhook event for the first session will contain additional information regarding the followup session. The two additional parts of the webhook response are the followup_order_id and the followup_order_member_details:
{
"event": "documents_notarized",
"nl_order_id": "order_1",
"their_order_id": "your_company_order_id",
"customer_email": "john.doe@notarylive.com",
"links_to_documents": ["https://notary-session-files.../document.pdf"],
"order_price": 25,
"number_of_participants_together": 1, // signers + witnesses, excluding verifiers
"participants": [
{
"email":"john.doe@notarylive.com",
"first_name":"John",
"last_name":"Doe",
"type":"signer"
}
],
"total_doc_page_count": 5,
"followup_order_id": "order_2",
"link_to_followup_order": "https://notarylive.com/tu/cai...",
"followup_order_member_details": "[{\"email\":\"jane.doe@notarylive.com\",\"first_name\":\"Jane\",\"last_name\":\"Doe\",\"type\":\"signer\"}]"
}
The primary signer of this followup session will be the first signer in the followup_order_member_details array above.
Canceled Orders
The following are the possible values for the cancel_reason_code
canceled_by_organization | The order was canceled by the organization |
customer_failed_identity_verification | The customer failed identity verification and could not provide a verifier |
canceled_by_notary | The order was canceled by the notary |
customer_declined_to_sign | The customer declined to sign the order |
order_expired | The order expired |
cs_refunded | The order was canceled by a NotaryLive customer service representative |
Expired Orders
For security purposes, incomplete orders are purged from the NotaryLive platform after multiple days of inactivity. When a customer tries to resume an order that is expired, they are instead shown a notice that they will need to start a new order.
In order to provide a more seamless experience to the customer, you may include an expired_order_redirect
parameter during the order creation API call. If this parameter is included during order creation, we will
automatically redirect the customer to the url provided when the customer tries to resume a canceled order. Once
the customer has been directed to your url, you can then tailor the expiration message, authentication rules and
conditions under which the customer can start a new notarization order to what will fit your business needs.
Validation Rules
The following are the validation rules for all arguments within the order creation API call:
Parameter | Validation Rules |
---|---|
document_files |
Optional | Array of files |
document_ids |
Optional | Array of ids | Must not contain duplicates, must match the number of documents being sent, and should be in the same order as the corresponding documents. For more information, please click here |
document_urls |
Optional | Array of urls |
Annotation Conversion
Only available for approved accounts - please contact us |
Optional | String |
charge_to |
Optional | String | Defaults to customer | Options: my_account , customer | Who is
paying for the order. For more details, click here |
client_can_add_or_remove_participants |
Optional | Boolean | Defaults to 0 | Options: 0 , 1 | assigning a 1 to this parameter allows the customer to add additional signers or witnesses to the session themselves. Regardless of the value of this parameter, customers are not able to remove signers or witnesses you added during the initial API call. |
client_can_change_names |
Optional | Boolean | Defaults to 1 | Options: 0 , 1 | assigning a 0 to this parameter prevents the customer from changing the names or email addresses of participants you added during the initial API call. |
company_email |
Optional | Email | Max length: 100 characters | The email address NotaryLive will send status updates to, as an order moves through the system. If a webhook url is supplied and the webhook receives a 200-response from the server, the email will not be sent to this email address |
confirmation_btn_text |
Required if confirmation_btn_url is set | String | Max length: 50 characters | The name
of the organization or workflow that your customers are returning to, when they exit our site from the
notarization confirmation page
|
confirmation_btn_url |
Optional | Url | The url the confirmation page button will link out to |
disable_followup_session_email |
Please contact us at support@notarylive.com for more context on this feature |
disable_kba_retake_email |
Optional | Boolean | Defaults to 0 | Options: 0 , 1 | If a customer fails Knowledge-Based-Assessment (KBA) too often in a 24 hour period, they are locked out of completing the notarization for 24 hours. NotaryLive will normally email the customer when this 24 hour period has expired. If this parameter is set to 1, we will instead send a webhook event to your server to let you know the customer can reattempt KBA. The customer will not receive a notification from us, and it will be your responsibility to notify the customer that they can reattempt KBA. |
expired_order_redirect |
Optional | Url | The url NotaryLive will redirect users to when the order has expired due to inactivity. For more details, click here |
instructions |
Optional | String | Max length: 1000 characters | Instructions and/or details that might be helpful during or after the Notarization session. Supports simple markup formatting: Use ##text## for bold text and - item for bullet points. Use \n for line breaks.
|
internal_id |
Optional | String | Max length: 191 characters | A value you supply that helps identify this record in your internal systems. For more details, click here |
has_additional_client_steps |
Optional |
Requires confirmation_btn_text and confirmation_btn_url to be set | String | Options: yes , yes_hide_docs , no |
If set, confirmation button will be set as CTA button at top of confirmation page.If set to yes_hide_docs , confirmation page will not show notarized documents, only the confirmation button
|
Limit the signer's ability to edit documents.
Only available for approved accounts - please contact us |
Optional | Boolean | Limits the participant to only add and place their signature, initials, and date on the document. |
notary |
Optional |
String | Options: any_nl_notary , any_of_mine , *the NotaryLive user ID of your notary* |
Choose a specific notary or notary pool to connect your customer with. any_nl_notary connects with any NotaryLive notary, and any_of_mine connects with any of your own notaries that belong to your NotaryLive organization.
Setting notary to a specific notary's user ID will connect the customer with that notary directly.
You can view your organization's notaries as well as their user IDs in your dashboard, under the Users tab.Please note: If you have notaries in your NotaryLive organization, your order by default will connect only with your own notaries. If you do not have any notaries in your NotaryLive organization, your order by default will connect with any NotaryLive notary. Use the notary parameter to override this default behavior.
|
receive_files_as_attachments |
Optional | Boolean | Choose how you receive notarized documents back from NotaryLive. If you want to receive IDs back as well, enable this parameter and please contact us at support@notarylive.com to get approved. For more information, please click here. |
Ask for Proof of Address
Only available for approved accounts - please contact us |
Optional | Boolean | Shows an additional page in the order form asking for Proof of Address as a document upload |
send_initial_session_link_email |
Optional | Boolean | NotaryLive will send the customer an email with the link to the session |
sender_message |
Optional | String | Max length: 3000 characters | Requires send_initial_session_link_email to be true | Message will be included in the email the customer will received with the link to the session |
skip_upload_doc_page |
Optional | Boolean | Requires at least one document | Skips showing the document upload page to the customer |
Bypass Edit Document Page
Only available for approved accounts - please contact us |
Optional | Boolean | Requires at least one document | Skips showing the edit document page to the customer |
template_id |
Optional | String | The ID of the template to use for the order. For more details, click here |
[company]_session_type
Only available for approved accounts - please contact us |
Optional | String | Applies corresponding discount amounts based on session type |
webhook_url |
Optional | Url | The url NotaryLive will POST status updates to, as an order moves through the system |
participants |
Required | Array of objects | Must include at least one participant of the type signer |
participants.*.email |
Required | Email | Max length: 100 characters | The email address of the participant |
participants.*.first_name |
Required | String | Max length: 35 characters | Letters, commas, periods, hypens, apostrophes and spaces only | The first name of the participant |
participants.*.last_name |
Required | String | Max length: 50 characters | Letters, commas, periods, hypens, apostrophes and spaces only | The last name of the participant |
Provide Proof of Address Instructions
Only available for approved accounts - please contact us | |
Provide the type of ID the participant is presenting to verify their identity
Only available for approved accounts - please contact us |
|
participants.*.preupload_id |
Optional | ULID | The preupload ID of the participant. For more details, click here. |
participants.*.type |
Required | String | Options: signer , witness | The type of the participant |
templated_documents_fields |
Optional | Array of objects | For more details, click here |
templated_documents_fields.*.fields |
Required if template_id is set | Array of arrays | The values for the templated fields |
templated_documents_fields.*.file_id |
Required if template_id is set | ULID | The ID of the document in the template |
Specify Company for Sandbox Order
Only available for approved accounts - please contact us |
Optional | String | Allows customization for all sandbox orders with this parameter |
If the skip_upload_doc_page
parameter is set to 1
a document must also be provided using
any of the following parameters: document_urls
or document_files
Internal ID
The internal_id
parameter is used to identify the order in your internal systems.
If you're using the same internal_id
for multiple sessions, make sure your system can properly track and differentiate each one to avoid any mix-ups when webhooks are received or when you're retrieving information for a specific session.
Example of webhook events for two different NotaryLive sessions with the same internal_id
:
{
"event": "order_created",
"nl_order_id": "notarylive_order_id",
"their_order_id": "1234",
"customer_email": "customer@domain.tld"
}
{
"event": "order_created",
"nl_order_id": "new_notarylive_order_id",
"their_order_id": "1234",
"customer_email": "customer@domain.tld"
}
Changelogs
For a list of changes to this api endpoint, please see the changelog.
Copyright © 2025, NotaryLive.com