Skip to content

Latest commit

 

History

History
75 lines (63 loc) · 5.19 KB

README.md

File metadata and controls

75 lines (63 loc) · 5.19 KB

NetSecGameAgents

Agents located in this repository should be use in the Network Security Game environment. They are intented for a navigation and problem solving in the adversarial network-security based environment where they play role of attackers or defenders.

BaseAgent

All future agents should extend BaseAgent - a minimal implementation of agent capable of interaction with he environment. The base agent also implement logging capabilities for the agent via the logging module of python. The logger can be accessed by property logger.

For creating an instance of a BaseAgent, three parameters have to be used:

  1. host:str - URL where the game server runs
  2. port: int - port number where game server runs
  3. role: str - Intended role of the agent. Options are Attacker, Defender, Human

When extending the BaseAgent, these args should be passed to in the constructor by calling: super().__init__(host, port, role)

There are 4 important methods to be used for interaction with the environment:

  1. register(): Should be used ONCE in the beginning of the interaction to register the agent in the game.
    • Uses the class name and role specified in the initialization for the registration in the game
    • returns Observation which contains the status of the registration and the initial GameState if the registration was successful
  2. make_step(Action: action): Used for sending a Action object to be used as a next step of the agent. Returns Observation with new state fo the environment after the action was applied.
  3. request_game_reset(): Used to RESET the state of the environment to its initial position (e.g. at the end of an episode). Returns Observation with state of the environment.
  4. terminate_connection(): Should be used ONCE at the end of the interaction to properly disconnect the agent from the game server.

Examples of agents extending the BaseAgent can be found in:

Agent's types

There are three types of roles an agent can play in NetSecEnv:

  1. Attacker
  2. Defender
  3. Benign

Agents of each type are stored in the corresponding directory within this repository:

├── agents
    ├── attakcers
        ├── concepts_q_learning
        ├── double_q_learning
        ├── gnn_reinforce
        ├── interactive_tui
        ├── ...
    ├── defenders
        ├── random
        ├── probabilistic
    ├── benign
        ├── benign_random

Agent utils

Utility functions in agent_utils.py can be used by any agent to evaluate a GameState, generate set of valid Actions in a GameState etc. Additionally, there are several files with utils functions that can be used by any agents:

Agents' compatibility with the environment

Agent NetSecGame branch Tag Status
BaseAgent main HEAD
Random Attacker main HEAD
InteractiveAgent main HEAD
Q-learning main HEAD
LLM main realease_out_of_the_cage
LLM_QA main realease_out_of_the_cage
GNN_REINFORCE main realease_out_of_the_cage
Random Defender main 👷🏼‍♀️
Probabilistic Defender main 👷🏼‍♀️

Agent utils

Utility functions in agent_utils.py can be used by any agent to evaluate a GameState, generate set of valid Actions in a GameState etc.

About us

This code was developed at the Stratosphere Laboratory at the Czech Technical University in Prague as part of the AIDojo Project.