Sha256: dee417a39d0ee8a0040df9286981153339950e7af7c84838efcc3210908ba9da
Contents?: true
Size: 1.89 KB
Versions: 16
Compression:
Stored size: 1.89 KB
Contents
require 'net/http' require 'uri' require 'openssl' require 'json' # Token used to terminate the file in the post body. Make sure it is not # present in the file you're uploading. BOUNDARY = 'myboundary' uri = URI.parse('https://demo.docusign.net/restapi/v2/accounts/327367/envelopes') file = 'test.pdf' request_hash = { emailBlurb: 'eblurb', emailSubject: 'esubj', documents: [ { documentId: '1', name: "#{File.basename(file)}" } ], recipients: { signers: [ { email: 'someone@example.com', name: 'Test Guy', recipientId: '1' } ] }, status: 'sent' } post_body = '' post_body << "\r\n" post_body << "--#{BOUNDARY}\r\n" post_body << "Content-Type: application/json\r\n" post_body << "Content-Disposition: form-data\r\n" post_body << "\r\n" post_body << request_hash.to_json post_body << "\r\n" post_body << "--#{BOUNDARY}\r\n" post_body << "Content-Type: application/pdf\r\n" post_body << "Content-Disposition: file; filename=\"#{File.basename(file)}\"; documentid=1\r\n" post_body << "\r\n" post_body << IO.read(file) #this includes the %PDF-1.3 and %%EOF wrapper post_body << "\r\n" post_body << "--#{BOUNDARY}--\r\n" http = Net::HTTP.new(uri.host, uri.port) http.use_ssl = true http.verify_mode = OpenSSL::SSL::VERIFY_PEER docusign_headers = %{ <DocuSignCredentials> <Username>jonkinney@gmail.com</Username> <Password>MnUWneAH3xqL2G</Password> <IntegratorKey>NAXX-93c39e8c-36c4-4cb5-8099-c4fcedddd7ad</IntegratorKey> </DocuSignCredentials> } headers = { 'X-DocuSign-Authentication' => "#{docusign_headers}", 'Content-Type' => "multipart/form-data; boundary=#{BOUNDARY}", 'Accept' => 'application/json', 'Content-Length' => "#{post_body.length}" } request = Net::HTTP::Post.new(uri.request_uri, headers) request.body = post_body response = http.request(request) puts response.body
Version data entries
16 entries across 16 versions & 1 rubygems