All notable changes to this project will be documented in this file.
Warning: Features marked as experimental may change or be removed in a future release without notice. Use with caution.
- Fix crash using the default
LCPDialogViewController
with CocoaPods.
- Support for Swift Package Manager (contributed by @stevenzeck).
- All APIs deprecated in previous versions are now unavailable.
- We removed the dependency to the private
R2LCPClient.framework
, which means:- Now
r2-lcp-swift
works as a Carthage dependency, no need to use a submodule anymore. - You do not need to modify
r2-lcp-swift
'sCartfile
anymore to add the privateliblcp
dependency. - However, you must provide a facade to
LCPService
(see README for an example implementation).
- Now
- The Renew Loan API got revamped to better support renewal through a web page.
- You will need to implement
LCPRenewDelegate
to coordinate the UX interaction. - Readium ships with a default implementation
LCPDefaultRenewDelegate
to handle web page renewal withSFSafariViewController
.
- You will need to implement
- Fixed really slow opening of large PDF documents.
- Upgraded shared dependencies.
- LCP implementation of the Content Protection API to work with the new Streamer API.
- It is highly recommended that you upgrade to the new
Streamer
API to open publications, which will simplify DRM unlocking.
- It is highly recommended that you upgrade to the new
- Two default implementations of
LCPAuthenticating
:LCPDialogAuthentication
to prompt the user for its passphrase with the official LCP dialog.LCPPassphraseAuthentication
to provide directly a passphrase, pulled for example from a database or a web service.
LCPService.acquirePublication()
is a new API to acquire a publication from a standalone license. Compared to the formerimportPublication()
:- It doesn't require the passphrase, to allow bulk imports.
- It can be cancelled by calling
cancel()
on the returnedLCPAcquisition
object.
LCPService.isLCPProtected()
provides a way to check if a file is protected with LCP.
LCPAuthenticating
is now provided with more information and you will need to update your implementation.
- Support for PDF and Readium Audiobooks protected with LCP.
LCPAuthenticating
can now return hashed passphrases in addition to clear ones. This can be used by reading apps fetching hashed passphrases from a web service or Authentication for OPDS, for example.- Provided
LCPAuthenticating
instances are now retained by the LCP service. Therefore, you can provide one without keeping a reference around in your own code.