Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(AutoIt) DocuSign: Requesting a Signature via Email (Remote Signing)See more DocuSign ExamplesThis code example demonstrates the simplest and quickest workflow for requesting a signature for a document via email. The email will contain a signing link the recipient can use to electronically sign a document from their mobile or desktop computer. For more information, see https://developers.docusign.com/esign-rest-api/code-examples/quickstart-request-signature-email
; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oHttp = ObjCreate("Chilkat_9_5_0.Http") Local $bSuccess ; Implements the following CURL command: ; curl --request POST https://demo.docusign.net/restapi/v2.1/accounts/${accountId}/envelopes \ ; --header "Authorization: Bearer ${accessToken}" \ ; --header "Content-Type: application/json" \ ; --data '{ ; "emailSubject": "Please sign this document", ; "documents": [ ; { ; "documentBase64": "JVBERi0xLjMKMyAwIG9iag ... dGFydHhyZWYKNjk5CiUlRU9GCg==", ; "name": "Lorem Ipsum", ; "fileExtension": "pdf", ; "documentId": "1" ; } ; ], ; "recipients": { ; "signers": [ ; { ; "email": "joe_sample@example.com", ; "name": "Joe Sample", ; "recipientId": "1", ; "routingOrder": "1", ; "tabs": { ; "signHereTabs": [ ; { ; "documentId": "1", "pageNumber": "1", ; "recipientId": "1", "tabLabel": "SignHereTab", ; "xPosition": "195", "yPosition": "147" ; } ; ] ; } ; } ; ] ; }, ; "status": "sent" ; }' ; Use this online tool to generate code from sample JSON: ; Generate Code to Create JSON ; The following JSON is sent in the request body. ; { ; "emailSubject": "Please sign this document", ; "documents": [ ; { ; "documentBase64": "JVBERi0xLjMKMyAwIG9iag ... dGFydHhyZWYKNjk5CiUlRU9GCg==", ; "name": "Lorem Ipsum", ; "fileExtension": "pdf", ; "documentId": "1" ; } ; ], ; "recipients": { ; "signers": [ ; { ; "email": "joe_sample@example.com", ; "name": "Joe Sample", ; "recipientId": "1", ; "routingOrder": "1", ; "tabs": { ; "signHereTabs": [ ; { ; "documentId": "1", ; "pageNumber": "1", ; "recipientId": "1", ; "tabLabel": "SignHereTab", ; "xPosition": "195", ; "yPosition": "147" ; } ; ] ; } ; } ; ] ; }, ; "status": "sent" ; } ; Load a PDF to be signed. $oPdfData = ObjCreate("Chilkat_9_5_0.BinData") $bSuccess = $oPdfData.LoadFile("qa_data/pdf/helloWorld.pdf") If ($bSuccess = False) Then ConsoleWrite("Failed to load local PDF file." & @CRLF) Exit EndIf $oJson = ObjCreate("Chilkat_9_5_0.JsonObject") $oJson.UpdateString("emailSubject","Please sign this document") $oJson.UpdateString("documents[0].documentBase64",$oPdfData.GetEncoded("base64")) $oJson.UpdateString("documents[0].name","Lorem Ipsum") $oJson.UpdateString("documents[0].fileExtension","pdf") $oJson.UpdateString("documents[0].documentId","1") $oJson.UpdateString("recipients.signers[0].email","joe_sample@example.com") $oJson.UpdateString("recipients.signers[0].name","Joe Sample") $oJson.UpdateString("recipients.signers[0].recipientId","1") $oJson.UpdateString("recipients.signers[0].routingOrder","1") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].documentId","1") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].pageNumber","1") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].recipientId","1") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].tabLabel","SignHereTab") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].xPosition","195") $oJson.UpdateString("recipients.signers[0].tabs.signHereTabs[0].yPosition","147") $oJson.UpdateString("status","sent") ; Get our previously obtained OAuth2 access token, which should contain JSON like this: ; { ; "access_token": "eyJ0eXA....YQyig", ; "token_type": "Bearer", ; "refresh_token": "eyJ0eXA....auE3eHKg", ; "expires_in": 28800 ; } $oJsonToken = ObjCreate("Chilkat_9_5_0.JsonObject") $bSuccess = $oJsonToken.LoadFile("qa_data/tokens/docusign.json") $oSbAuth = ObjCreate("Chilkat_9_5_0.StringBuilder") $oSbAuth.Append("Bearer ") $oSbAuth.Append($oJsonToken.StringOf("access_token")) $oHttp.SetRequestHeader "Authorization",$oSbAuth.GetAsString() $oHttp.SetRequestHeader "Content-Type","application/json" ; Don't forget to modify this line to use your account ID Local $oResp = $oHttp.PostJson3("https://demo.docusign.net/restapi/v2.1/accounts/${accountId}/envelopes","application/json",$oJson) If ($oHttp.LastMethodSuccess = False) Then ConsoleWrite($oHttp.LastErrorText & @CRLF) Exit EndIf $oSbResponseBody = ObjCreate("Chilkat_9_5_0.StringBuilder") $oResp.GetBodySb($oSbResponseBody) $oJResp = ObjCreate("Chilkat_9_5_0.JsonObject") $oJResp.LoadSb($oSbResponseBody) $oJResp.EmitCompact = False ConsoleWrite("Response Body:" & @CRLF) ConsoleWrite($oJResp.Emit() & @CRLF) Local $iRespStatusCode = $oResp.StatusCode ConsoleWrite("Response Status Code = " & $iRespStatusCode & @CRLF) If ($iRespStatusCode >= 400) Then ConsoleWrite("Response Header:" & @CRLF) ConsoleWrite($oResp.Header & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf ; Sample JSON response: ; (Sample code for parsing the JSON response is shown below) ; { ; "envelopeId": "d51cfdab-22ed-4832-bf68-446c44077ffc", ; "uri": "/envelopes/d51cfdab-22ed-4832-bf68-446c44077ffc", ; "statusDateTime": "2018-04-17T16:31:51.8830000Z", ; "status": "sent" ; } ; Sample code for parsing the JSON response... ; Use the following online tool to generate parsing code from sample JSON: ; Generate Parsing Code from JSON Local $sEnvelopeId Local $sUri Local $statusDateTime Local $status $sEnvelopeId = $oJResp.StringOf("envelopeId") $sUri = $oJResp.StringOf("uri") $statusDateTime = $oJResp.StringOf("statusDateTime") $status = $oJResp.StringOf("status") |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.