Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/CyberBattleSim
Path: blob/main/notebooks/randomnetwork.py
597 views
1
# ---
2
# jupyter:
3
# jupytext:
4
# formats: py:percent,ipynb
5
# text_representation:
6
# extension: .py
7
# format_name: percent
8
# format_version: '1.3'
9
# jupytext_version: 1.16.4
10
# kernelspec:
11
# display_name: Python 3 (ipykernel)
12
# language: python
13
# name: python3
14
# ---
15
16
# %% [markdown]
17
# pyright: reportUnusedExpression=false
18
19
# %% [markdown]
20
# Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT License.
21
#
22
# # Randomly generated CyberBattle network environment (experimental)
23
24
# %%
25
import numpy as np
26
import cyberbattle.simulation.model as model
27
import cyberbattle.agents.random_agent as random_agent
28
from typing import List
29
import cyberbattle.simulation.generate_network as g
30
31
# %matplotlib inline
32
33
# %%
34
traffic = g.generate_random_traffic_network(
35
seed=1,
36
n_clients=50,
37
n_servers={
38
"SMB": 15,
39
"HTTP": 15,
40
"RDP": 15,
41
},
42
alpha=np.array([(1, 1), (0.2, 0.5)], dtype=float),
43
beta=np.array([(1000, 10), (10, 100)], dtype=float),
44
)
45
46
# %%
47
network = g.cyberbattle_model_from_traffic_graph(traffic)
48
49
# %%
50
env = model.Environment(network=network, vulnerability_library=dict([]), identifiers=g.ENV_IDENTIFIERS)
51
env.plot_environment_graph()
52
53
# %%
54
network.nodes
55
56
57
# %%
58
def ports_from_vuln(vuln: model.VulnerabilityInfo) -> List[model.PortName]:
59
if isinstance(vuln.outcome, model.LeakedCredentials):
60
return [c.port for c in vuln.outcome.credentials]
61
else:
62
return []
63
64
65
# %%
66
all_existing_ports = (
67
set({port for _, v in env.vulnerability_library.items() for port in ports_from_vuln(v)})
68
.union({port for _, node_info in env.nodes() for _, v in node_info.vulnerabilities.items() for port in ports_from_vuln(v)})
69
.union({service.name for _, node_info in env.nodes() for service in node_info.services})
70
)
71
72
# %%
73
all_existing_ports
74
75
# %%
76
[node_info.services for _, node_info in env.nodes()]
77
78
# %%
79
# import sys, logging
80
# logging.basicConfig(stream=sys.stdout, level=logging.INFO, format="%(levelname)s: %(message)s")
81
import gymnasium as gym
82
import cyberbattle._env.cyberbattle_env as cyberbattle_env
83
84
# %%
85
gym_env = gym.make("CyberBattleRandom-v0").unwrapped
86
87
# %%
88
assert isinstance(gym_env, cyberbattle_env.CyberBattleEnv)
89
90
random_agent.run_random_agent(1, 5600, gym_env)
91
92
# %%
93
94