Unsupported private APIs

Nutrient Android SDK ships with a stable and well-documented public API, which provides access to all the features Nutrient supports. Our framework’s private APIs sit behind these public APIs. Private APIs are not designed for public use and should not be directly accessed by your application code. This article explains what private APIs are and how you can prevent issues that might arise from using them.

What are private APIs?

Private APIs are classes, methods, and fields that are not intended to be accessed directly by framework customers. Private APIs can be easily identified, since their classes are located inside the com.pspdfkit.framework Java package.

Furthermore, most private APIs are minified using Android’s R8. Minified classes and methods are smaller and faster than non-optimized classes, and they have intentionally obscured names like a, ab, and so on, which should signal that that they are not meant for public use. However, some meant-to-be-private classes can’t be obfuscated for technical reasons (e.g. Nutrient’s View subclasses, which are referenced inside layout files using their names) and are therefore visible inside Android Studio.

Use of private APIs is not prevented by the compiler or IDE but will quickly lead to problems in your app because:

  • We don’t provide any guarantees about API stability for non-documented, private APIs. These methods might break without notice, both in structure and behavior.

  • We don’t provide binary compatibility of minified classes. Our build process will yield different symbol names with every version.

  • There is no public documentation for private APIs.

  • We are considering preventing the use of private APIs altogether with future versions of Nutrient (similar to Android’s restrictions on private APIs).

Information

We can’t give technical support for issues that might arise due to the use of private APIs. If you are using private APIs in your code, you should migrate to a suitable public API replacement. If you have troubles with migrating to public APIs, reach out to us on support with your specific use case and problem.

Migration to public APIs

If you are using private APIs in your app, you should start your migration to public API counterparts by first searching our online guides and API reference documentation for public APIs that accommodate your use case. Should you not be able to find a suitable public API replacement, contact our customer support with your specific use case and problem. We will then advise you on suitable public API replacements and migration strategies.