diff options
author | 2016-11-03 13:40:24 +0700 | |
---|---|---|
committer | 2016-11-07 12:07:09 +0700 | |
commit | 6605861481c7156064c4b293e65fa74e1adab7f5 (patch) | |
tree | 54d34835cef407b4105282d516762ae9495ed23d /scripts/automation/trex_control_plane/stl/services/scapy_server | |
parent | 3e48c0b5d1b21554eea8d12bc66175a9157a6951 (diff) |
scapy_service: payload generator upper limit and null check
Signed-off-by: Anton Kiselev <anton.kisel@gmail.com>
Diffstat (limited to 'scripts/automation/trex_control_plane/stl/services/scapy_server')
-rwxr-xr-x | scripts/automation/trex_control_plane/stl/services/scapy_server/scapy_service.py | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/scripts/automation/trex_control_plane/stl/services/scapy_server/scapy_service.py b/scripts/automation/trex_control_plane/stl/services/scapy_server/scapy_service.py index 80e2fc99..5a31410a 100755 --- a/scripts/automation/trex_control_plane/stl/services/scapy_server/scapy_service.py +++ b/scripts/automation/trex_control_plane/stl/services/scapy_server/scapy_service.py @@ -315,18 +315,21 @@ def generate_bytes(bytes_definition): # {generate: template, template_base64: '<base64str>', size: <size_bytes>} # {generate: template_code, template_text_code: '<template_code_str>', size: <size_bytes>} gen_type = bytes_definition.get('generate') - bytes_size = bytes_definition.get('size') - seed = bytes_definition.get('seed') or 12345 - if gen_type == 'random_bytes': - return generate_random_bytes(bytes_size, seed, 0, 0xFF) - elif gen_type == 'random_ascii': - return generate_random_bytes(bytes_size, seed, 0x20, 0x7E) - elif gen_type == 'template': - return generate_bytes_from_template(bytes_size, b64_to_bytes(bytes_definition["template_base64"])) - elif gen_type == 'template_code': - return generate_bytes_from_template(bytes_size, bytes_definition["template_code"]) - elif gen_type == None: + if gen_type == None: return b64_to_bytes(bytes_definition['base64']) + else: + bytes_size = int(bytes_definition['size']) # required + seed = int(bytes_definition.get('seed') or 12345) # optional + if (bytes_size > (1<<20)): # 1Mb ought to be enough for anybody + raise ValueError('size is too large') + if gen_type == 'random_bytes': + return generate_random_bytes(bytes_size, seed, 0, 0xFF) + elif gen_type == 'random_ascii': + return generate_random_bytes(bytes_size, seed, 0x20, 0x7E) + elif gen_type == 'template': + return generate_bytes_from_template(bytes_size, b64_to_bytes(bytes_definition["template_base64"])) + elif gen_type == 'template_code': + return generate_bytes_from_template(bytes_size, bytes_definition["template_code"]) class ScapyException(Exception): pass |