Case files can be very complex and the configuration of the documents and signers (who is going to sign what) is often non-trivial.
Therefore Penneo has an archive of common case file types that can be used directly as templates. When using a template you only specify the documents and the signers of the case file, and their respective types. Then Penneo makes sure that everything is mapped together with the correct signature lines.
Let's try to create a new case file based on a pre-existing case file template:
// Create a new case file
var myCaseFile = new CaseFile();
// Get the case file templates available to the authenticated user
var availableTemplates = myCaseFile.GetCaseFileTemplates();
// Assign the first list item as the case file template
myCaseFile.SetCaseFileTemplate(availableTemplates.First());
When using a templated case file, every document assigned to the case file must be given a type. As above, the available types can be extracted from the case file object, once it has been persisted. Let's look at an example:
// Create a new document
var myDocument = new Document(myCaseFile);
// Get available document types from the case file object
var availableDocumentTypes = myCaseFile.GetDocumentTypes();
// Lets just assign the first type available
myDocument.SetDocumentType(availableDocumentTypes.First());
Like documents, signers must also be given types. The procedure looks almost identical:
// Create a new signer
var mySigner = new Signer(myCaseFile);
// Get available signer types from the case file object
availableSignerTypes = myCaseFile.GetSignerTypes();
// Lets just assign the first type available
mySigner.SetSignerType(availableSignerTypes.First());
Case file templates can contain restrictions on both documents and signers. A template can fx. require that certain document types are present, or limit the number of signers for a certain signer type.
The case file object has a method for checking templated case files for validation errors:
// Check case file for validation errors
var errors = myCaseFile.GetErrors();
// Check the $errors array to see if any configuration errors were encountered.
if (errors.Any()){
Console.WriteLine("The case file configuration has the following problems:");
foreach(var error in errors){
Console.WriteLine(error);
}
}
else{
Console.WriteLine("The case file is error free!");
}