diff options
author | marekpl <marek.pondel@nokia.com> | 2019-08-05 16:17:22 +0200 |
---|---|---|
committer | marekpl <marek.pondel@nokia.com> | 2019-08-06 13:23:04 +0200 |
commit | 1f4b615239b75e2dfe0482555f01771aa8d4dc5a (patch) | |
tree | aa2132fd8f8a73fcebb75e2c8f77bd58d8d682ac /robotframework-onap | |
parent | 3db5715fbfa519dfabb2dab95630b294e7fd2857 (diff) |
send_binary_data_over_ssl keyword added to SocketKeywords.py
send_binary_data_over_ssl keyword added to SocketKeywords.py
Issue-ID: DCAEGEN2-565
Signed-off-by: marekpl <marek.pondel@nokia.com>
Change-Id: Icdb36610a78f955f0ffe0db2ce6e23be9727401d
Diffstat (limited to 'robotframework-onap')
-rw-r--r-- | robotframework-onap/ONAPLibrary/SocketKeywords.py | 34 |
1 files changed, 26 insertions, 8 deletions
diff --git a/robotframework-onap/ONAPLibrary/SocketKeywords.py b/robotframework-onap/ONAPLibrary/SocketKeywords.py index 08a3fc7..2999880 100644 --- a/robotframework-onap/ONAPLibrary/SocketKeywords.py +++ b/robotframework-onap/ONAPLibrary/SocketKeywords.py @@ -1,4 +1,4 @@ -import socket +import socket, ssl from robot.api.deco import keyword @@ -9,10 +9,28 @@ class SocketKeywords(object): super(SocketKeywords, self).__init__() @keyword - def send_binary_data(self, host, port, data): - """ send raw bytes over tcp socket""" - sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) - # Connect to server and send data - sock.connect((host, int(port))) - sock.sendall(bytes(data)) - sock.close() + def send_binary_data(self, host, port, data, ssl_enabled=None, cert_required=None, ca=None, cert=None, key=None): + """ send raw bytes over tcp socket with optional ssl """ + if ssl_enabled: + if cert_required: + context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2) + context.verify_mode = ssl.CERT_REQUIRED + # Load CA cert + context.load_verify_locations(str(ca)) + # Load Client cert and key + context.load_cert_chain(str(cert), str(key)) + else: + context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2) + context.verify_mode = ssl.CERT_OPTIONAL + sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + ssock = context.wrap_socket(sock, server_hostname=str(host)) + # Connect to server over ssl and send data + ssock.connect((str(host), int(port))) + ssock.sendall(bytes(data)) + ssock.close() + else: + sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + # Connect to server and send data + sock.connect((str(host), int(port))) + sock.sendall(bytes(data)) + sock.close() |