This project shows you how to use Microsoft's Graph for OpenXML (docx/pptx/xlsx) to PDF conversion from Java.
(Similar code would work to convert doc or rtf to docx, or for binary .ppt or .xls to pdf etc)
Different combinations of libraries can be used to do this, and the purpose of this project is to make it easier for you to assess your options.
The dimensions include:
- whether to use the Graph SDK or not, and if so, whether to use the high- or low-level API
- if you choose not to use the Graph SDK:
- choice of authentication library (MSAL4J, or scribe)
- choice of http library (scribe offers this, and we can use with MSAL4J as well)
Each permutation is in its own module (aka sub-project), and available in Maven Central, https://search.maven.org/search?q=graph-convert Choose ONE of:
<dependency>
<groupId>org.plutext.graph-convert</groupId>
<artifactId>using-graph-sdk</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>org.plutext.graph-convert</groupId>
<artifactId>using-graph-sdk-core-only</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>org.plutext.graph-convert</groupId>
<artifactId>without-graph-sdk-using-msal4j</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>org.plutext.graph-convert</groupId>
<artifactId>without-graph-sdk-using-scribe</artifactId>
<version>1.0.3</version>
</dependency>
Which module works best for you may depend on:
- whether you are already using and familiar with a particular http library: the without-graph-sdk modules allow you to choose between the http libraries supported by scribe. Note that the default - JDKHttpClient - is not actually async. As an example, without-graph-sdk-using-msal4j is setup to use scribejava-httpclient-apache
- whether you need to handle docx files larger than 4MB
- whether you want to minimise the size of the dependencies (see the dependency trees at dependency-trees.txt)
- your sensibilities (using-graph-sdk is the most obscure, but supports big (4MB) files
Whichever you choose, you can look at the graph-convert-sample module; just specify your chosen module in the pom there.
(Copy the pom and Java source code from this module into your IDE as a new project)
Before you start, you'll need to set some stuff up in Microsoft's cloud. I followed https://medium.com/medialesson/convert-files-to-pdf-using-microsoft-graph-azure-functions-20bc84d2adc4 but the following may also help:
- https://docs.microsoft.com/en-us/graph/tutorials/java
- https://docs.microsoft.com/en-us/graph/auth-register-app-v2
- https://devzigma.com/java/upload-files-to-sharepoint-using-java/
This info you then setup in the graph-convert-sample module's AuthConfigImpl.
Once you've done that, you can run https://github.com/plutext/java-docx-to-pdf-using-Microsoft-Graph/blob/master/graph-convert-sample/src/main/java/samples/ConvertDocxToPdfExample.java. You'll need to specify a docx file of course.
Notes/caveats:
- Refreshing a token which is nearing expiry is a TODO.
- There is a 4MB upload limit. This is currently only circumvented in the using-graph-sdk sub-project (though it ought to be possible to do in some of the other modules; PR welcome)
- For doc/docx, there doesn't seem to be a way to update a TOC (either page numbers or entries). Vote for this enhancement at https://microsoftgraph.uservoice.com/forums/920506-microsoft-graph-feature-requests/suggestions/41235295-docx-to-pdf-file-conversion-update-table-of-conte
- Scribe can use a variety of http clients, the default, apache, and OkHttp work. The others (ning, async http client and armeria, need to be configured to follow redirect, and thoe are TODOs)