Skip to content

Commit

Permalink
add convert post
Browse files Browse the repository at this point in the history
  • Loading branch information
mcraa committed Sep 13, 2024
1 parent c6ccff9 commit b76dcff
Show file tree
Hide file tree
Showing 2 changed files with 143 additions and 0 deletions.
143 changes: 143 additions & 0 deletions content/post/2024_09_06_Convert_anything_to_PDF.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
+++
title = 'Convert anything to PDF'
date = 2024-09-06T09:22:43+02:00
draft = false
showonlyimage = true
image = "img/posts/convert_to_pdf.png"
writer = "Peter Makra"
categories = [ "web", "files" ]
weight = 1
tags = [ "docker", "office", "pdf", "convert", "api", "node" ]
+++

<script src="https://www.google.com/recaptcha/api.js"></script>
<script>
function onSubmit() {
if ($('input#captcha-answer').val() == window.buzievagy) {
// todo call api download pdf
console.log('approved')
var reader = new FileReader();
reader.onload = event => {
var form = new FormData();
form.append("document", $('#upload-file').prop('files')[0]);
$.ajax({
url: 'https://x-foss-convertopdf.whitetree-d4666f7f.northeurope.azurecontainerapps.io/topdf',
data: form,
cache: false,
contentType: false,
mimeType: "multipart/form-data",
processData: false,
method: 'POST',
type: 'POST',
xhrFields: {
responseType: 'blob'
},
success: function(blob, status, xhr) {
var filename = "converted.pdf";


var URL = window.URL || window.webkitURL;
var downloadUrl = URL.createObjectURL(blob);
// use HTML5 a[download] attribute to specify filename
var a = document.createElement("a");
// safari doesn't support this yet
if (typeof a.download === 'undefined') {
window.location.href = downloadUrl;
} else {
a.href = downloadUrl;
a.download = filename;
document.body.appendChild(a);
a.click();
}

setTimeout(function () { URL.revokeObjectURL(downloadUrl); }, 100); // cleanup
}
})
}
reader.readAsText($('#upload-file').prop('files')[0]);
}
}
document.addEventListener("DOMContentLoaded", function() {
var numbers = ["zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"]
var operands = ["+", "-", "*"]
var left = Math.floor(Math.random()*10)
var right = Math.floor(Math.random()*10)
var op = operands[Math.floor(Math.random()*3)]
window.buzievagy = eval(`${left} ${op} ${right}`)
$('span#simple-captcha').text(`${numbers[left]} ${op} ${numbers[right]} =`)
});
</script>
<button class="g-recaptcha"
style="display: none"
data-sitekey="6LcZkD0qAAAAAHkQkStv2njGkKuk-aoTWDBK5frg"
data-action='submit'></button>

### Try it out
<div style="background: #d6d5d4; padding: 10px; margin: 5px; box-shadow: 2px 2px 2px gray; border-radius: 3px; font-weight: bold">
<form id="demo-form">
<ol>
<li>
Choose a file <input id="upload-file" type="file">
</li>
<li>
<span>Enter the result of the calculation with numbers before clicking convert.</span>
<br />
<span id="simple-captcha"></span>
<input style="padding: 0; min-height: 5px; width: 50px; line-height: 1" id="captcha-answer" type="text">
</li>
<li>
<span>Click convert -></span>
<input style="padding: 0" id="send-file" type="button" value="Convert" onclick="onSubmit()"/>
</li>
<li>
<span>Get your pdf</span>
</li>
<li>
<span>Be happy :)</span>
</li>
</ol>
</form>
</div>

> Be aware that the deployed demo instance is with minimal resources.
If it does not work it may be maxxed out, or scaled to zero.
In the second case after few seconds it should work again.
In the first.. well stop ddosing pls.


### tl;dr for the curious ones
Resources:
- <a href="https://github.com/mcraa/libre-to-pdf-node" class="github" target="_blank">
<i class="fab fa-github" title="github"></i>
<span class="screen-reader-text">github logo</span>
mcraa/libre-to-pdf-node</a>
- <a href="https://hub.docker.com/r/mcraa/libre-to-pdf-node" class="github" target="_blank">
<i class="fab fa-docker" title="docker"></i>
<span class="screen-reader-text">docker logo</span>
docker pull mcraa/libre-to-pdf-node</a>
- special thanks to [Libre office](https://www.libreoffice.org/) as most of the work is done by them.
- as well as to the creator of the node<i class="fab fa-node-js" title="nodejs"></i> lib used [<i class="fab fa-npm" title="npm"></i> office-to-pdf](https://www.npmjs.com/package/office-to-pdf?activeTab=readme)

#### So what is added here?

Simple web server created with one endpoint making that CLI command happening.
So you can use it with one click.

[![Deploy to Azure](https://aka.ms/deploytoazurebutton)](https://portal.azure.com/#create/Microsoft.Template/uri/https%3A%2F%2Fgist.githubusercontent.com%2Fmcraa%2Ffc199581ecee2ccdb69699d5b66f70d4%2Fraw%2Fe6c87b7485404bdf84230b8b84ca1e7474b94e07%2Farmtemplate-container-pdfconverter.json)

Or one `docker run`.
Or simply adding it to a kubernetes cluster.
You choose your cup of tea.

#### Background story

Recently a client who handles documents with sensitive data on their web application
wanted to have previews online of all the files uploaded.
My colleague quickly realized converting to PDF is the way to go,
but all solutions he quickly found were sending the file to an unknown thirdparty blackbox.
Which was not acceptable of course.

Luckily a very similar problem existed years ago (just check the commit date in the repo).
Search on docker hub improved since then, while writing this I found a similar solution 4 years older.

So we added a container to the clients cluster, the files never leave our solution, and all files can have preview now as the browser handles pdf easily.
Binary file added static/img/posts/convert_to_pdf.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit b76dcff

Please sign in to comment.