From 100a1b00826c46426a724ec843be61435c7b3318 Mon Sep 17 00:00:00 2001 From: Matthew Kosarek Date: Mon, 15 Jul 2024 11:04:29 -0400 Subject: [PATCH] docs: defining a threat model for Ubuntu Frame --- doc/sphinx/explanation/index.md | 1 + doc/sphinx/explanation/threat-model.md | 13 +++++++++ .../explanation/ubuntu_frame_threat_model.mmd | 29 +++++++++++++++++++ 3 files changed, 43 insertions(+) create mode 100644 doc/sphinx/explanation/threat-model.md create mode 100644 doc/sphinx/explanation/ubuntu_frame_threat_model.mmd diff --git a/doc/sphinx/explanation/index.md b/doc/sphinx/explanation/index.md index 98d4ba8f8b8..022fc9e72c6 100644 --- a/doc/sphinx/explanation/index.md +++ b/doc/sphinx/explanation/index.md @@ -4,6 +4,7 @@ These pages provide additional detail about a number of aspects related to using - [Architecture](architecture): an overview of Mir's architecture for contributors - [Libraries](libraries): an overview of Mir's libraries and how they depend on one another - [Graphics support](mir-graphics-support): what's required to run Mir compositors +- [Threat Model](threat-model): defining a security threat model for Mir - [What is Wayland anyway?](ok-so-what-is-this-wayland-thing-anyway): so what is it? - [Windowing paradigms](window-positions-under-wayland): how are windows managed? - [Component reports](component_reports): information on Mir's debug and performance reporting infrastructure diff --git a/doc/sphinx/explanation/threat-model.md b/doc/sphinx/explanation/threat-model.md new file mode 100644 index 00000000000..c270f0b0955 --- /dev/null +++ b/doc/sphinx/explanation/threat-model.md @@ -0,0 +1,13 @@ +# Threat Model +Mir is a C++ library for building compositors, not a product itself. As such, +when discussing the threat model for Mir, it is useful to discuss it in terms +of an actual product that is built on Mir. With this in mind, we will define +the threat model of **Ubuntu Frame** in this document. + +## Ubuntu Frame Threat Model Diagram +Ubuntu Frame is published as a snap. As such, the threat model for frame assumes +that the snap is secure, and proceeds to outline the frame snap's interactions +with the outside world. + +```{mermaid} ubuntu_frame_threat_model.mmd +``` diff --git a/doc/sphinx/explanation/ubuntu_frame_threat_model.mmd b/doc/sphinx/explanation/ubuntu_frame_threat_model.mmd new file mode 100644 index 00000000000..7ed94f82e15 --- /dev/null +++ b/doc/sphinx/explanation/ubuntu_frame_threat_model.mmd @@ -0,0 +1,29 @@ +%%{ init: { 'flowchart': { 'curve': 'monotoneY' } } }%% +flowchart + shell((Mir-based Shell)) + vnc_server(VNC Server) + vnc_client(VNC Client) + osk(On-screen Keyboard) + snapd(Snapd) + operator_app(Operator App) + user(User) + display(Display) + + subgraph snap [Snap] + vnc_server--input-->shell + shell--screen content-->vnc_server + + shell--content-->osk + osk--input-->shell + end + + shell--contents/configuration--->display + snapd--configuration-->shell + display--visuals-->user + operator_app--help message-->shell + user--io events-->shell + display--properties-->shell + vnc_server<--vnc-->vnc_client + + classDef boundary fill:none,stroke-dasharray: 5 5 + snap:::boundary \ No newline at end of file