Find out how to use the Document Generator pre-built function in OCI Functions to generate documents based on Office templates and JSON data.
Common Usage Scenarios
Common ways to use the Document Generator function include:
Place an Office Template and JSON data in object storage and directly invoke the function to generate PDF documents and store the results in object storage.
Services related to the Document Generator function include:
The following are best practices when using this pre-built function:
The VCN linked to the application facilitates access to other OCI services by using a Service Gateway, Internet Gateway, or NAT gateway.
Set the default memory size to 512 MB for most tasks. Using bigger data sets, bundling fonts, or using batch processing might require more memory.
For batch processing, set the pre-built function timeout to 300 seconds.
Configuring the Document Generator Function π
To configure a Document Generator function, perform the following steps:
On the Pre-Built Functions page, select Document Generator, and then select Create function.
Configure the Name, Compartment, and Application as follows:
Name: A name of your choice for the new function. The name must start with a letter or underscore, followed by letters, numbers, hyphens, or underscores. Length can be 1β255 characters. Avoid entering confidential information.
To create the function in a different compartment, select Change Compartment.
Application: Select the application in which you want to create the function.
If a suitable application doesn't already exist in the current compartment, select Create new application and specify the following details:
Name: A name for the new application. Avoid entering confidential information.
VCN: The VCN (virtual cloud network) in which to run functions in the application. Optionally, select Change Compartment to select a VCN from a different compartment.
Subnets: The subnet (or subnets, up to a maximum of three) in which to run functions. Optionally, select Change Compartment to select a subnet from a different compartment.
Shape: The processor architecture of the compute instances on which to deploy and run functions in the application. All the functions in the application are deployed and run on compute instances with the same architecture. The function's image must contain the necessary dependencies for the architecture you select.
Tagging options:
If you have permissions to create a resource, then you also have permissions to apply free-form tags to that resource. To apply a defined tag, you must have permissions to use the tag namespace. For more information about tagging, see Resource Tags. If you're not sure whether to apply tags, skip this option or ask an administrator. You can apply tags later.
Configure the IAM policy for pre-built functions.
By default, OCI Functions creates a dynamic group and an IAM policy with the policy statements required to run the pre-built function. Make no changes to accept the default behavior.
If you don't want OCI Functions to automatically create the dynamic group and policy, select Do not create a dynamic group and IAM policy.
Important
If you select the Do not create a dynamic group and IAM policy option, you must define the dynamic group and the IAM policy yourself. For more information, see Permissions.
Configure function memory and timeout values as follows:
Memory: The maximum amount of memory that the function can use while running, in megabytes. This is the memory available to the function image. (Default: 512 MB)
Timeout: The maximum amount of time that the function can run for, in seconds. If the function doesnβt complete in the specified time, the system cancels the function. (Default: 300)
(Optional) Configure Provisioned concurrency to minimize any initial delays when invoking the function by specifying a minimum number of concurrent function invocations for which you want to have execution infrastructure constantly available. (Default: Not selected)
If selected, specify the number of provisioned concurrency units assigned to this function. Default: 10.
Optionally enter any tags in the Tagging options section. If you have permissions to create a resource, then you also have permissions to apply free-form tags to that resource. To apply a defined tag, you must have permissions to use the tag namespace. For more information about tagging, see Resource Tags. If you're not sure whether to apply tags, skip this option or ask an administrator. You can apply tags later.
Logging level, options are DEBUG, INFO, WARN, and ERROR. Defaults to INFO.
No
Permissions π
Running a function requires certain IAM policies. If you selected the Do not create a dynamic group and IAM policy option when creating the function, you must define the dynamic group and the IAM policy yourself.
To set the proper policies, perform the following steps:
Create a dynamic group with the rule:
Copy
ALL {resource.id = '<function_ocid>' , resource.compartment.id = '<compartment_ocid>'}
Configure an IAM policy using the dynamic group:
Copy
Allow dynamic-group <dynamic-group-name> to manage objects in compartment <compartment-name>
Note
Replace <function-ocid> with the OCID of the function that you created in preceding steps.
Note
Replace <dynamic-group-name> with the name of the dynamic group that you created using the function's OCID.
Note
Replace <compartment_ocid> with the OCID of the compartment that contains the function.
Invoking This Function π
You can invoke the function in the following ways:
Invoke the function directly as documented in Invoking Functions by creating a request body as shown in the following JSON example.
With "responseType": "BATCH", multiple documents are produced. You can control the naming of these documents using the required{documentId} in the document name.
output.objectName format
Description
Examples
invoice{documentId}.pdf
No padding. Starts at 1.
invoice1.pdf, invoice2.pdf
invoice{documentId|zeroPadding=auto}.pdf
Automatic padding based on number of documents in batch. Starts at 1.
invoice01.pdf ... invoice10.pdf
invoice{documentId|firstId=51}.pdf
No zero padding. Starts at 51.
invoice51.pdf, invoice52.pdf
invoice{documentId|firstId=51,zeroPadding=5}.pdf
5 digits left padding with 0. Starts at 51.
invoice00051.pdf, invoice00052.pdf
invoice{documentId|zeroPadding=5}.pdf
5 digits left padding with 0. Starts at 1.
invoice00001.pdf, invoice00002.pdf
Supported Document Types π
From Template (contentType)
To Output (contentType)
Microsoft Word >= 2010 (application/vnd.openxmlformats-officedocument.wordprocessingml.document)
PDF (application/pdf)
Microsoft Word >= 2010 (application/vnd.openxmlformats-officedocument.wordprocessingml.document)
Microsoft Word >= 2010 (application/vnd.openxmlformats-officedocument.wordprocessingml.document)
Microsoft Excel >= 2010 (application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet)
PDF (application/pdf)
Microsoft Excel >= 2010 (application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet)
Microsoft Excel >= 2010 (application/application/vnd.openxmlformats-officedocument.spreadsheetml.sheet)
Fonts π
The following fonts are available when generating a PDF:
Caladea
Cookie
Carlito
DejaVu
LiberationMono (Courier)
LiberationSans (Arial)
LiberationSerif (Times New Roman)
NotoSans-Black
NotoSans-BoldItalic
NotoSans-ExtraLight
NotoSans-Light
NotoSans-MediumItalic
NotoSans-SemiBoldItalic
NotoSans-BlackItalic
NotoSans-ExtraBold
NotoSans-ExtraLightItalic
NotoSans-LightItalic
NotoSans-Regular
NotoSans-Thin
NotoSans-Bold
NotoSans-ExtraBoldItalic
NotoSans-Italic
NotoSans-Medium
NotoSans-SemiBold
NotoSans-ThinItalic
NotoSansJP-Bold
NotoSansJP-Regular
NotoSansKR-Regular
NotoSansKR-Bold
NotoSansSC-Regular
NotoSansSC-Bold
NotoSansTC-Regular
NotoSansTC-Bold.otf
NotoSansArabic-Regular
NotoSansArabic-Bold
NotoSansHebrew-Regular
NotoSansHebrew-Bold
NotoSerif-Bold
NotoSerif-BoldItalic
NotoSerif-Italic
NotoSerif-Regular
OracleSans-Bold
OracleSans-Regular
Oswald-Bold
Oswald-ExtraLight
Oswald-Light
Oswald-Medium
Oswald-Regular
Oswald-SemiBold
If you need a font that is not in this list, you can specify a font bundle in the Document Generator request. A font bundle is a zip file containing .ttf and .otf files that will be used during PDF generation. For an example, see RequestSingle Reference.
Protecting a Generated PDF Document with a Password π
When generating a single PDF (with "requestType": "SINGLE") or multiple PDFs (with "requestType": "BATCH"), you can specify a password to protect the generated PDF. Having generated the PDF, the password has to be entered before the PDF can be opened.
To specify the password to protect the generated PDF, include "documentOpenPassword" : "<a-password>" in an "options" section of the request. The value of <a-password> must be an alphanumeric string of between 1 and 127 characters in length.
Note that most clients have an inner timeout of 60 seconds. Even when the pre-built function timeout is set to 300 seconds, the following might be required:
When using the OCI CLI: Use --read-timeout 300
When using the OCI SDK: Set the read timeout to 300 when creating the client
When using DBMS_CLOUD.SEND_REQUEST: Use UTL_HTTP.set_transfer_timeout(300);
Most issues return a 502 status code (see Invoking a function returns a Function failed message and a 502 error). A 502 error with the message "error receiving function response" might be resolved by increasing the memory allocation. A 502 might occur occasionally when the function is in some transient state. A retry might solve the issue.
Document Generator pre-built function status codes
Status Code
Description
200
Success
207
For a responseType=BATCH, verify the response code for each individual document.
400
Validation error or Processing error. If an ObjectNotFound error is returned, ensure that the subnet containing the function has access to the Object Storage service.
All the pre-built functions provide an option to specify the logging level as a configuration parameter. You can set the logging level to DEBUG to get more information.
Since an application has multiple functions, the pre-built function log entries are identified by the prefix "PBF | <PBF NAME> ".
For example, a log entry for the Document Generator pre-built function looks similar to the following:
"PBF | Document Generator | INFO | 2023-08-31T20:19:51.181593Z | 2. LOG001 - Setting Log Level to : DEBUG"