PDFGenerationAPI - Scoped, Global

  • Rversion finale: Australia
  • Mis à jour 12 mars 2026
  • 41 minutes de lecture
  • The PDFGenerationAPI provides support for PDF conversion and handling PDF fields.

    This API is part of the ServiceNow PDF Generation Utilities plugin (com.snc.apppdfgenerator) and is provided within the sn_pdfgeneratorutils namespace. The plugin is activated by default.

    Use the glide.pdf.url.whitelist property to add an extra layer of validation to ensure whether any external URL introduced should be included in the generated PDF. If the system property glide.pdf.url.whitelisting.enabled is set to true, the PDF does not process URL content unless it is listed in the Value field of the com.snc.pdf.whitelisted_urls system property. These properties are listed in the System Properties [sys_properties] table. For more information, see Available system properties.

    Remarque :
    The maximum PDF size is 50 MB.
    The methods in this class enable the following tasks:
    Remarque :
    These methods can also be used for documents created by non-catalog items.

    PDFGenerationAPI – PDFGenerationAPI()

    Instantiates a new PDFGenerationAPI object.

    Tableau 1. Parameters
    Name Type Description
    None

    The following example shows how to create a PDFGenerationAPI object.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;

    PDFGenerationAPI – convertToPDF(String html, String targetTable, String targetTableSysId, String pdfName, String fontFamilySysId, Object documentConfiguration)

    Converts an HTML string to a PDF document.

    This method creates a PDF using the page size A4 – 595 × 842 points. Content will be truncated if it exceeds this size.

    To generate a PDF with additional settings, such as page size, orientation, and page numbers, use convertToPDFWithHeaderFooter().

    Tableau 2. Parameters
    Name Type Description
    html String HTML to convert to a PDF document.
    targetTable String Name of the table on which to attach the converted PDF.
    targetTableSysId String Sys_id of the record on which to attach the converted PDF.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    fontFamilySysId String Optional. Sys_id of the font family to use for the PDF. This sys_id is from the PDF Generation Font Family [sys_pdf_generation_font_family] table.

    Default: none

    documentConfiguration Object Optional. Object containing a table of contents configuration and a page number configuration.
    {​
       "accessibilityEnabled" : Boolean,
       "toc_config" : "String",​
       "page_number_config": "String"​
    }​
    documentConfiguration.accessibilityEnabled Boolean Optional. Flag that indicates whether to format the generated PDF to support accessibility. When this feature is enabled, accessibility tags will be available in the PDF tag tree to help users who rely on screen readers to navigate, understand, and interact with the generated PDF documents.
    Valid values:
    • true: The generated PDF is formatted for accessibility.
    • false: The generated PDF is not formatted for accessibility.

    Default: False

    documentConfiguration.toc_config String Optional. Sys_id of the table of contents configuration to use for the PDF. This sys_id is from the Table of Contents Configuration [doc_toc_config] table.

    Default: none

    documentConfiguration.page_number_config String Optional. Sys_id of the page number configuration to use for the PDF. This sys_id is from the Page Number Configuration [doc_page_number_config] table.

    Default: none

    Tableau 3. Returns
    Type Description
    Object Object containing sys_id of the PDF attachment if conversion is successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "request_id": "String",
      "status": "String"
    }
    <Object>.​attachment_id If HTML conversion is successful, sys_id of the converted and attached PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.message Message confirming success or error.
    Possible values:
    • Conversion failed. – No PDF created. Make sure the values provided are accurate.
    • Conversion is successful. – The HTML successfully converted to PDF.
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.
    • <URL> is not listed in whitelisted URL, please check URL whitelisting property : "glide.pdf.url.whitelisting.enabled" and "com.snc.pdf.whitelisted_urls" – If the system property glide.pdf.url.whitelisting.enabled is set to true, the PDF does not process URL content unless it is listed in the Value field of the com.snc.pdf.whitelisted_urls system property. These properties are listed in the System Properties [sys_properties] table.

    Data type: String

    <Object>.request_id Sys_id of the change producer request record.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to convert HTML to a PDF and attach it to a record in the Incident [incident] table.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    
    //  (Option) get HTML from the description field of an incident record
    var gr = new GlideRecord("incident");
    var html;
    
    if (gr.get("<tableSysId>")) {
     html = gr.description.toString();
    }
    
    var result = v.convertToPDF(html, "incident", "<target_sys_id>", "myPDF");
    gs.info(JSON.stringify(result));

    Output:

    {"attachment_id":"<sys_id>","message":"Conversion is successful.","request_id":"<change_sys_id>","status":"success"}

    PDFGenerationAPI – convertToPDFAsync(String html, String targetTable, String targetTableSysId, String pdfName, String fontFamilySysId, Object documentConfiguration)

    Stages a job that converts an HTML string to a PDF document asynchronously. Asynchronous processing enables you to work in the instance while the PDF conversion is in progress. This is especially helpful for larger PDF exports.

    This API creates a PDF using the page size A4 – 595 × 842 points. Content will be truncated if it exceeds this size.

    To generate a PDF with additional settings, such as page size, orientation, and page numbers, use convertToPDFWithHeaderFooterAsync().

    Tableau 4. Parameters
    Name Type Description
    html String HTML to convert to a PDF document.
    targetTable String Name of the table on which to attach the converted PDF.
    targetTableSysId String Sys_id of the record on which to attach the converted PDF.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    fontFamilySysId String Optional. Sys_id of the font family to use for the PDF. This sys_id is from the PDF Generation Font Family [sys_pdf_generation_font_family] table.

    Default: none

    documentConfiguration Object Optional. Object containing a table of contents configuration and a page number configuration.
    {​
       "accessibilityEnabled" : Boolean,
       "toc_config" : "String",​
       "page_number_config": "String"​
    }​
    documentConfiguration.accessibilityEnabled Boolean Optional. Flag that indicates whether to format the generated PDF to support accessibility. When this feature is enabled, accessibility tags will be available in the PDF tag tree to help users who rely on screen readers to navigate, understand, and interact with the generated PDF documents.
    Valid values:
    • true: The generated PDF is formatted for accessibility.
    • false: The generated PDF is not formatted for accessibility.

    Default: False

    documentConfiguration.toc_config String Optional. Sys_id of the table of contents configuration to use for the PDF. This sys_id is from the Table of Contents Configuration [doc_toc_config] table.

    Default: none

    documentConfiguration.page_number_config String Optional. Sys_id of the page number configuration to use for the PDF. This sys_id is from the Page Number Configuration [doc_page_number_config] table.

    Default: none

    Tableau 5. Returns
    Type Description
    Object Object indicating whether the PDF conversion is in progress. You can review the conversion status in the PDF Generation Status [sys_pdf_generation_status] table.
    {
      "message": "String",
      "request_id": "String"
    }
    <Object>.message Message confirming success or error.
    Possible values:
    • HTML to PDF Conversion is in progress. – Request to convert HTML to a PDF document is successful.
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.
    • <URL> is not listed in whitelisted URL, please check URL whitelisting property : "glide.pdf.url.whitelisting.enabled" and "com.snc.pdf.whitelisted_urls" – If the system property glide.pdf.url.whitelisting.enabled is set to true, the PDF does not process URL content unless it is listed in the Value field of the com.snc.pdf.whitelisted_urls system property. These properties are listed in the System Properties [sys_properties] table.

    Data type: String

    <Object>.request_id Sys_id of the change producer request record.

    Data type: String

    The following example shows how to queue a task that converts HTML to a PDF. When the conversion is complete, the PDF named "myPDF" is attached to the target record in the Incident [incident] table.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    
    //  (Option) get HTML from the description field of an incident record
    var gr = new GlideRecord("incident");
    var html;
    
    if (gr.get("<tableSysId>")) {
     html = gr.description.toString();
    }
    
    var result = v.convertToPDFAsync(html, "incident", "<target_sys_id>", "myPDF");
    gs.info(JSON.stringify(result));

    Output:

    {"message":"HTML to PDF Conversion is in progress.","request_id":"<sys_id>"}

    PDFGenerationAPI – convertToPDFWithHeaderFooter(String html, String targetTable, String targetTableSysId, String pdfName, Object headerFooterInfo, String fontFamilySysId, Object documentConfiguration)

    Converts an HTML string into a PDF with header and footer content.

    Use this method to generate PDFs with page settings:
    • Header and footer information
    • Margin sizes
    • Orientation
    • Enumeration
    • Page size
    Tableau 6. Parameters
    Name Type Description
    html String HTML to convert to a PDF document.
    targetTable String Name of the table on which to attach the converted PDF.
    targetTableSysId String Sys_id of the record on which to attach the converted PDF.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    headerFooterInfo Object Defines PDF header and footer details.
    {
      "FooterImageAlignment": "String",
      "FooterImageAttachmentId": "String",
      "FooterImageHeight": "String",
      "FooterText": "String",
      "FooterTextAlignment": "String",
      "GeneratePageNumber": "String",
      "HeaderImageAlignment": "String",
      "HeaderImageAttachmentId": "String",
      "HeaderImageHeight": "String",
      "LeftOrRightMargin": "String",
      "PageOrientation": "String",
      "PageSize": "String",
      "TopOrBottomMargin": "String"
    }
    headerFooterInfo.​FooterImageAlignment String Sets the image position in the footer.
    Valid values:
    • BOTTOM_CENTER: Position the image in the bottom center of the footer.
    • BOTTOM_LEFT: Position the image in the bottom left area of the footer.
    • BOTTOM_RIGHT: Position the image in the bottom right area of the footer.
    • TOP_CENTER: Position the image in the top center of the footer.
    • TOP_LEFT: Position the image in the top left area of the footer.
    • TOP_RIGHT: Position the image in the top right area of the footer.
    headerFooterInfo.​FooterImageAttachmentId String Sys_id of the footer image in the Attachments [sys_attachment] table. To determine if the file type is supported in your instance, Navigate to System Properties, Security, and check if it's listed in List of file extensions (comma-separated) that can be attached field.
    headerFooterInfo.​FooterImageHeight String Height of footer image.

    Default: 50 points

    headerFooterInfo.​FooterText String Footer text to place at the bottom of each PDF page.
    headerFooterInfo.​FooterTextAlignment String Sets the text position in the footer. Make sure this value does not match or conflict with the area provided in headerFooterInfo.FooterImageAlignment.
    Valid values:
    • BOTTOM_CENTER: Position the text in the bottom center of the footer.
    • BOTTOM_LEFT: Position the text in the bottom left area of the footer.
    • BOTTOM_RIGHT: Position the text in the bottom right area of the footer.
    • TOP_CENTER: Position the text in the top center of the footer.
    • TOP_LEFT: Position the text in the top left area of the footer.
    • TOP_RIGHT: Position the text in the top right area of the footer.
    headerFooterInfo.​GeneratePageNumber String Flag that indicates whether to generate a PDF page number.
    Valid values:
    • true: Generate page numbers.
    • false: Do not generate page numbers.

    Default: true

    headerFooterInfo.​HeaderImageAlignment String Sets the image position in the header.
    Valid values:
    • center: Position the image in the center of the header.
    • left: Position the image on the left side of the header.
    • right: Position the image on the right side of the header.
    headerFooterInfo.​HeaderImageAttachmentId String Sys_id of the header image in the Attachments [sys_attachment] table. To determine if the file type is supported in your instance, Navigate to System Properties, Security, and check if it's listed in List of file extensions (comma-separated) that can be attached field.
    headerFooterInfo.​HeaderImageHeight String Height of the header image.

    Default: 50 points

    headerFooterInfo.​LeftOrRightMargin String Size of the left and right margins. If positioned in the left or right side of the page, header/footer details are placed within in this area.

    Default: 36 points

    headerFooterInfo.​PageOrientation String Page orientation.
    Valid values:
    • PORTRAIT
    • LANDSCAPE

    Default: Portrait

    headerFooterInfo.​PageSize String Document page size.
    Valid values:
    • A4 – 595 × 842 points
    • LETTER – 612 × 792 points
    • LEDGER – 792 x 1224 points

    Content will be truncated if it exceeds the page size.

    headerFooterInfo.​TopOrBottomMargin String Size of the top and bottom margins. Header and footer details are placed within in this area.

    Default: 72 points

    fontFamilySysId String Optional. Sys_id of the font family to use for the PDF. This sys_id is from the PDF Generation Font Family [sys_pdf_generation_font_family] table.

    Default: none

    documentConfiguration Object Optional. Object containing a table of contents configuration and a page number configuration.
    {​
       "accessibilityEnabled" : Boolean,
       "toc_config" : "String",​
       "page_number_config": "String"​
    }​
    documentConfiguration.accessibilityEnabled Boolean Optional. Flag that indicates whether to format the generated PDF to support accessibility. When this feature is enabled, accessibility tags will be available in the PDF tag tree to help users who rely on screen readers to navigate, understand, and interact with the generated PDF documents.
    Valid values:
    • true: The generated PDF is formatted for accessibility.
    • false: The generated PDF is not formatted for accessibility.

    Default: False

    documentConfiguration.toc_config String Optional. Sys_id of the table of contents configuration to use for the PDF. This sys_id is from the Table of Contents Configuration [doc_toc_config] table.

    Default: none

    documentConfiguration.page_number_config String Optional. Sys_id of the page number configuration to use for the PDF. This sys_id is from the Page Number Configuration [doc_page_number_config] table.

    Default: none

    Tableau 7. Returns
    Type Description
    Object Object containing sys_id of the PDF attachment if conversion is successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "request_id": "String",
      "status": "String"
    }
    <Object>.​attachment_id If HTML conversion is successful, sys_id of the converted and attached PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.​message Message confirming success or error.
    Possible values:
    • Conversion failed. – No PDF created. Make sure the values provided are accurate.
    • Conversion is successful. – The HTML successfully converted to PDF.
    • Footer Image alignment and text alignment cannot be in the same region with same alignment: <footerImageAlignment value> – Make sure that headerFooterInfo.​FooterImageAlignment and headerFooterInfo.​FooterTextAlignment values are not in the same area.
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • Invalid footer image alignment: <invalid_option> is provided. – Provide a valid option in the headerFooterInfo.​FooterImageAlignment property.
    • Invalid footer text alignment: " + <invalid_option> + " is provided. – Provide a valid option in the headerFooterInfo.​footerTextAlignment property.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Unable to get the footer image. sysId: + <value provided> – Make sure the sys_id provided for headerFooterInfo.​footerImageId is accurate.
    • Unable to get the header image. sysId: + <value provided> – Make sure the sys_id provided for headerFooterInfo.​headerImageId is accurate.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.
    • <URL> is not listed in whitelisted URL, please check URL whitelisting property : "glide.pdf.url.whitelisting.enabled" and "com.snc.pdf.whitelisted_urls" – If the system property glide.pdf.url.whitelisting.enabled is set to true, the PDF does not process URL content unless it is listed in the Value field of the com.snc.pdf.whitelisted_urls system property. These properties are listed in the System Properties [sys_properties] table.

    Data type: String

    <Object>.request_id Sys_id of the change producer request record.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to convert HTML to a PDF named "myPDF" and add the PDF as an attachment to a record in the Incident [incident] table. The PDF contains header and footer provided via attachment.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    
    //  (Option) get HTML from the description field of an incident record
    var gr = new GlideRecord("incident");
    var html;
    
    if (gr.get("<tableSysId>")) {
     html = gr.description.toString();
    }
    
    var hfInfo = new Object();
    hfInfo["HeaderImageAttachmentId"] = "<hdrImgAttSysId>";
    hfInfo["HeaderImageAlignment"] = "left";
    hfInfo["FooterImageAttachmentId"] = "<ftrImgAttSysId>";
    hfInfo["FooterImageAlignment"] = "TOP_CENTER";
    hfInfo["FooterText"] = "Sample Footer Message";
    hfInfo["PageSize"] = "A4";
    hfInfo["GeneratePageNumber"] = "false";
    hfInfo["TopOrBottomMargin"] = "36";
    hfInfo["LeftOrRightMargin"] = "24";
    
    var result = v.convertToPDFWithHeaderFooter(html, "incident", "<targetTbl_sys_id>", "myPDF", hfInfo);
    gs.info(JSON.stringify(result));

    Output:

    {"attachment_id":"<sys_id>","message":"Conversion is successful.","request_id":"<change_sys_id>","status":"success"}

    PDFGenerationAPI – convertToPDFWithHeaderFooterAsync(String html, String targetTable, String targetTableSysId, String pdfName, Object headerFooterInfo, String fontFamilySysId, Object documentConfiguration)

    Stages a job that converts an HTML string into a PDF with header and footer content asynchronously. Asynchronous processing enables you to work in the instance while the PDF conversion is in progress. This is especially helpful for larger PDF exports.

    Use this method to generate PDFs with page settings:
    • Header and footer information
    • Margin sizes
    • Orientation
    • Enumeration
    • Page size
    Tableau 8. Parameters
    Name Type Description
    html String HTML to convert to a PDF document.
    targetTable String Name of the table on which to attach the converted PDF.
    targetTableSysId String Sys_id of the record on which to attach the converted PDF.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    headerFooterInfo Object Defines PDF header and footer details.
    {
      "FooterImageAlignment": "String",
      "FooterImageAttachmentId": "String",
      "FooterImageHeight": "String",
      "FooterText": "String",
      "FooterTextAlignment": "String",
      "GeneratePageNumber": "String",
      "HeaderImageAlignment": "String",
      "HeaderImageAttachmentId": "String",
      "HeaderImageHeight": "String",
      "LeftOrRightMargin": "String",
      "PageOrientation": "String",
      "PageSize": "String",
      "TopOrBottomMargin": "String"
    }
    headerFooterInfo.​FooterImageAlignment String Sets the image position in the footer.
    Valid values:
    • BOTTOM_CENTER: Position the image in the bottom center of the footer.
    • BOTTOM_LEFT: Position the image in the bottom left area of the footer.
    • BOTTOM_RIGHT: Position the image in the bottom right area of the footer.
    • TOP_CENTER: Position the image in the top center of the footer.
    • TOP_LEFT: Position the image in the top left area of the footer.
    • TOP_RIGHT: Position the image in the top right area of the footer.
    headerFooterInfo.​FooterImageAttachmentId String Sys_id of the footer image in the Attachments [sys_attachment] table. To determine if the file type is supported in your instance, Navigate to System Properties, Security, and check if it's listed in List of file extensions (comma-separated) that can be attached field.
    headerFooterInfo.​FooterImageHeight String Height of footer image.

    Default: 50 points

    headerFooterInfo.​FooterText String Footer text to place at the bottom of each PDF page.
    headerFooterInfo.​FooterTextAlignment String Sets the text position in the footer. Make sure this value does not match or conflict with the area provided in headerFooterInfo.FooterImageAlignment.
    Valid values:
    • BOTTOM_CENTER: Position the text in the bottom center of the footer.
    • BOTTOM_LEFT: Position the text in the bottom left area of the footer.
    • BOTTOM_RIGHT: Position the text in the bottom right area of the footer.
    • TOP_CENTER: Position the text in the top center of the footer.
    • TOP_LEFT: Position the text in the top left area of the footer.
    • TOP_RIGHT: Position the text in the top right area of the footer.
    headerFooterInfo.​GeneratePageNumber String Flag that indicates whether to generate a PDF page number.
    Valid values:
    • true: Generate page numbers.
    • false: Do not generate page numbers.

    Default: true

    headerFooterInfo.​HeaderImageAlignment String Sets the image position in the header.
    Valid values:
    • center: Position the image in the center of the header.
    • left: Position the image on the left side of the header.
    • right: Position the image on the right side of the header.
    headerFooterInfo.​HeaderImageAttachmentId String Sys_id of the header image in the Attachments [sys_attachment] table. To determine if the file type is supported in your instance, Navigate to System Properties, Security, and check if it's listed in List of file extensions (comma-separated) that can be attached field.
    headerFooterInfo.​HeaderImageHeight String Height of the header image.

    Default: 50 points

    headerFooterInfo.​LeftOrRightMargin String Size of the left and right margins. If positioned in the left or right side of the page, header/footer details are placed within in this area.

    Default: 36 points

    headerFooterInfo.​PageOrientation String Page orientation.
    Valid values:
    • PORTRAIT
    • LANDSCAPE

    Default: Portrait

    headerFooterInfo.​PageSize String Document page size.
    Valid values:
    • A4 – 595 × 842 points
    • LETTER – 612 × 792 points
    • LEDGER – 792 x 1224 points

    Content will be truncated if it exceeds the page size.

    headerFooterInfo.​TopOrBottomMargin String Size of the top and bottom margins. Header and footer details are placed within in this area.

    Default: 72 points

    fontFamilySysId String Optional. Sys_id of the font family to use for the PDF. This sys_id is from the PDF Generation Font Family [sys_pdf_generation_font_family] table.

    Default: none

    documentConfiguration Object Optional. Object containing a table of contents configuration and a page number configuration.
    {​
       "accessibilityEnabled" : Boolean,
       "toc_config" : "String",​
       "page_number_config": "String"​
    }​
    documentConfiguration.accessibilityEnabled Boolean Optional. Flag that indicates whether to format the generated PDF to support accessibility. When this feature is enabled, accessibility tags will be available in the PDF tag tree to help users who rely on screen readers to navigate, understand, and interact with the generated PDF documents.
    Valid values:
    • true: The generated PDF is formatted for accessibility.
    • false: The generated PDF is not formatted for accessibility.

    Default: False

    documentConfiguration.toc_config String Optional. Sys_id of the table of contents configuration to use for the PDF. This sys_id is from the Table of Contents Configuration [doc_toc_config] table.

    Default: none

    documentConfiguration.page_number_config String Optional. Sys_id of the page number configuration to use for the PDF. This sys_id is from the Page Number Configuration [doc_page_number_config] table.

    Default: none

    Tableau 9. Returns
    Type Description
    Object
    <Object>.​message Message confirming success or error.
    Possible values:
    • HTML to PDF Conversion is in progress. – Request to convert HTML to a PDF document is successful.
    • Footer Image alignment and text alignment cannot be in the same region with same alignment: <footerImageAlignment value> – Make sure that headerFooterInfo.​FooterImageAlignment and headerFooterInfo.​FooterTextAlignment values are not in the same area.
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • Invalid footer image alignment: <invalid_option> is provided. – Provide a valid option in the headerFooterInfo.​FooterImageAlignment property.
    • Invalid footer text alignment: " + <invalid_option> + " is provided. – Provide a valid option in the headerFooterInfo.​footerTextAlignment property.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Unable to get the footer image. sysId: + <value provided> – Make sure the sys_id provided for headerFooterInfo.​footerImageId is accurate.
    • Unable to get the header image. sysId: + <value provided> – Make sure the sys_id provided for headerFooterInfo.​headerImageId is accurate.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.
    • <URL> is not listed in whitelisted URL, please check URL whitelisting property : "glide.pdf.url.whitelisting.enabled" and "com.snc.pdf.whitelisted_urls" – If the system property glide.pdf.url.whitelisting.enabled is set to true, the PDF does not process URL content unless it is listed in the Value field of the com.snc.pdf.whitelisted_urls system property. These properties are listed in the System Properties [sys_properties] table.

    Data type: String

    <Object>.request_id Sys_id of the change producer request record.

    Data type: String

    The following example shows how to queue a task that converts HTML to a PDF. The PDF contains header and footer provided via attachment. When the conversion is complete, the PDF named "myPDF" is attached to the target record in the Incident [incident] table.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    
    //  (Option) get HTML from the description field of an incident record
    var gr = new GlideRecord("incident");
    var html;
    
    if (gr.get("<tableSysId>")) {
     html = gr.description.toString();
    }
    
    var hfInfo = new Object();
    hfInfo["HeaderImageAttachmentId"] = "<hdrImgAttSysId>";
    hfInfo["HeaderImageAlignment"] = "left";
    hfInfo["FooterImageAttachmentId"] = "<ftrImgAttSysId>";
    hfInfo["FooterImageAlignment"] = "TOP_CENTER";
    hfInfo["FooterText"] = "Sample Footer Message";
    hfInfo["PageSize"] = "A4";
    hfInfo["GeneratePageNumber"] = "false";
    hfInfo["TopOrBottomMargin"] = "36";
    hfInfo["LeftOrRightMargin"] = "24";
    
    var result = v.convertToPDFWithHeaderFooterAsync(html, "incident", "<targetTbl_sys_id>", "myPDF", hfInfo);
    gs.info(JSON.stringify(result));

    Output:

    {"message":"HTML to PDF Conversion is in progress.","request_id":"<sys_id>"}

    PDFGenerationAPI – fillDocumentFields(Object fieldsMap, String sysId, String tableName, String tableSysId, String pdfName)

    Fills fields in an editable PDF and attaches it to the provided record.

    Use the following methods to determine if the PDF is fillable and get field information:
    PDFGenerationAPI provides additional fill methods with different options:
    Tableau 10. Parameters
    Name Type Description
    fieldsMap Object Optional. Key value map by PDF field name and value to fill. Use the getDocumentFields() method to get the list of available fields.
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    tableName String Name of the table containing the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    tableSysId String Sys_id of the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    Tableau 11. Returns
    Type Description
    Object Object containing sys_id of the updated PDF attachment if successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.​attachment_id If the operation is successful, sys_id of the filled PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.message Message confirming success or error.
    Valid values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to fill fields in an editable PDF.

    var fieldMap = new Object();
    fieldMap["Address"] = "Address value here";
    fieldMap["State"] = "State value here";
    
    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.fillDocumentFields(fieldMap, "<attachmentSysId>", "<tableName>", "<tableSysId>", "pdfName");
    gs.info(JSON.stringify(result));

    Output:

    {"attachment_id":"<sys_id>","message":"Request completed successfully.","status":"success"}

    PDFGenerationAPI – fillDocumentFieldsAndFlatten(Object fieldsMap, String sysId, String tableName, String tableSysId, String pdfName, Object flatten)

    Fills fields in an editable PDF, flattens the data fields, and attaches it to the provided record.

    Use the following methods to determine if the PDF is fillable and get field information:
    PDFGenerationAPI provides additional fill methods with different options:
    Tableau 12. Parameters
    Name Type Description
    fieldsMap Object Optional. Key value map by PDF field name and value to fill. Use the getDocumentFields() method to get the list of available fields.
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    tableName String Name of the table containing the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    tableSysId String Sys_id of the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    flatten Object Optional. Flattening fields enable locking the fields so that other users cannot change the information. Specify the key as "FlattenType" and provide a flattening option as a string.
    Valid values:
    • donot_flatten - Do not flatten any fields.
    • partially_flatten - Flatten only the fields which are modified.
    • fully_flatten - Flattens all the fields.

    Default: fully_flatten

    {
      "FlattenType": "String" 
    }
    Tableau 13. Returns
    Type Description
    Object Object containing sys_id of the updated PDF attachment if successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.​attachment_id If the operation is successful, sys_id of the filled PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.message Message confirming success or error.
    Valid values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to fill fields and flatten an editable PDF.

    var fieldMap = new Object();
    fieldMap["Last Name First Name Middle Initial"] = "Tuter Abel E.";
    fieldMap["Date of Birth"] = "08101952";
    fieldMap["US SSN"] = "111-22-9999";
    fieldMap["Address"] = "PO Box 344";
    fieldMap["City"] = "Jerome";
    fieldMap["State"] = "AZ";
    fieldMap["Zip"] = "86331";
    
    var flatten = new Object();
    flatten["FlattenType"] = "partially_flatten";
    
    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.fillDocumentFieldsAndFlatten(fieldMap, "<attachmentSysId>", "<tableName>", "<tableSysId>", "pdfName", flatten);
    gs.info(JSON.stringify(result));

    Output:

    "attachment_id":"<sys_id>","message":"Request completed successfully.","status":"success"

    PDFGenerationAPI – fillFieldsAndMergeSignature(Object fieldsMap, String sysId, String tableName, String tableSysId, String pdfName, PdfMergeSignRequestor requestor, Object flatten)

    Fills fields in an editable PDF, adds signature image, flattens the data fields, and attaches it to the provided record.

    Use the following methods to determine if the PDF is fillable and get field information:
    PDFGenerationAPI provides additional fill methods with different options:
    Tableau 14. Parameters
    Name Type Description
    fieldsMap Object Optional. Key value map by PDF field name and value to fill. Use the getDocumentFields() method to get the list of available fields.
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    tableName String Name of the table containing the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    tableSysId String Sys_id of the record to which the PDF is attached. You can find this value in the same row as the attachment listed in the Attachments [sys_attachment] table.
    pdfName String Name to give the PDF.

    Default: Sys_id of the PDF in the Attachments [sys_attachment] table.

    requestor PdfMergeSign​Requestor Signature input returned from pdfMergeSignRequestor.
    flatten Object Optional. Flattening fields enable locking the fields so that other users cannot change the information. Specify the key as "FlattenType" and provide a flattening option as a string.
    Valid values:
    • donot_flatten - Do not flatten any fields.
    • partially_flatten - Flatten only the fields which are modified.
    • fully_flatten - Flattens all the fields.

    Default: fully_flatten

    {
      "FlattenType": "String" 
    }
    Tableau 15. Returns
    Type Description
    Object Object containing sys_id of the updated PDF attachment if successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.​attachment_id If the operation is successful, sys_id of the filled PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.message Message confirming success or error.
    Valid values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to fill fields with signature with default settings to completely flatten the fields.

    var fieldMap = new Object();
    fieldMap["Address_Salutation"] = "Address value here";
    
    var paramMap = new Object();
    paramMap["FlattenType"] = "partially_flatten";
    
    var requestor = new sn_pdfgeneratorutils.PdfMergeSignRequestor;
    requestor.createRequest("<attachmentSysId>", "incident", "<tableSysId>", "filledPdf");
    requestor.addSignatureMapping(6, 40, 50, 188, 44, "<signatureSysId>");
    
    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.fillFieldsAndMergeSignature(fieldMap, "<attachmentSysId>", "incident", "<tableSysId>", requestor, "filledPdf", paramMap);
    gs.info(JSON.stringify(result));
    Output:
    {"attachment_id":"5440d993dbed3010d66be1191396194e","message":"Request completed successfully.","status":"success"}

    PDFGenerationAPI – getDocumentFields(String sysId)

    Gets a list of editable fields in a PDF document. Enables listing editable PDF fields without manually opening the file to check.

    Tableau 16. Parameters
    Name Type Description
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    Tableau 17. Returns
    Type Description
    Object Object containing ID of the signed PDF, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.fields If the request is successful, list containing the name of each field in the PDF.

    Data type: Array of strings

    "fields": ["field_name"]
    <Object>.message Message confirming success or error.
    Possible values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to retrieve fields in a PDF attachment.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.getDocumentFields("attachmentSysId");
    gs.info(JSON.stringify(result));
    

    Output:

    {"message":"Request completed successfully.","fields":["NP_formFillable","reset","print","1SSN","Signature.1","5sigDate","Check Box21"],"status":"success"}

    PDFGenerationAPI – getDocumentFieldsType(String sysId)

    Gets the field type of set of editable fields from a PDF document.

    Tableau 18. Parameters
    Name Type Description
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    Tableau 19. Returns
    Type Description
    Object Object containing each PDF field type if successful, error message otherwise.
    {
      "fields_type": {Object},
      "message": "String",
      "status": "String"
    }
    <Object>.fields_type Object listing each field in the specified PDF if successful, error message otherwise.

    Data type: Object

    "fields_type": {
      "<field type>": {Object},
    }
    <Object>.fields_type.​<field> Object containing page number of each field. The <field> name represents the field label, for example, "SSN", or an automated label representing the type.

    Data type: Object

    "<field>": { 
      "fieldsDetails": [Array], // Check boxes, radio buttons, choice boxes only
      "pageNumber": "String",
      "type": "String"
    }
    <Object>.fields_type.​<field>.fieldsDetails List of objects containing field name and corresponding value of each option for choice field types.
    Applicable types:
    • Check box
    • Choice box
    • Combo box
    • Multi select choice box

    Data type: Array

    "fieldsDetails": [ 
      "fieldName": "String",
      "value": "String"
    ]
    <Object>.fields_type.​<field>.fieldsDetails.fieldName Name of a choice field.

    Data type: String

    <Object>.fields_type.​<field>.fieldsDetails.value Value of a choice field.

    Data type: String

    <Object>.fields_type.​<field>.pageNumber PDF page number corresponding to this field.

    Data type: String

    <Object>.fields_type.​<field>.type PDF field type.
    Possible values:
    • check_box
    • choice_box
    • combo_box
    • multi_select_choice_box
    • push_button
    • radio_button
    • signature
    • text

    Data type: String

    <Object>.message Message confirming success or error.
    Possible values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to retrieve field types in a PDF attachment. Results include manual returns for readability and are truncated for brevity.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.getDocumentFieldsType("<attachmentSysId>");
    gs.info(JSON.stringify(result));
    

    Output:

    {"fields_type":{"1ADDLINE2.25":{"pageNumber":2,"type":"text"},"1ADDLINE2.24":{"pageNumber":2,"type":"text"},
    "1ADDLINE2.23":{"pageNumber":2,"type":"text"},"1ADDLINE2.22":{"pageNumber":2,"type":"text"},
    "1ADDLINE2.11":{"pageNumber":2,"type":"text"},
    "Check Box1":{"fieldsDetails":[{"fieldName":"Yes"}],"pageNumber":2,"type":"check_box"},
    "4consentDate.6":{"pageNumber":4,"type":"text"},"4consentDate.7":{"pageNumber":4,"type":"text"},
    "3SSN.9":{"pageNumber":3,"type":"text"},"3SSN.8":{"pageNumber":3,"type":"text"},"3SSN.7":{"pageNumber":3,"type":"text"},
    "pageNumber":2,"type":"check_box"},"Check Box8":{"fieldsDetails":[{"fieldName":"Off"},{"fieldName":"yes"}],
    "4planAdminDate.8":{"pageNumber":4,"type":"text"},"4planAdminDate.7":{"pageNumber":4,"type":"text"},
    "1FirstName_ID.7":{"pageNumber":2,"type":"text"},
    "Check Box9":{"fieldsDetails":[{"fieldName":"Yes"}],"pageNumber":3,"type":"check_box"},
    "1LN.1":{"pageNumber":2,"type":"text"},"1LN.2":{"pageNumber":2,"type":"text"},
    "Check Box11":{"fieldsDetails":[{"fieldName":"Yes"}],"pageNumber":3,"type":"check_box"},
    "1LN.9":{"pageNumber":2,"type":"text"},
    "Check Box17":{"fieldsDetails":[{"fieldName":"Yes"}],"pageNumber":3,"type":"check_box"},
    "Check Box16":{"fieldsDetails":[{"fieldName":"Yes"}],"pageNumber":3,"type":"check_box"},
    "1LN.7":{"pageNumber":2,"type":"text"},"Check Box19":{"fieldsDetails":[{"fieldName":"Yes"}],
    "1LN.8":{"pageNumber":2,"type":"text"},"Check Box18":{"fieldsDetails":[{"fieldName":"Yes"}],
    "print":{"pageNumber":2,"type":"push_button"},"4planAdministrator.1":{"pageNumber":4,"type":"text"},
    "1TaxID.9":{"pageNumber":2,"type":"text"},"4SSN.1":{"pageNumber":3,"type":"text"},"4SSN.2":{"pageNumber":3,"type":"text"},
    "Signature.1":{"pageNumber":4,"type":"text"},"1ZIP.2":{"pageNumber":2,"type":"text"},"1ZIP.3":{"pageNumber":2,"type":"text"},
    "message":"Request completed successfully.","status":"success"}

    PDFGenerationAPI – getFilledDocumentWithSignatureAsBase64(Object fieldsMap, String sysId, PdfMergeSignRequestor requestor, Object flatten)

    Fills fields in an editable PDF, creates an image, and converts it to a Base64-encoded PDF.

    Base64 encoding enables you to output a PDF as a string within a text document, such as HTML or JSON, without damaging the binary character syntax.

    Use the following methods to determine if the PDF is fillable and get field information:
    PDFGenerationAPI provides additional fill methods with different options:
    Tableau 20. Parameters
    Name Type Description
    fieldsMap Object Optional. Key value map by PDF field name and value to fill. Use the getDocumentFields() method to get the list of available fields.
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    requestor PdfMergeSign​Requestor Signature input returned from pdfMergeSignRequestor.
    flatten Object Optional. Flattening fields enable locking the fields so that other users cannot change the information. Specify the key as "FlattenType" and provide a flattening option as a string.
    Valid values:
    • donot_flatten - Do not flatten any fields.
    • partially_flatten - Flatten only the fields which are modified.
    • fully_flatten - Flattens all the fields.

    Default: fully_flatten

    {
      "FlattenType": "String" 
    }
    Tableau 21. Returns
    Type Description
    String If successful, PDF converted to Base64 format is added to the Attachments table [sys_attachment]. Contents reflect the PDF attachment provided with fields and signature filled. The fields are not editable unless an alternative flattening option was provided with the flatten parameter.
    <Object>.message Message confirming success or error.
    Valid values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Given target record [<tableName> - <targetTableSysId>] does not exist. – Target table sys_id is not in the table provided. Make sure you include the correct table name for the record.
    • No Form associated with pdf to fill. attachmentSysId: <sys_id>
    • No editable fields exist with specified names. Please check and try again. field names: <field names>
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to load two fields in a PDF attachment, flatten the fields, and convert the PDF to Base64 format.

    var mymap = new Object();
    mymap["City"] = "City value here";
    mymap["State"] = "XX";
    
    // create a requestor
    var requestor = new sn_pdfgeneratorutils.PdfMergeSignRequestor;
    requestor.createRequest("<sys_id>", "tableName", "<tableSysId>", "pdfName");
    requestor.addSignatureMapping(6, 40, 50, 188, 44, "<signImgSysId>");
    var processedRequestObj = requestor.processRequest();
    
    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    
    var result = v.getFilledDocumentWithSignatureAsBase64(mymap, "<attachmentSysId>", processedRequestObj);
    gs.info (JSON.stringify(result));

    PDFGenerationAPI – getPdfPageSizes(String sysId)

    Gets the page size of a PDF document.

    Tableau 22. Parameters
    Name Type Description
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    Tableau 23. Returns
    Type Description
    Object Object containing the size of each page if successful, error message otherwise.
    {
      "pages_size": {Object},
      "message": "String",
      "status": "String"
    }
    <Object>.pages_size If the operation is successful, width and height of each PDF page in points. The page number is returned as a string and the measurement values are returned as number data types.

    Data type: Object

    "pages_size": {"<page number>":[<width>,<height>]}
    <Object>.message Message confirming success or error.
    Possible values:
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to display the width and height of each page in a PDF attachment.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.getPdfPageSizes ("<attachmentSysId>");
    gs.info(JSON.stringify(result));
    

    Output:

    {"pages_size":{"1":[612,792],"2":[612,792],"3":[612,792],"4":[612,792],"5":[612,792]},"message":"Request completed successfully.","status":"success"}
    

    PDFGenerationAPI – isDocumentFillable(String sysId)

    Checks if the PDF document contains editable fields.

    Tableau 24. Parameters
    Name Type Description
    sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    Tableau 25. Returns
    Type Description
    Object Object containing the size of each page if successful, error message otherwise.
    {
      "document_editable": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.​document_editable If the operation is successful, flag indicating whether the document is editable.
    Valid values:
    • true: PDF document has editable fields.
    • false: PDF document does not have editable fields.

    Data type: Boolean value provided as a string

    <Object>.message Message confirming success or error.
    Possible values:
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to determine if PDF document fields are editable.

    var v = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = v.isDocumentFillable("<attachmentSysId>");
    gs.info(JSON.stringify(result));
    

    Output:

    {"message":"Request completed successfully.","document_editable":"true","status":"success"}

    PDFGenerationAPI – redact(Object inputJson)

    Applies redaction to a PDF document based on the given rectangle coordinates, search keywords, or both. A redacted copy of the original PDF is generated in the Attachments [sys_attachment] table.

    Remarque :
    • Redaction results might include an unexpected white redacted text block that overwrites text not intended to be redacted. If this event occurs, you can manually select the content for redaction using the highlightedSections property or the PDF Generation Utilities plugin. For more information, see Redact data from documents.
    • This method doesn’t support redaction in PDFs containing JBIG2 images.
    Tableau 26. Parameters
    Name Type Description
    inputJson Object Identifies the PDF and its content to be redacted.
    {
      "sysId": "String",
      "highlightedSections": [Array],
      "searchedKeywords": [Array]
    }
    inputJson.sysId String Sys_id of a PDF in the Attachments [sys_attachment] table.
    inputJson. highlightedSections Array of Objects List of rectangles coordinates provided as an object. Each coordinate represents the location of the content to be redacted on each page.
    Optional if including the searchedKeywords property.
    [
       {
         "pageNumber": Number,
         "x": Number,
         "y": Number,
         "width": Number,
         "height": Number
       }
    ]
    inputJson. highlightedSections. pageNumber Number PDF page number containing the content to select for redaction.
    inputJson. highlightedSections. x Number The X-axis (horizontal position) of the redaction rectangle on the PDF in points. The value at the bottom-left corner of the PDF page is 0. For example, a value of 306 places the rectangle approximately in the horizontal center of a letter-size PDF page.
    inputJson. highlightedSections. y Number The Y-axis (vertical position) of the redaction rectangle on the PDF in points. The value at the bottom-left corner of the PDF page is 0. For example, a value of 396 places the rectangle approximately in the vertical center of a letter-size PDF page.
    inputJson. highlightedSections. width Number Width of the redaction rectangle is in points. This value increases the size of the rectangle horizontally from the lower left point at which the x an y axes intersect.
    inputJson. highlightedSections. height Number Height of the redaction rectangle in points. This value increases the size of the rectangle vertically from the lower left point at which the x an y axes intersect.
    inputJson. searchedKeywords Array List of one or more strings used to find text for redaction. The redaction rectangle size matches the height and width of the text that is blocked out as a result.
    Optional if including the highlightedSections property.
    Remarque :
    In some cases, text strings containing special characters or punctuation such as "items:" and "PDF." aren't redacted. You can alternatively remove the character from the string or highlight the area to remove the text.
    Tableau 27. Returns
    Type Description
    Object Object containing sys_id of the updated PDF attachment if successful, error message otherwise.
    {
      "attachment_id": "String",
      "message": "String",
      "status": "String"
    }
    <Object>.​attachment_id If the operation is successful, sys_id of the filled PDF. The file is listed in the Attachments [sys_attachment] table.

    Data type: String

    <Object>.message Message confirming success or error.
    Possible values:
    • Can't parse this format – Unable to process an image embedded in the PDF. The PDF contains one or more images in an unsupported format, such as a JBIG2 image.
    • Exception while reading Source document contents. PDF header not found. – Input attachment provided is not a valid PDF. Provide the correct attachment sys_id.
    • Request cannot proceed as the attachment with sys_id [{0}] did not pass security scan – The PDF did not pass the antivirus scan.
    • Request cannot proceed as the attachment with sys_id [{0}] is pending security scan – The PDF requires an antivirus scan.
    • Request completed successfully – Operation is successful.
    • Undefined – Sys_id provided does not exist or is not a PDF attachment.

    Data type: String

    <Object>.status Status indicating whether the operation is successful.
    Possible values:
    • success - Operation was successful.
    • failure – Operation was not successful. The message provides details.

    Data type: String

    The following example shows how to redact by rectangle and key word. On the redacted PDF, the areas selected on page 2 are blocked out. The string '23' is redacted on any page that it's found on.

    var pdfRequest = {
      sysId: 'e4b3ae35fc128210f877789781ea59f3',
      highlightedSections: [
        {
          "pageNumber": 2,
          "x": 261.75,
          "y": 480,
          "width": 21,
          "height": 14.25
        },
        {
          "pageNumber": 2,
          "x": 249,
          "y": 390.75,
          "width": 63.75,
          "height": 15.75
        }
        // Add more coordinates as needed
      ],
      searchedKeywords: ['23']
    };
    
    // Convert the JSON object to a string
    var jsonRequest = JSON.stringify(pdfRequest);
    gs.info('JSON Request: ' + jsonRequest + '\n');
    
    var PDFRedaction = new sn_pdfgeneratorutils.PDFGenerationAPI;
    var result = PDFRedaction.redact(jsonRequest);
    gs.info(JSON.stringify(result));

    Output:

    JSON Request: {"sysId":"e4b3ae35fc128210f877789781ea59f3","highlightedSections":[{"pageNumber":2,"x":261.75,"y":480,"width":21,"height":14.25},{"pageNumber":2,"x":249,"y":390.75,"width":63.75,"height":15.75}],"searchedKeywords":[23]}
    
    {"attachment_id":"1744ae35fc128210f877789781ea59fc","message":"Request completed successfully.","status":"success"}