Self-encrypt html markdown reports using sodium. The goal is to provide functionality to password protect markdown html documents and share them with others securely. The code needed to decrypt the file is bundled into the exported html file, which makes the resulting file fully self contained.
** EXPERIMENTAL **
remotes::install_github("dirkschumacher/encryptedRmd")
library(encryptedRmd)
encrypt_html_file("devel/example/test.html", output_path = "docs/test.encrypted.html")
#> The key to your file is: 70ca2dbb8f44908bdd12fe20df4b4cce36fb44cc0b482d96cd9704312ee7cb3b
#> Your file has been encrypted and saved at docs/test.encrypted.html
You can take a look at the exported file here and use the key printed above to decrypt it.
---
title: "test"
output: encryptedRmd::encrypted_html_document
---
See here for an example. After knitting, the document is encrypted with a random key and the file is stored in the same directory together with the key.
Inspired and based on the work by @derhuerst on self encrypting html pages.
In devel/r-encrypted-html-template
the code to generate the javascript
file is contained. In order to update the template, you have to run the
following:
- In
devel/r-encrypted-html-template
runnpm run build
. This creates a new version of the template and copies it todevel/html-template.js
. It also creates a file calledJSLICENSES.txt
that contains all licenses of used node packages. - In
devel
runcombine.R
. This generates the file report template and copies it toinst/html-template.html
. This template is then used within the R package to generate encrypted html files.