/// <summary> /// Initial method / factory instanciation. /// In case the call is successfully completed you will get back an /// envelope object that can be used to work with this envelope. /// In case the envelope is misconstructed an exception will be thrown /// The IDs on both the recipients and documents are going to be altered /// after the call and the Tabs will be linked to the appropriate document and /// recipient ids. /// </summary> /// <param name="signers">A collection of signer objects that describes who is going to /// recieve the documents. You should have at least one signer. Every signer /// must have at least one signature.</param> /// <param name="documents">A set of documents with tabs attached /// to them. There should be at least one document in the envelope and there should be /// at least one tab on the envelope.</param> /// <param name="subject">Subject of the e-mail that the signers /// are going to receive</param> /// <param name="emailBlurb">e-mail blurb that will be inserted /// into the messages delivered to signers</param> /// <returns>An envelope object that can be used to work with this envelope.</returns> public static Envelope CreateAndSendEnvelope(AccountCredentials accountCredentials, DocuSignWeb.Recipient[] signers, LinkedDocument[] documents, string subject, string emailBlurb, DocuSignWeb.CustomField[] fields, DocuSignWeb.Attachment[] attachments) { // // Assign sequential IDs to all the recipients // int nextRecipientId = 1; foreach (DocuSignWeb.Recipient recipient in signers) { recipient.ID = nextRecipientId.ToString(System.Globalization.CultureInfo.InvariantCulture); nextRecipientId++; } // // go through the documents // assign them appropriate IDs // and then pull out the tabs and properly assign // recipients to for them. // List <DocuSignWeb.Tab> tabs = new List <DocuSignWeb.Tab>(); int nextDocId = 1; foreach (LinkedDocument linkedDoc in documents) { linkedDoc.Document.ID = nextDocId.ToString(CultureInfo.InvariantCulture); foreach (LinkedTab linkedTab in linkedDoc.Tabs) { linkedTab.Tab.DocumentID = linkedDoc.Document.ID; linkedTab.Tab.RecipientID = linkedTab.Recipient.ID; tabs.Add(linkedTab.Tab); } nextDocId++; } // // Envelope wide initialization // DocuSignWeb.Envelope envelope = new DocuSignWeb.Envelope(); envelope.Subject = subject; envelope.EmailBlurb = emailBlurb; envelope.Recipients = signers; envelope.AccountId = accountCredentials.AccountId; // assign the document array envelope.Documents = new DocuSignWeb.Document[documents.Length]; for (int i = 0; i < documents.Length; ++i) { envelope.Documents[i] = documents[i].Document; } // assign the tabs to the envelope envelope.Tabs = tabs.ToArray(); envelope.CustomFields = fields; envelope.EnvelopeAttachment = attachments; using (DocuSignWeb.APIServiceWse apiService = CreateApiProxy(accountCredentials)) { DocuSignWeb.EnvelopeStatus envStatus = apiService.CreateAndSendEnvelope(envelope); return(new Envelope(envStatus.EnvelopeID, accountCredentials)); } }
/// <summary> /// Create a basic envelope without sending /// </summary> /// <param name="accountId">user's account ID</param> /// <param name="subject">email subject line</param> /// <returns></returns> internal static DocuSignWeb.Envelope CreateBasicEnvelope(String accountId, String subject) { DocuSignWeb.Recipient[] recipients = HeartbeatTests.CreateOneSigner(); int nextRecipientId = 1; foreach (DocuSignWeb.Recipient recipient in recipients) { recipient.ID = nextRecipientId.ToString(System.Globalization.CultureInfo.InvariantCulture); nextRecipientId++; } DocuSignWeb.Envelope envelope = new DocuSignWeb.Envelope(); envelope.Subject = subject; envelope.EmailBlurb = "testing docusign creation services"; envelope.Recipients = recipients; envelope.AccountId = accountId; return envelope; }