collab/mermaid/cypress/platform/xss10.htmlblame
View source
6dd74de1<html>
6dd74de2 <head>
6dd74de3 <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" />
6dd74de4 <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" />
6dd74de5 <link
6dd74de6 rel="stylesheet"
6dd74de7 href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.7.2/css/font-awesome.min.css"
6dd74de8 />
6dd74de9 <link
6dd74de10 href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap"
6dd74de11 rel="stylesheet"
6dd74de12 />
6dd74de13 <style>
6dd74de14 body {
6dd74de15 /* background: rgb(221, 208, 208); */
6dd74de16 /* background:#333; */
6dd74de17 font-family: 'Arial';
6dd74de18 /* font-size: 18px !important; */
6dd74de19 }
6dd74de20 h1 {
6dd74de21 color: grey;
6dd74de22 }
6dd74de23 .mermaid2 {
6dd74de24 display: none;
6dd74de25 }
6dd74de26 .mermaid svg {
6dd74de27 /* font-size: 18px !important; */
6dd74de28 }
6dd74de29 .malware {
6dd74de30 position: fixed;
6dd74de31 bottom: 0;
6dd74de32 left: 0;
6dd74de33 right: 0;
6dd74de34 height: 150px;
6dd74de35 background: red;
6dd74de36 color: black;
6dd74de37 display: flex;
6dd74de38 display: flex;
6dd74de39 justify-content: center;
6dd74de40 align-items: center;
6dd74de41 font-family: monospace;
6dd74de42 font-size: 72px;
6dd74de43 }
6dd74de44 </style>
6dd74de45 <script>
6dd74de46 function xssAttack() {
6dd74de47 const div = document.createElement('div');
6dd74de48 div.id = 'the-malware';
6dd74de49 div.className = 'malware';
6dd74de50 div.innerHTML = 'XSS Succeeded';
6dd74de51 document.getElementsByTagName('body')[0].appendChild(div);
6dd74de52 throw new Error('XSS Succeeded');
6dd74de53 }
6dd74de54 </script>
6dd74de55 </head>
6dd74de56 <body>
6dd74de57 <div>Security check</div>
6dd74de58 <div class="flex">
6dd74de59 <div id="diagram" class="mermaid"></div>
6dd74de60 <div id="res" class=""></div>
6dd74de61 </div>
6dd74de62 <script type="module">
6dd74de63 import mermaid from './mermaid.esm.mjs';
6dd74de64 mermaid.parseError = function (err, hash) {
6dd74de65 // console.error('Mermaid error: ', err);
6dd74de66 };
6dd74de67 mermaid.initialize({
6dd74de68 theme: 'forest',
6dd74de69 arrowMarkerAbsolute: true,
6dd74de70 // themeCSS: '.edgePath .path {stroke: red;} .arrowheadPath {fill: red;}',
6dd74de71 logLevel: 0,
6dd74de72 state: {
6dd74de73 defaultRenderer: 'dagre-d3',
6dd74de74 },
6dd74de75 flowchart: {
6dd74de76 // defaultRenderer: 'dagre-wrapper',
6dd74de77 nodeSpacing: 10,
6dd74de78 curve: 'cardinal',
6dd74de79 htmlLabels: true,
6dd74de80 },
6dd74de81 htmlLabels: true,
6dd74de82 // gantt: { axisFormat: '%m/%d/%Y' },
6dd74de83 sequence: { actorFontFamily: 'courier', actorMargin: 50, showSequenceNumbers: false },
6dd74de84 // sequenceDiagram: { actorMargin: 300 } // deprecated
6dd74de85 // fontFamily: '"times", sans-serif',
6dd74de86 // fontFamily: 'courier',
6dd74de87 fontSize: 18,
6dd74de88 curve: 'basis',
6dd74de89 securityLevel: 'antiscript',
6dd74de90 startOnLoad: false,
6dd74de91 secure: ['secure', 'securityLevel', 'startOnLoad', 'maxTextSize'],
6dd74de92 // themeVariables: {relationLabelColor: 'red'}
6dd74de93 });
6dd74de94 function callback() {
6dd74de95 alert('It worked');
6dd74de96 }
6dd74de97 function xssAttack() {
6dd74de98 const div = document.createElement('div');
6dd74de99 div.id = 'the-malware';
6dd74de100 div.className = 'malware';
6dd74de101 div.innerHTML = 'XSS Succeeded';
6dd74de102 document.getElementsByTagName('body')[0].appendChild(div);
6dd74de103 throw new Error('XSS Succeeded');
6dd74de104 }
6dd74de105
6dd74de106 let diagram = 'classDiagram\n';
6dd74de107 diagram += 'class Square~<img/src';
6dd74de108 diagram += "='1'/onerror=xssAttack()>~{\n";
6dd74de109 diagram += 'id A\n';
6dd74de110 diagram += '}';
6dd74de111
6dd74de112 // var diagram = "stateDiagram-v2\n";
6dd74de113 // diagram += "<img/src='1'/onerror"
6dd74de114 // diagram += "=xssAttack()> --> B";
6dd74de115 console.log(diagram);
6dd74de116 // document.querySelector('#diagram').innerHTML = diagram;
6dd74de117 const { svg } = await mermaid.render('diagram', diagram);
6dd74de118 console.log(res);
6dd74de119 document.querySelector('#res').innerHTML = svg;
6dd74de120 </script>
6dd74de121 </body>
6dd74de122</html>