From 51a6cd0d949caf7fc5c37bfd53c2b37d36ffd0e0 Mon Sep 17 00:00:00 2001 From: Nathaniel Case Date: Mon, 13 Jul 2020 16:23:05 -0400 Subject: [PATCH] Quick send_file method. Maybe it works? --- plugins/connection/httpapi.py | 40 +++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/plugins/connection/httpapi.py b/plugins/connection/httpapi.py index 6750a70f3..84b854b0d 100644 --- a/plugins/connection/httpapi.py +++ b/plugins/connection/httpapi.py @@ -169,6 +169,7 @@ - name: ansible_persistent_log_messages """ +import os from io import BytesIO from ansible.errors import AnsibleConnectionFailure @@ -337,6 +338,45 @@ def send(self, path, data, **kwargs): return response, response_buffer + def send_file(self, path, filename, chunk_size=-1, retries=0, **kwargs): + start = 0 + tries = 0 + total_size = os.stat(filename).st_size + with open(filename, "rb") as fileobj: + while True: + if retries > tries: + raise ConnectionError( + "Failed to upload file too many times." + ) + + file_slice = fileobj.read(chunk_size) + if not file_slice: + break + + slice_size = len(file_slice) + end = start + slice_size + headers = { + "Content-Range": "{0}-{1}/{2}".format( + start, end - 1, total_size + ), + "Content-Type": kwargs.pop( + "Content-Type", "application/octet-stream" + ), + } + try: + response, response_data = self.send( + path, file_slice, headers=headers, **kwargs + ) + except HTTPError: + # Try that again + start = 0 + fileobj.seek(0) + tries += 1 + continue + start = end + + return True + def transport_test(self, connect_timeout): """This method enables wait_for_connection to work.