Blog post

Custom Data for PDF Annotations

Illustration: Custom Data for PDF Annotations

Our PSPDFKit SDKs make it easy to create annotations, both programmatically and via a convenient user interface. Annotations can be stored in a PDF, but many of our partners have existing setups and prefer to store user annotations in their own databases. We fully support this and offer XFDF and Instant JSON for exporting data in a standardized format.

Up until now, we recommended that users use the UUID assigned to a new annotation as a key and store custom data in their own database, keyed by this UUID. This works, but it’s tedious, as a separate database entry needs to be maintained whenever an annotation is created or deleted. In turn, this can lead to issues when the synchronization isn’t always correct.

With our new custom annotation data feature, we offer a space to store annotation user data directly in the annotation object, and we’ll ensure things are properly serialized and stored — be it in the PDF, XFDF, Instant JSON, or even the native platform serialization, like NSCoder on iOS. As a developer, you can use the customData property and store in it any data that is allowed in a JSON.

Industry Example

Currently, we’re working with a popular provider of document-signing solutions. This company is rewriting its web document editor and using our Web SDK for the new release. Marking the places where a document should be signed happens via creating form fields, which are just another subtype of annotations.

As multiple users could be signing a single document, the UI displays a dropdown where the person to sign should be selected. This userId field is stored as custom annotation data. Once all signature elements are placed, an Instant JSON file that contains all fields, the necessary annotation data, and custom additions (such as the aforementioned userId) is generated. This simplifies the setup, as there’s no code needed to wrap or extend the JSON created by PSPDFKit — leading to an ultimately faster and less buggy signing experience.

To illustrate this, here’s a simple code example of how customData can be used:

const updatedAnnotation = annotation.set("customData", {
  userId: getCurrentUserId()
});

instance.updateAnnotation(updatedAnnotation);

Version Overview

Custom annotation data is enabled for the following releases and higher:

Conclusion

With the new custom annotation data feature, it’s easier than ever to store additional annotation data, making integration both faster and simpler.

Explore related topics

Free trial Ready to get started?
Free trial