Skip to content

Instantly share code, notes, and snippets.

@jeremyckahn
Last active December 5, 2023 03:24
Show Gist options
  • Save jeremyckahn/25f8aff35d4c0af5323846b87da98335 to your computer and use it in GitHub Desktop.
Save jeremyckahn/25f8aff35d4c0af5323846b87da98335 to your computer and use it in GitHub Desktop.
{
"type": "excalidraw",
"version": 2,
"source": "https://excalidraw.com",
"elements": [
{
"id": "eJf_ZiWYQLX4xuxjywCaG",
"type": "text",
"x": 345,
"y": 163.5,
"width": 280.31964111328125,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1953390518,
"version": 88,
"versionNonce": 816403306,
"isDeleted": false,
"boundElements": [
{
"id": "osF1pVZlWk7e7ybgPZ4g1",
"type": "arrow"
},
{
"id": "QIDDIxhjfG4RVtYmHsa4E",
"type": "arrow"
}
],
"updated": 1701744693630,
"link": null,
"locked": false,
"text": "User navigates to /personal",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "User navigates to /personal",
"lineHeight": 1.25
},
{
"id": "osF1pVZlWk7e7ybgPZ4g1",
"type": "arrow",
"x": 470.3001279161457,
"y": 196.5,
"width": 34.12279419065146,
"height": 99,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 308130602,
"version": 350,
"versionNonce": 545417526,
"isDeleted": false,
"boundElements": null,
"updated": 1701744336999,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
34.12279419065146,
99
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "eJf_ZiWYQLX4xuxjywCaG",
"focus": 0.1506413079485682,
"gap": 8
},
"endBinding": {
"elementId": "TTxYiBmN5x7JekaphaX8x",
"focus": 0.0226264770699342,
"gap": 9.5
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "TTxYiBmN5x7JekaphaX8x",
"type": "text",
"x": 333,
"y": 305,
"width": 349.8995666503906,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1809258230,
"version": 213,
"versionNonce": 1847356714,
"isDeleted": false,
"boundElements": [
{
"id": "osF1pVZlWk7e7ybgPZ4g1",
"type": "arrow"
},
{
"id": "346eKVwL0ZZdFe-wttdKL",
"type": "arrow"
}
],
"updated": 1701744336999,
"link": null,
"locked": false,
"text": "User is prompted to create a room",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "User is prompted to create a room",
"lineHeight": 1.25
},
{
"id": "_fzz15gfm1BsXjC2BJGfX",
"type": "text",
"x": 284,
"y": 456,
"width": 580.4393310546875,
"height": 50,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1028490614,
"version": 192,
"versionNonce": 2077019958,
"isDeleted": false,
"boundElements": [
{
"id": "346eKVwL0ZZdFe-wttdKL",
"type": "arrow"
},
{
"id": "e9XgWofbSXhXXdEH7COc8",
"type": "arrow"
}
],
"updated": 1701744342510,
"link": null,
"locked": false,
"text": "User creates personal room\n - Creates public/private key and stores it in IndexedDB",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 43,
"containerId": null,
"originalText": "User creates personal room\n - Creates public/private key and stores it in IndexedDB",
"lineHeight": 1.25
},
{
"id": "346eKVwL0ZZdFe-wttdKL",
"type": "arrow",
"x": 516.5086564825729,
"y": 340.5,
"width": 10.345823025114669,
"height": 114.5,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 2144808246,
"version": 443,
"versionNonce": 1866864490,
"isDeleted": false,
"boundElements": null,
"updated": 1701744739251,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
10.345823025114669,
114.5
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "TTxYiBmN5x7JekaphaX8x",
"focus": -0.0368054343006254,
"gap": 10.5
},
"endBinding": {
"elementId": "_fzz15gfm1BsXjC2BJGfX",
"focus": -0.1539118397633652,
"gap": 1
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "ppoc8fYPqVrdEHq51WC0d",
"type": "text",
"x": 322.5,
"y": 629.5,
"width": 378.799560546875,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 605519542,
"version": 199,
"versionNonce": 1407261546,
"isDeleted": false,
"boundElements": [
{
"id": "e9XgWofbSXhXXdEH7COc8",
"type": "arrow"
},
{
"id": "Ct3QSXB_ZRCDBPeGZltVn",
"type": "arrow"
},
{
"id": "kflzfAgJKU_pZINi-84lC",
"type": "arrow"
}
],
"updated": 1701744511955,
"link": null,
"locked": false,
"text": "User navigates to /personal/:publicKey",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "User navigates to /personal/:publicKey",
"lineHeight": 1.25
},
{
"id": "e9XgWofbSXhXXdEH7COc8",
"type": "arrow",
"x": 528.6782615318693,
"y": 512.5,
"width": 4.760943849899036,
"height": 116,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 1488438634,
"version": 334,
"versionNonce": 1029273514,
"isDeleted": false,
"boundElements": null,
"updated": 1701744349858,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
4.760943849899036,
116
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "_fzz15gfm1BsXjC2BJGfX",
"focus": 0.1611891471426673,
"gap": 6.5
},
"endBinding": {
"elementId": "ppoc8fYPqVrdEHq51WC0d",
"focus": 0.11633496507855304,
"gap": 1
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "IhT4p-Umz5oYnz_z0Ezy_",
"type": "text",
"x": 236,
"y": 799.5,
"width": 308.0396728515625,
"height": 50,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 121014442,
"version": 83,
"versionNonce": 1394370294,
"isDeleted": false,
"boundElements": [
{
"id": "Ct3QSXB_ZRCDBPeGZltVn",
"type": "arrow"
},
{
"id": "Sb_jWA3lTKwyPYL0p0tha",
"type": "arrow"
},
{
"id": "FEoSlJJnKDwLKXgng-nge",
"type": "arrow"
}
],
"updated": 1701745250754,
"link": null,
"locked": false,
"text": ":publicKey exists in IndexedDB \nalong with private key",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 43,
"containerId": null,
"originalText": ":publicKey exists in IndexedDB \nalong with private key",
"lineHeight": 1.25
},
{
"id": "BcxWTj7Ut6Bnd4gm80qgZ",
"type": "text",
"x": 693.5,
"y": 794,
"width": 383.1595764160156,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 451227126,
"version": 51,
"versionNonce": 1729994102,
"isDeleted": false,
"boundElements": [
{
"id": "kflzfAgJKU_pZINi-84lC",
"type": "arrow"
},
{
"id": "M1GF4o9-e5MsrmqbGenzm",
"type": "arrow"
}
],
"updated": 1701745288834,
"link": null,
"locked": false,
"text": ":publicKey does not exist in IndexedDB",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": ":publicKey does not exist in IndexedDB",
"lineHeight": 1.25
},
{
"id": "Ct3QSXB_ZRCDBPeGZltVn",
"type": "arrow",
"x": 519.4070788996042,
"y": 664.5,
"width": 105.38205706922082,
"height": 130.5,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 700844394,
"version": 138,
"versionNonce": 874226038,
"isDeleted": false,
"boundElements": null,
"updated": 1701745250755,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
-105.38205706922082,
130.5
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "ppoc8fYPqVrdEHq51WC0d",
"focus": -0.0562786562053072,
"gap": 10
},
"endBinding": {
"elementId": "IhT4p-Umz5oYnz_z0Ezy_",
"focus": 0.0010515467782874486,
"gap": 4.5
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "kflzfAgJKU_pZINi-84lC",
"type": "arrow",
"x": 542.6804207286289,
"y": 669,
"width": 337.0419394712412,
"height": 116,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 2030773750,
"version": 72,
"versionNonce": 220280822,
"isDeleted": false,
"boundElements": null,
"updated": 1701745288835,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
337.0419394712412,
116
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "ppoc8fYPqVrdEHq51WC0d",
"focus": 0.16501019454665034,
"gap": 14.5
},
"endBinding": {
"elementId": "BcxWTj7Ut6Bnd4gm80qgZ",
"focus": 0.250600316345669,
"gap": 9
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "x7hbKpCQ15fkZr7WNeoOT",
"type": "text",
"x": 347,
"y": 991.5,
"width": 397.2594909667969,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 540984938,
"version": 158,
"versionNonce": 2119930742,
"isDeleted": false,
"boundElements": [
{
"id": "Sb_jWA3lTKwyPYL0p0tha",
"type": "arrow"
},
{
"id": "-FVnn3giDivfgRCJkYYNp",
"type": "arrow"
}
],
"updated": 1701746310203,
"link": null,
"locked": false,
"text": "Public key validates against private key",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "Public key validates against private key",
"lineHeight": 1.25
},
{
"id": "sg2FawVWqYZkc4MdJY-Cy",
"type": "text",
"x": -155.5,
"y": 938,
"width": 482.3794250488281,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 602808490,
"version": 128,
"versionNonce": 1752388150,
"isDeleted": false,
"boundElements": [
{
"id": "FEoSlJJnKDwLKXgng-nge",
"type": "arrow"
},
{
"id": "QIDDIxhjfG4RVtYmHsa4E",
"type": "arrow"
}
],
"updated": 1701746285161,
"link": null,
"locked": false,
"text": "Public key does not validate against private key",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "Public key does not validate against private key",
"lineHeight": 1.25
},
{
"id": "Sb_jWA3lTKwyPYL0p0tha",
"type": "arrow",
"x": 462.74760214094044,
"y": 857.0000000000001,
"width": 80.0422724231745,
"height": 133.4999999999999,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 2147316394,
"version": 252,
"versionNonce": 1835940854,
"isDeleted": false,
"boundElements": null,
"updated": 1701745250755,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
80.0422724231745,
133.4999999999999
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "IhT4p-Umz5oYnz_z0Ezy_",
"focus": -0.2977733858924808,
"gap": 7.5
},
"endBinding": {
"elementId": "x7hbKpCQ15fkZr7WNeoOT",
"focus": 0.025490883092512732,
"gap": 1
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "FEoSlJJnKDwLKXgng-nge",
"type": "arrow",
"x": 351.89718268860565,
"y": 864,
"width": 213.70249347271292,
"height": 70,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 1801120106,
"version": 99,
"versionNonce": 1721810102,
"isDeleted": false,
"boundElements": null,
"updated": 1701746285162,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
-213.70249347271292,
70
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "IhT4p-Umz5oYnz_z0Ezy_",
"focus": -0.36718859841368373,
"gap": 14.5
},
"endBinding": {
"elementId": "sg2FawVWqYZkc4MdJY-Cy",
"focus": 0.0076328599634305425,
"gap": 4
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "QIDDIxhjfG4RVtYmHsa4E",
"type": "arrow",
"x": 15.697185555699164,
"y": 926.5000000000001,
"width": 473.00000000000006,
"height": 744.7831602096559,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 2094750326,
"version": 399,
"versionNonce": 135509494,
"isDeleted": false,
"boundElements": null,
"updated": 1701746285162,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
-152.10981730580602,
-381.7831602096559
],
[
320.89018269419404,
-744.7831602096559
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "sg2FawVWqYZkc4MdJY-Cy",
"focus": -0.24548268445293137,
"gap": 11.5
},
"endBinding": {
"elementId": "eJf_ZiWYQLX4xuxjywCaG",
"focus": 0.9020473769421605,
"gap": 8.412631750106812
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "fYh8YNlTXwEXddXVZMErC",
"type": "text",
"x": 365.7302253927503,
"y": 1161.6454112189158,
"width": 364.99957275390625,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1473404522,
"version": 125,
"versionNonce": 134047914,
"isDeleted": false,
"boundElements": [
{
"id": "-FVnn3giDivfgRCJkYYNp",
"type": "arrow"
}
],
"updated": 1701746624265,
"link": null,
"locked": false,
"text": "User joins room with host permissions",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "User joins room with host permissions",
"lineHeight": 1.25
},
{
"id": "-FVnn3giDivfgRCJkYYNp",
"type": "arrow",
"x": 546.9507526755199,
"y": 1019.5739826474869,
"width": 17.132026795379716,
"height": 139.5714285714289,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 1888013430,
"version": 221,
"versionNonce": 491177514,
"isDeleted": false,
"boundElements": null,
"updated": 1701746624267,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
17.132026795379716,
139.5714285714289
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "x7hbKpCQ15fkZr7WNeoOT",
"focus": 0.00462105319073888,
"gap": 3.0739826474869005
},
"endBinding": {
"elementId": "fYh8YNlTXwEXddXVZMErC",
"focus": 0.09614509273461279,
"gap": 2.5
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "mC9AYrSoTWGkKgB4wgi9a",
"type": "text",
"x": 924.5873682498932,
"y": 941.7168397903442,
"width": 370.95953369140625,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1576365302,
"version": 87,
"versionNonce": 1600948394,
"isDeleted": false,
"boundElements": [
{
"id": "M1GF4o9-e5MsrmqbGenzm",
"type": "arrow"
},
{
"id": "1BqSZr8HOEfdwsEGK42UE",
"type": "arrow"
}
],
"updated": 1701745092112,
"link": null,
"locked": false,
"text": "Sets internal isHost boolean to false",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "Sets internal isHost boolean to false",
"lineHeight": 1.25
},
{
"id": "M1GF4o9-e5MsrmqbGenzm",
"type": "arrow",
"x": 893.371068060431,
"y": 825.7168397903442,
"width": 225.25673823868135,
"height": 110,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 1684683510,
"version": 80,
"versionNonce": 501232246,
"isDeleted": false,
"boundElements": null,
"updated": 1701745288836,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
225.25673823868135,
110
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "BcxWTj7Ut6Bnd4gm80qgZ",
"focus": 0.13853650141708676,
"gap": 6.716839790344238
},
"endBinding": {
"elementId": "mC9AYrSoTWGkKgB4wgi9a",
"focus": 0.2200369146407422,
"gap": 6
},
"startArrowhead": null,
"endArrowhead": "arrow"
},
{
"id": "rYw-ZZfNoBkizaxVXczSQ",
"type": "text",
"x": 985.0873682498932,
"y": 1105.7168397903442,
"width": 376.35955810546875,
"height": 25,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": null,
"seed": 1330595690,
"version": 90,
"versionNonce": 720543594,
"isDeleted": false,
"boundElements": [
{
"id": "1BqSZr8HOEfdwsEGK42UE",
"type": "arrow"
}
],
"updated": 1701746295130,
"link": null,
"locked": false,
"text": "User joins room with guest permissions",
"fontSize": 20,
"fontFamily": 1,
"textAlign": "left",
"verticalAlign": "top",
"baseline": 18,
"containerId": null,
"originalText": "User joins room with guest permissions",
"lineHeight": 1.25
},
{
"id": "1BqSZr8HOEfdwsEGK42UE",
"type": "arrow",
"x": 1128.3951213614628,
"y": 976.2168397903444,
"width": 68.84689816345735,
"height": 124.49999999999989,
"angle": 0,
"strokeColor": "#1e1e1e",
"backgroundColor": "transparent",
"fillStyle": "solid",
"strokeWidth": 2,
"strokeStyle": "solid",
"roughness": 1,
"opacity": 100,
"groupIds": [],
"frameId": null,
"roundness": {
"type": 2
},
"seed": 708402422,
"version": 156,
"versionNonce": 871189738,
"isDeleted": false,
"boundElements": null,
"updated": 1701746295131,
"link": null,
"locked": false,
"points": [
[
0,
0
],
[
68.84689816345735,
124.49999999999989
]
],
"lastCommittedPoint": null,
"startBinding": {
"elementId": "mC9AYrSoTWGkKgB4wgi9a",
"focus": -0.037653261965490126,
"gap": 9.5
},
"endBinding": {
"elementId": "rYw-ZZfNoBkizaxVXczSQ",
"focus": 0.17249362696242598,
"gap": 5
},
"startArrowhead": null,
"endArrowhead": "arrow"
}
],
"appState": {
"gridSize": null,
"viewBackgroundColor": "#ffffff"
},
"files": {}
}
Display the source blob
Display the rendered blob
Raw
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1536.946926355362 1043.1454112189158" width="3073.893852710724" height="2086.2908224378316" filter="invert(93%) hue-rotate(180deg)">
<!-- svg-source:excalidraw -->
<defs>
<style class="style-fonts">
@font-face {
font-family: "Virgil";
src: url("https://excalidraw.com/Virgil.woff2");
}
@font-face {
font-family: "Cascadia";
src: url("https://excalidraw.com/Cascadia.woff2");
}
@font-face {
font-family: "Assistant";
src: url("https://excalidraw.com/Assistant-Regular.woff2");
}
</style>
</defs>
<rect x="0" y="0" width="1536.946926355362" height="1043.1454112189158" fill="#ffffff"></rect><g transform="translate(510.5 10) rotate(0 140.15982055664062 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User navigates to /personal</text></g><g stroke-linecap="round"><g transform="translate(635.8001279161457 43) rotate(0 17.06139709532573 49.5)"><path d="M-0.71 0.13 C5.02 16.57, 27.84 82.47, 33.49 98.87 M1.12 -0.85 C7.32 15.77, 30.12 83.59, 35.87 100.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(635.8001279161457 43) rotate(0 17.06139709532573 49.5)"><path d="M17.09 76.95 C21.63 81.34, 25.47 86.2, 35.87 100.34 M17.09 76.95 C22.06 83.08, 26.1 88.59, 35.87 100.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(635.8001279161457 43) rotate(0 17.06139709532573 49.5)"><path d="M36.52 70.34 C36.64 76.13, 36.06 82.49, 35.87 100.34 M36.52 70.34 C36.34 78.09, 35.29 85.33, 35.87 100.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(498.5 151.5) rotate(0 174.9497833251953 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User is prompted to create a room</text></g><g transform="translate(449.5 302.5) rotate(0 290.21966552734375 25)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User creates personal room</text><text x="0" y="25" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge"> - Creates public/private key and stores it in IndexedDB</text></g><g stroke-linecap="round"><g transform="translate(682.0086564825729 187) rotate(0 5.172911512557334 57.25)"><path d="M-0.51 0.99 C0.96 20.27, 7.91 95.79, 9.65 114.51 M1.43 0.47 C3.2 20.06, 10.75 97.13, 12 116.06" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(682.0086564825729 187) rotate(0 5.172911512557334 57.25)"><path d="M-0.6 88.83 C5.49 97.86, 8.54 108.45, 12 116.06 M-0.6 88.83 C1.45 94.43, 5 99.64, 12 116.06" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(682.0086564825729 187) rotate(0 5.172911512557334 57.25)"><path d="M19.85 87.1 C18.3 96.69, 13.74 107.92, 12 116.06 M19.85 87.1 C17.8 92.92, 17.24 98.47, 12 116.06" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(488 476) rotate(0 189.3997802734375 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User navigates to /personal/:publicKey</text></g><g stroke-linecap="round"><g transform="translate(694.1782615318693 359) rotate(0 2.380471924949518 58)"><path d="M-0.12 0.66 C0.72 20.04, 3.19 97.48, 3.89 116.77 M-1.64 -0.04 C-0.33 18.96, 5.38 96.01, 6.15 115.05" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(694.1782615318693 359) rotate(0 2.380471924949518 58)"><path d="M-5.77 87.52 C-2.11 91.75, 0.52 97.74, 6.15 115.05 M-5.77 87.52 C-1.25 97.06, 2.76 105.31, 6.15 115.05" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(694.1782615318693 359) rotate(0 2.380471924949518 58)"><path d="M14.71 86.3 C14.16 90.76, 12.59 96.99, 6.15 115.05 M14.71 86.3 C12.43 96.19, 9.65 104.85, 6.15 115.05" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(401.5 646) rotate(0 154.01983642578125 25)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">:publicKey exists in IndexedDB </text><text x="0" y="25" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">along with private key</text></g><g transform="translate(859 640.5) rotate(0 191.5797882080078 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">:publicKey does not exist in IndexedDB</text></g><g stroke-linecap="round"><g transform="translate(684.9070788996042 511) rotate(0 -52.69102853461041 65.25)"><path d="M-0.82 -0.29 C-18.21 21.2, -86.66 108.1, -104.22 129.98 M0.95 -1.49 C-16.5 20.67, -87.11 109.51, -104.56 131.24" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(684.9070788996042 511) rotate(0 -52.69102853461041 65.25)"><path d="M-94.99 102.81 C-98.17 113.41, -101.49 118.82, -104.56 131.24 M-94.99 102.81 C-98.34 112.52, -101.46 121.68, -104.56 131.24" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(684.9070788996042 511) rotate(0 -52.69102853461041 65.25)"><path d="M-78.96 115.61 C-87.17 122.17, -95.42 123.65, -104.56 131.24 M-78.96 115.61 C-87.85 120.95, -96.43 125.75, -104.56 131.24" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(708.1804207286289 515.5) rotate(0 168.5209697356206 58)"><path d="M-0.62 0.27 C55.56 19.39, 281.12 95.65, 337.28 114.9 M1.26 -0.63 C57.27 18.57, 280.79 96.26, 336.46 115.85" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(708.1804207286289 515.5) rotate(0 168.5209697356206 58)"><path d="M306.47 116.24 C316.54 116.68, 323.85 115.07, 336.46 115.85 M306.47 116.24 C315.6 115.73, 322.99 116.78, 336.46 115.85" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(708.1804207286289 515.5) rotate(0 168.5209697356206 58)"><path d="M313.23 96.87 C321.17 103.48, 326.32 108.08, 336.46 115.85 M313.23 96.87 C320.47 101.8, 325.98 108.26, 336.46 115.85" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(512.5 838) rotate(0 198.62974548339844 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">Public key validates against private key</text></g><g transform="translate(10 784.5) rotate(0 241.18971252441406 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">Public key does not validate against private key</text></g><g stroke-linecap="round"><g transform="translate(628.2476021409404 703.5000000000001) rotate(0 40.02113621158725 66.74999999999994)"><path d="M-0.12 0.76 C13.37 22.62, 66.84 110.15, 80.3 132.36 M-1.64 0.11 C11.76 22.59, 65.85 111.32, 79.48 133.3" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(628.2476021409404 703.5000000000001) rotate(0 40.02113621158725 66.74999999999994)"><path d="M55.99 114.65 C63.26 119.72, 65.93 124.88, 79.48 133.3 M55.99 114.65 C63.19 119.99, 72.83 128.16, 79.48 133.3" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(628.2476021409404 703.5000000000001) rotate(0 40.02113621158725 66.74999999999994)"><path d="M73.48 103.91 C76.51 111.63, 74.85 119.46, 79.48 133.3 M73.48 103.91 C74.57 113.14, 78.15 125.03, 79.48 133.3" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(517.3971826886057 710.5) rotate(0 -106.85124673635646 35)"><path d="M-0.74 1.09 C-36.18 12.7, -177.27 59.12, -212.71 70.59 M1.07 0.62 C-34.43 11.78, -177.3 57.02, -213.14 68.77" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(517.3971826886057 710.5) rotate(0 -106.85124673635646 35)"><path d="M-189.44 50.38 C-194.4 57.26, -202.18 61.54, -213.14 68.77 M-189.44 50.38 C-196.51 55.62, -203.69 60.93, -213.14 68.77" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(517.3971826886057 710.5) rotate(0 -106.85124673635646 35)"><path d="M-183.16 69.92 C-190.12 71.05, -199.73 69.61, -213.14 68.77 M-183.16 69.92 C-192.02 69.41, -201.03 69.04, -213.14 68.77" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(181.19718555569915 773.0000000000001) rotate(0 84.39018269419401 -372.39158010482794)"><path d="M0.14 0.34 C-25.11 -63.35, -204.71 -258.02, -151.1 -382.17 C-97.5 -506.32, 242.99 -684.17, 321.74 -744.55 M-1.25 -0.52 C-26.61 -64.05, -205.3 -257.07, -151.52 -380.84 C-97.74 -504.6, 242.52 -682.72, 321.43 -743.11" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(181.19718555569915 773.0000000000001) rotate(0 84.39018269419401 -372.39158010482794)"><path d="M303.26 -719.24 C309.87 -725.53, 314.7 -733.73, 321.43 -743.11 M303.26 -719.24 C308.77 -727.79, 315.35 -733.59, 321.43 -743.11" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(181.19718555569915 773.0000000000001) rotate(0 84.39018269419401 -372.39158010482794)"><path d="M292.16 -736.5 C302.47 -737.06, 310.99 -739.51, 321.43 -743.11 M292.16 -736.5 C301.29 -739.58, 311.41 -739.86, 321.43 -743.11" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(531.2302253927503 1008.1454112189158) rotate(0 182.49978637695312 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User joins room with host permissions</text></g><g stroke-linecap="round"><g transform="translate(712.4507526755199 866.0739826474869) rotate(0 8.566013397689858 69.78571428571445)"><path d="M0.47 0.2 C3.13 23.7, 13.34 116.62, 16.29 139.79 M-0.74 -0.74 C2.27 22.47, 15.45 114.27, 18.56 137.79" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(712.4507526755199 866.0739826474869) rotate(0 8.566013397689858 69.78571428571445)"><path d="M4.53 111.27 C9.22 118.53, 13.87 130.34, 18.56 137.79 M4.53 111.27 C8.37 119.06, 11.94 124.81, 18.56 137.79" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(712.4507526755199 866.0739826474869) rotate(0 8.566013397689858 69.78571428571445)"><path d="M24.85 108.45 C22.83 116.72, 20.79 129.46, 18.56 137.79 M24.85 108.45 C23.23 117.06, 21.32 123.57, 18.56 137.79" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(1090.0873682498932 788.2168397903442) rotate(0 185.47976684570312 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">Sets internal isHost boolean to false</text></g><g stroke-linecap="round"><g transform="translate(1058.8710680604308 672.2168397903442) rotate(0 112.62836911934068 55)"><path d="M0.33 0.06 C37.96 18.55, 187.73 91.7, 225.06 109.87 M-0.95 -0.96 C36.56 17.83, 186.06 92.86, 224.02 111.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(1058.8710680604308 672.2168397903442) rotate(0 112.62836911934068 55)"><path d="M194.2 108.02 C201.47 108.42, 208.36 108.04, 224.02 111.34 M194.2 108.02 C201.54 109.03, 207.03 110.53, 224.02 111.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(1058.8710680604308 672.2168397903442) rotate(0 112.62836911934068 55)"><path d="M203.31 89.63 C208.21 94.5, 212.9 98.56, 224.02 111.34 M203.31 89.63 C208.61 94.69, 212.07 100.31, 224.02 111.34" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask><g transform="translate(1150.5873682498932 952.2168397903442) rotate(0 188.17977905273438 12.5)"><text x="0" y="0" font-family="Virgil, Segoe UI Emoji" font-size="20px" fill="#1e1e1e" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="text-before-edge">User joins room with guest permissions</text></g><g stroke-linecap="round"><g transform="translate(1293.8951213614628 822.7168397903444) rotate(0 34.42344908172868 62.24999999999994)"><path d="M0.36 0.39 C12.04 20.99, 58.55 103.24, 69.92 123.76 M-0.91 -0.45 C10.73 20.28, 58.1 104.12, 69.53 124.92" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(1293.8951213614628 822.7168397903444) rotate(0 34.42344908172868 62.24999999999994)"><path d="M46.83 105.31 C53.97 112.61, 58.56 115.97, 69.53 124.92 M46.83 105.31 C51.04 109.44, 56.74 113, 69.53 124.92" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g><g transform="translate(1293.8951213614628 822.7168397903444) rotate(0 34.42344908172868 62.24999999999994)"><path d="M64.74 95.3 C66.8 105.5, 66.28 111.72, 69.53 124.92 M64.74 95.3 C65.16 101.72, 66.95 107.46, 69.53 124.92" stroke="#1e1e1e" stroke-width="2" fill="none"></path></g></g><mask></mask></svg>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment