yawning_titan.envs.generic.core.blue_action_set.BlueActionSet#
- class yawning_titan.envs.generic.core.blue_action_set.BlueActionSet(network_interface)[source]#
- Bases: - object- A class representing a Blue Agents action set. - Initialise a blue agents action set. - Parameters:
- network_interface – Object that allows the class to interact with the network 
- settings_file – Dictionary containing configuration data 
 
 - Methods - Add a deceptive node into the environment. - Do Nothing. - Isolate a node by disabling all of its connections to other nodes. - Make a target node safe. - Enable all of the connections to and from a node. - Reduce the vulnerability of the target node. - Restore a node to its starting state: safe and with its starting vulnerability. - Scan all of the nodes within the environment and attempt to get their states. - reduce_node_vulnerability(node)[source]#
- Reduce the vulnerability of the target node. - Will not reduce the vulnerability past the lower bound setting in the configuration file: - BLUE: node_vulnerability_min 
 - Parameters:
- node – The node to reduce the vulnerability of as an instance of - Node.
- Returns:
- The name of the action taken (“reduce_vulnerability”) and the - Nodethe action was taken on.
 
 - restore_node(node)[source]#
- Restore a node to its starting state: safe and with its starting vulnerability. - Parameters:
- node – the node to restore 
- Returns:
- The name of the action (“restore_node”) The name of the node the action was taken on 
 
 - make_safe_node(node)[source]#
- Make a target node safe. - Can also affect the vulnerability of the node. There are settings that can change how this action works in the configuration file: - BLUE: making_node_safe_modifies_vulnerability 
- BLUE: vulnerability_change 
- BLUE: making_node_safe_gives_random_vulnerability 
 - Parameters:
- action (The name of the) – 
- safe (The name of the node to make) – 
 
 
 - scan_all_nodes()[source]#
- Scan all of the nodes within the environment and attempt to get their states. - The blue agents ability to see intrusions is based on the values in the config file:
- BLUE: chance_to_discover_intrusion_on_scan 
- BLUE: chance_to_discover_intrusion_on_scan_deceptive_node 
 
 - Returns:
- The name of the action (“scan”) The node the action was performed on (None: as scan affects all nodes, not just 1) 
 
 - isolate_node(node)[source]#
- Isolate a node by disabling all of its connections to other nodes. - Parameters:
- node – the node to disable 
- Returns:
- The name of the action (“isolate”) The node affected 
 
 - reconnect_node(node)[source]#
- Enable all of the connections to and from a node. - Parameters:
- node – the node to enable to connections to 
- Returns:
- The name of the action (“connect”) The node affected 
 
 - do_nothing()[source]#
- Do Nothing. - Returns:
- The name of the action (“do_nothing”) The nodes affected (None: as do nothing affects no nodes) 
 
 - add_deceptive_node(edge)[source]#
- Add a deceptive node into the environment. - Deceptive nodes are the same as standard nodes except they have a 100% chance (by default) to be able to detect attacks from the red agent. A deceptive node is added on an edge between two nodes. - Parameters:
- edge – The edge to place the deceptive node on 
- Returns:
- The name of the action performed (“add_deceptive_node” or “do_nothing” depending on if action is valid) A pair of nodes that the deceptive node was placed between (or None if no action performed)