summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--robotframework-onap/ONAPLibrary/SocketKeywords.py34
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()