Overview
The Hybrid Viewing and PDF Viewing Package creation features reduce the overall server usage by enabling document rendering in the Viewer and the creation of much smaller viewing packages.
You can also use PDF Viewing Packages with the Legacy (SVG based) viewer, taking advantage of faster document viewing and the ability to keep markup intact with your documents after PrizmDoc or host system upgrades.
To take advantage of these features, PAS needs to be configured with a Metered License, Offline Metered License or OEM License (you can use the same license to configure both PrizmDoc Server and PAS). If you do not want to use these features, you do not need to install a license key in PAS. For more information on how to set up the license in the PAS configuration, see PAS Licensing, or see below.
NOTE: If you want to evaluate Hybrid Viewing, contact info@accusoft.com.
Requirements & Considerations
- 
You are required to use Metered Licensing, Offline Metered Licensing or OEM Licensing with PAS to enable the creation of PDF-only Viewing Packages and view them client-side using the Hybrid Viewing feature. A database is required for PAS. 
- 
If you want to create the original, full Viewing Packages and view them with SVG viewing, then you do not need a license for PAS. 
- 
If you are using the Hybrid Viewing feature and enabling a Content Security Policy, you will need to add the worker-src blob:parameter to theContent-Security-Policytag.
Get Started with PAS Licensing & PDF Viewing Package Creation
Step 1: Set up the License
NOTE: A Metered License, Offline Metered License or OEM License is required for this feature.
- Edit your pas.win.yml/pas.nix.yml
- 
Set the License Key and Solution Name: license.key: YOUR_LICENSE_KEY license.solutionName: YOUR_SOLUTION_NAME
Step 2: Set up a Database
- Use the PAS Configuring a Database page to configure a connection to your database.
- 
Once you have set up the database, you should have something similar in your PAS config file as shown below: NOTE: The example below is for a MySQL database. Your code may look slightly different if you are using an SQL Server database. database.adapter: mysql database.connectionString: "mysql://dbUser:dbPassword@host.docker.internal:3306/dbName"
- 
Edit your pas.win.yml/pas.nix.yml
- 
Enable the Viewing Package feature by adding a line in the config: feature.viewingPackages: "enabled"
- 
If you wish to manually generate the necessary tables in the database, use the Run Database Scripts topic. Otherwise, this is done automatically at startup if the database is configured correctly. 
- Your PAS is now ready to create Viewing Packages. The following steps will help you verify that everything is functioning properly.
Step 3: Verify that everything works by creating a Viewing Session from a Viewing Package
- 
Create a PDF Viewing Package from the viewingPackageCreatorsendpoint in PAS. Note thepackageTypeofpdfis how you indicate to PAS that you want a PDF Viewing Package.Example Request POST http://localhost:3000/v2/viewingPackageCreators Content-Type: application/json { "input": { "source": { "type": "document", "fileName": "PdfDemoSample.pdf", "documentId": "test-id-1", "packageType": "pdf" }, "viewingPackageLifetime": 2592000 } }Example Response 200 OK Content-Type: application/json { "input": { "source": { "documentId": "test-id-1", "type": "document", "packageType": "pdf", "fileName": "PdfDemoSample.pdf" }, "viewingPackageLifetime": 2592000 }, "expirationDateTime": "2022-11-14T20:39:31.000Z", "processId": "YOxF4JFiuaXjfsfNKga1iw", "state": "queued", "percentComplete": 0 }
- 
Wait for the viewing package creation to be complete by checking the percentCompletein the response toGET /v2/viewingPackageCreators.Example Request GET http://localhost:3000/v2/viewingPackageCreators/<your-process-id>Example Response 200 OK Content-Type: application/json { "input": { "source": { "documentId": "test-id-1", "type": "document", "packageType": "pdf", "fileName": "PdfDemoSample.pdf" }, "viewingPackageLifetime": 2592000 }, "expirationDateTime": "2022-11-14T20:40:28.000Z", "processId": "YOxF4JFiuaXjfsfNKga1iw", "state": "complete", "percentComplete": 100 }
- 
Now create a Viewing Session using the documentIdfrom the previous step, again setting theallowedClientFileFormatsto['pdf']andpackageTypetopdf.Example Request POST http://localhost:3000/ViewingSession Content-Type: application/json { "source": { "type": "upload", "displayName": "PdfDemoSample.pdf", "documentId": "test-id-1", "packageType": "pdf" }, "allowedClientFileFormats": ["pdf"] }Example Response 200 OK Content-Type: application/json { "viewingSessionId": "ceDKddC6Lx6vYMyzmRhVl0xoDsxHlPHHQQUMsNqs1YeXLiwX-5NNBjmHy0SITQdTbliB8J_y5Inn5BvBG460Sg" }
Next Steps
- To set up a viewer for your viewing session, follow the instructions in Create On-Demand Viewing Packages.
