From cd924489d3a057d7fee92307225733585ea56f38 Mon Sep 17 00:00:00 2001 From: Donny Mellstrom Date: Sat, 6 Oct 2018 20:14:54 -0500 Subject: [PATCH] Accept simple GET requests to generate from URLs --- Dockerfile | 1 + README.md | 8 ++++++ app.py | 71 +++++++++++++++++++++++++++++++++++------------------- 3 files changed, 55 insertions(+), 25 deletions(-) diff --git a/Dockerfile b/Dockerfile index 0a0b057d..4666a0af 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,6 +2,7 @@ FROM openlabs/docker-wkhtmltopdf:latest MAINTAINER Sharoon Thomas # Install dependencies for running web service +RUN apt-get update RUN apt-get install -y python-pip RUN pip install werkzeug executor gunicorn diff --git a/README.md b/README.md index 7bbd483e..571f7f09 100644 --- a/README.md +++ b/README.md @@ -32,6 +32,14 @@ Take a note of the public port number where docker binds to. There are multiple ways to generate a PDF of HTML using the service. +### Generating from a URL + +A GET request may be sent to the server with the source `url` and any desired wkhtmltopdf options set as url parameters. + +```sh +curl "http://:/?url=https://github.com/openlabs/docker-wkhtmltopdf-aas&page-width=210mm&page-height=297mm" -o path/to/output/file.pdf +``` + ### Uploading a HTML file This is a convenient way to use the service from command line diff --git a/app.py b/app.py index 273f15b6..5b893dc9 100644 --- a/app.py +++ b/app.py @@ -10,17 +10,58 @@ from werkzeug.wsgi import wrap_file from werkzeug.wrappers import Request, Response +from werkzeug.urls import url_decode from executor import execute +def generate(url, options): + # Evaluate argument to run with subprocess + args = ['wkhtmltopdf'] + + # Add Global Options + if options: + for option, value in options.items(): + args.append('--%s' % option) + if value: + args.append('"%s"' % value) + + # Create unique output file name + output_filename = tempfile.mktemp() + # Add source file name and output file name + args += [url, output_filename + ".pdf"] + + # Execute the command using executor + execute(' '.join(args)) + + return output_filename + + +def respond(request, file_name): + return Response( + wrap_file(request.environ, open(file_name + '.pdf')), + mimetype='application/pdf', + ) + + @Request.application def application(request): """ - To use this application, the user must send a POST request with - base64 or form encoded encoded HTML content and the wkhtmltopdf Options in - request data, with keys 'base64_html' and 'options'. + To use this application, the user sends a GET request with the parameter + 'url' set to the desired source location and the desired wkhtmltopdf + options also encoded as url-parameters, or a POST request with + base64 or form encoded HTML content and the wkhtmltopdf Options in + request data, with keys 'content' and 'options'. The application will return a response with the PDF file. """ + if request.method == 'GET': + params = url_decode(request.query_string) + url = params.get('url', '') + options = {k: v for k, v in params.items() if k != 'url'} + if not url: + return + file_name = generate(url, options) + return respond(request, file_name) + if request.method != 'POST': return @@ -41,28 +82,8 @@ def application(request): source_file.flush() - # Evaluate argument to run with subprocess - args = ['wkhtmltopdf'] - - # Add Global Options - if options: - for option, value in options.items(): - args.append('--%s' % option) - if value: - args.append('"%s"' % value) - - # Add source file name and output file name - file_name = source_file.name - args += [file_name, file_name + ".pdf"] - - # Execute the command using executor - execute(' '.join(args)) - - return Response( - wrap_file(request.environ, open(file_name + '.pdf')), - mimetype='application/pdf', - ) - + file_name = generate(source_file.name, options) + return respond(request, file_name) if __name__ == '__main__': from werkzeug.serving import run_simple