Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PHP Extension) DocuSign Send a Draft EnvelopeSee more DocuSign ExamplesDemonstrates how to send a DocuSign draft envelope. For more information, see https://developers.docusign.com/docs/esign-rest-api/reference/envelopes/envelopes/update/
<?php // The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number. // For example, if using Chilkat v9.5.0.48, then include as shown here: include("chilkat_9_5_0.php"); // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. $http = new CkHttp(); // Load a previously obtained OAuth2 access token. $jsonToken = new CkJsonObject(); $success = $jsonToken->LoadFile('qa_data/tokens/docusign.json'); if ($success == false) { print $jsonToken->lastErrorText() . "\n"; exit; } // Adds the "Authorization: Bearer eyJ0eXAi.....UE8Kl_V8KroQ" header. $http->put_AuthToken($jsonToken->stringOf('access_token')); // Send the following request. // Make sure to use your own account ID (obtained from Get Docusign User Account Information) // PUT https://demo.docusign.net/restapi/v2.1/accounts/<account ID>/envelopes/<envelope ID> HTTP/1.1 // Accept: application/json // Cache-Control: no-cache // Authorization: Bearer eyJ0eX... // Content-Length: ... // Content-Type: application/json // // { // "status": "sent" // } $json = new CkJsonObject(); $json->UpdateString('status','sent'); $sbJson = new CkStringBuilder(); $json->put_EmitCompact(false); $json->EmitSb($sbJson); $http->SetRequestHeader('Cache-Control','no-cache'); $http->SetRequestHeader('Accept','application/json'); // Use your own account ID here. $http->SetUrlVar('accountId','7f3f65ed-5e87-418d-94c1-92499ddc8252'); // Use the envelope ID returned by DocuSign when creating the draft envelope). $http->SetUrlVar('envelopeId','cee4191c-f94e-4089-9d7c-8033685cbc1a'); $url = 'https://demo.docusign.net/restapi/v2.1/accounts/{$accountId}/envelopes/{$envelopeId}'; // resp is a CkHttpResponse $resp = $http->PTextSb('PUT',$url,$sbJson,'utf-8','application/json',false,false); if ($http->get_LastMethodSuccess() == false) { print $http->lastErrorText() . "\n"; exit; } $jResp = new CkJsonObject(); $jResp->Load($resp->bodyStr()); $jResp->put_EmitCompact(false); print 'Response Body:' . "\n"; print $jResp->emit() . "\n"; // If you get a 401 response status code, it's likely you need to refresh the DocuSign OAuth2 token). $respStatusCode = $resp->get_StatusCode(); print 'Response Status Code = ' . $respStatusCode . "\n"; if ($respStatusCode >= 400) { print 'Response Header:' . "\n"; print $resp->header() . "\n"; print 'Failed.' . "\n"; exit; } // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // If the envelope you're trying to send is not yet completed, you'll get an error such as this: // { // "errorCode": "ENVELOPE_IS_INCOMPLETE", // "message": "The Envelope is not Complete. A Complete Envelope Requires Documents, Recipients, Tabs, and a Subject Line." // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON ?> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.