From 8f56e754e2983517aaaefa3c1832bdc944c59a15 Mon Sep 17 00:00:00 2001 From: Cory McWilliams Date: Sun, 29 Jan 2017 12:30:02 +0000 Subject: [PATCH] Oh, the webroot mode works well enough for me to use Let's Encrypt for Tilde Friends. git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@3384 ed5197a5-7fde-0310-b194-c3ffbd925b24 --- core/core.js | 9 +++++++++ tools/letsencrypt.sh | 24 ++++++++++++++++++++++++ 2 files changed, 33 insertions(+) create mode 100755 tools/letsencrypt.sh diff --git a/core/core.js b/core/core.js index 1b8ad032e..53bdc7b4f 100644 --- a/core/core.js +++ b/core/core.js @@ -445,6 +445,15 @@ httpd.all("", function(request, response) { return terminal.handler(request, response, match[1], match[2], match[3]); } else if (request.uri == "/robots.txt") { return terminal.handler(request, response, null, null, request.uri); + } else if ((match = /^\/.well-known\/(.*)/.exec(request.uri)) && request.uri.indexOf("..") == -1) { + var data = File.readFile("data/global/.well-known/" + match[1]); + if (data) { + response.writeHead(200, {"Content-Type": "text/plain", "Content-Length": data.length}); + response.end(data); + } else { + response.writeHead(404, {"Content-Type": "text/plain", "Content-Length": "File not found".length}); + response.end("File not found"); + } } else { var data = "File not found."; response.writeHead(404, {"Content-Type": "text/plain; charset=utf-8", "Content-Length": data.length.toString()}); diff --git a/tools/letsencrypt.sh b/tools/letsencrypt.sh new file mode 100755 index 000000000..2b212da73 --- /dev/null +++ b/tools/letsencrypt.sh @@ -0,0 +1,24 @@ +#!/bin/bash + +# --config-dir, --logs-dir, and --work-dir + + +#certbot certonly \ +# --webroot \ +# --webroot-path data/global/ \ +# -d www.tildefriends.net \ +# -d tildefriends.net \ +# --config-dir data/global/letsencrypt/etc \ +# --logs-dir data/global/letsencrypt/logs \ +# --work-dir data/global/letsencrypt/work \ +# --cert-path data/global/httpd/certificate.pem \ +# --key-path data/global/httpd/privatekey.pem \ + +certbot renew \ + --webroot \ + --webroot-path data/global/ \ + --config-dir data/global/letsencrypt/etc \ + --logs-dir data/global/letsencrypt/logs \ + --work-dir data/global/letsencrypt/work \ + --cert-path data/global/httpd/certificate.pem \ + --key-path data/global/httpd/privatekey.pem \