# Download Files GET https://api.hellosign.com/v3/signature_request/files/{signature_request_id} Obtain a copy of the current documents specified by the `signature_request_id` parameter. Returns a PDF or ZIP file. If the files are currently being prepared, a status code of `409` will be returned instead. Reference: https://developer.hellosign.com/api/signature-request/files ## OpenAPI Specification ```yaml openapi: 3.1.1 info: title: Download Files version: endpoint_signatureRequest.files paths: /signature_request/files/{signature_request_id}: get: operationId: files summary: Download Files description: >- Obtain a copy of the current documents specified by the `signature_request_id` parameter. Returns a PDF or ZIP file. If the files are currently being prepared, a status code of `409` will be returned instead. tags: - - subpackage_signatureRequest parameters: - name: signature_request_id in: path description: The id of the SignatureRequest to retrieve. required: true schema: type: string - name: file_type in: query description: >- Set to `pdf` for a single merged document or `zip` for a collection of individual documents. required: false schema: $ref: >- #/components/schemas/SignatureRequestFilesSignatureRequestIdGetParametersFileType - name: Authorization in: header description: Basic authentication of the form `Basic `. required: true schema: type: string responses: '200': description: successful operation content: application/octet-stream: schema: type: string format: binary '400': description: failed_operation content: {} components: schemas: SignatureRequestFilesSignatureRequestIdGetParametersFileType: type: string enum: - value: pdf - value: zip default: pdf ``` ## SDK Code Examples ```php PHP setUsername("YOUR_API_KEY"); // $config->setAccessToken("YOUR_ACCESS_TOKEN"); try { $response = (new Dropbox\Sign\Api\SignatureRequestApi(config: $config))->signatureRequestFiles( signature_request_id: "fa5c8a0b0f492d768749333ad6fcc214c111e967", file_type: "pdf", ); copy($response->getRealPath(), __DIR__ . '/file_response'); } catch (Dropbox\Sign\ApiException $e) { echo "Exception when calling SignatureRequestApi#signatureRequestFiles: {$e->getMessage()}"; } ``` ```csharp C# using System; using System.Collections.Generic; using System.IO; using System.Text.Json; using Dropbox.Sign.Api; using Dropbox.Sign.Client; using Dropbox.Sign.Model; namespace Dropbox.SignSandbox; public class SignatureRequestFilesExample { public static void Run() { var config = new Configuration(); config.Username = "YOUR_API_KEY"; // config.AccessToken = "YOUR_ACCESS_TOKEN"; try { var response = new SignatureRequestApi(config).SignatureRequestFiles( signatureRequestId: "fa5c8a0b0f492d768749333ad6fcc214c111e967", fileType: "pdf" ); var fileStream = File.Create("./file_response"); response.Seek(0, SeekOrigin.Begin); response.CopyTo(fileStream); fileStream.Close(); } catch (ApiException e) { Console.WriteLine("Exception when calling SignatureRequestApi#SignatureRequestFiles: " + e.Message); Console.WriteLine("Status Code: " + e.ErrorCode); Console.WriteLine(e.StackTrace); } } } ``` ```typescript TypeScript import * as fs from 'fs'; import api from "@dropbox/sign" import models from "@dropbox/sign" const apiCaller = new api.SignatureRequestApi(); apiCaller.username = "YOUR_API_KEY"; // apiCaller.accessToken = "YOUR_ACCESS_TOKEN"; apiCaller.signatureRequestFiles( "fa5c8a0b0f492d768749333ad6fcc214c111e967", // signatureRequestId "pdf", // fileType ).then(response => { fs.createWriteStream('./file_response').write(response.body); }).catch(error => { console.log("Exception when calling SignatureRequestApi#signatureRequestFiles:"); console.log(error.body); }); ``` ```java Java package com.dropbox.sign_sandbox; import com.dropbox.sign.ApiException; import com.dropbox.sign.Configuration; import com.dropbox.sign.api.*; import com.dropbox.sign.auth.*; import com.dropbox.sign.JSON; import com.dropbox.sign.model.*; import java.io.File; import java.math.BigDecimal; import java.time.LocalDate; import java.time.OffsetDateTime; import java.util.ArrayList; import java.util.List; import java.util.Map; public class SignatureRequestFilesExample { public static void main(String[] args) { var config = Configuration.getDefaultApiClient(); ((HttpBasicAuth) config.getAuthentication("api_key")).setUsername("YOUR_API_KEY"); // ((HttpBearerAuth) config.getAuthentication("oauth2")).setBearerToken("YOUR_ACCESS_TOKEN"); try { var response = new SignatureRequestApi(config).signatureRequestFiles( "fa5c8a0b0f492d768749333ad6fcc214c111e967", // signatureRequestId "pdf" // fileType ); response.renameTo(new File("./file_response")); } catch (ApiException e) { System.err.println("Exception when calling SignatureRequestApi#signatureRequestFiles"); System.err.println("Status code: " + e.getCode()); System.err.println("Reason: " + e.getResponseBody()); System.err.println("Response headers: " + e.getResponseHeaders()); e.printStackTrace(); } } } ``` ```ruby Ruby require "json" require "dropbox-sign" Dropbox::Sign.configure do |config| config.username = "YOUR_API_KEY" # config.access_token = "YOUR_ACCESS_TOKEN" end begin response = Dropbox::Sign::SignatureRequestApi.new.signature_request_files( "fa5c8a0b0f492d768749333ad6fcc214c111e967", # signature_request_id { file_type: "pdf", }, ) FileUtils.cp(response.path, "./file_response") rescue Dropbox::Sign::ApiError => e puts "Exception when calling SignatureRequestApi#signature_request_files: #{e}" end ``` ```python Python import json from datetime import date, datetime from pprint import pprint from dropbox_sign import ApiClient, ApiException, Configuration, api, models configuration = Configuration( username="YOUR_API_KEY", # access_token="YOUR_ACCESS_TOKEN", ) with ApiClient(configuration) as api_client: try: response = api.SignatureRequestApi(api_client).signature_request_files( signature_request_id="fa5c8a0b0f492d768749333ad6fcc214c111e967", file_type="pdf", ) open("./file_response", "wb").write(response.read()) except ApiException as e: print("Exception when calling SignatureRequestApi#signature_request_files: %s\n" % e) ``` ```go package main import ( "fmt" "net/http" "io" ) func main() { url := "https://api.hellosign.com/v3/signature_request/files/fa5c8a0b0f492d768749333ad6fcc214c111e967" req, _ := http.NewRequest("GET", url, nil) req.Header.Add("Authorization", "Basic :") res, _ := http.DefaultClient.Do(req) defer res.Body.Close() body, _ := io.ReadAll(res.Body) fmt.Println(res) fmt.Println(string(body)) } ``` ```swift import Foundation let headers = ["Authorization": "Basic :"] let request = NSMutableURLRequest(url: NSURL(string: "https://api.hellosign.com/v3/signature_request/files/fa5c8a0b0f492d768749333ad6fcc214c111e967")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0) request.httpMethod = "GET" request.allHTTPHeaderFields = headers let session = URLSession.shared let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in if (error != nil) { print(error as Any) } else { let httpResponse = response as? HTTPURLResponse print(httpResponse) } }) dataTask.resume() ```