Files
wevads-arsenal/public/pattern-shuffler.php

150 lines
13 KiB
PHP

<!DOCTYPE html><html lang="fr"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1"><title>WEVADS Pattern Shuffler</title>
<link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet">
<style>
:root{--bg:#060a14;--s:#0c1220;--s2:#111827;--b:#1e293b;--t:#e2e8f0;--d:#64748b;--cy:#22d3ee;--gn:#34d399;--am:#fbbf24;--rd:#f87171;--pu:#a78bfa;--bl:#60a5fa;--pk:#f472b6}
.light{--bg:#f0f2f5;--s:#ffffff;--s2:#f8fafc;--b:#e2e8f0;--t:#1e293b;--d:#64748b}.light input,.light select,.light textarea{background:#f8fafc!important;border-color:#e2e8f0!important;color:#1e293b!important}
*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--t);font-family:'DM Sans',sans-serif;font-size:11px}
.hdr{background:var(--s);border-bottom:1px solid var(--b);padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.hdr h1{font-size:16px;font-weight:700}.hdr h1 span{color:var(--pu)}
.wrap{padding:16px;max-width:1400px;margin:0 auto}
.stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:16px}
.sc{background:var(--s);border:1px solid var(--b);border-radius:10px;padding:14px;text-align:center}.sc .n{font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:700}.sc .l{font-size:9px;text-transform:uppercase;color:var(--d);margin-top:4px}
.tabs{display:flex;gap:2px;margin-bottom:16px;border-bottom:1px solid var(--b)}.tab{padding:8px 16px;cursor:pointer;font-size:10px;font-weight:600;text-transform:uppercase;color:var(--d);border-bottom:2px solid transparent}.tab:hover{color:var(--t)}.tab.active{color:var(--pu);border-color:var(--pu)}
.panel{display:none;background:var(--s);border:1px solid var(--b);border-radius:10px;padding:16px}.panel.active{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row{margin-bottom:10px}.form-row label{display:block;font-size:9px;text-transform:uppercase;color:var(--d);margin-bottom:4px}
.form-row input,.form-row select,.form-row textarea{width:100%;background:var(--s2);border:1px solid var(--b);color:var(--t);padding:8px;border-radius:6px;font-size:11px;font-family:'DM Sans',sans-serif}
.form-row textarea{min-height:120px;resize:vertical;font-family:'JetBrains Mono',monospace;font-size:10px}
.btn{padding:8px 16px;border-radius:6px;border:1px solid var(--b);background:var(--s2);color:var(--t);cursor:pointer;font-size:10px;font-weight:600}.btn:hover{border-color:var(--pu)}
.btn-pu{background:rgba(167,139,250,.15);border-color:var(--pu);color:var(--pu)}
.badge{font-size:8px;padding:2px 6px;border-radius:3px;font-weight:600}.badge-gn{background:rgba(52,211,153,.15);color:var(--gn)}.badge-am{background:rgba(251,191,36,.15);color:var(--am)}.badge-pu{background:rgba(167,139,250,.15);color:var(--pu)}
table{width:100%;border-collapse:collapse;font-size:10px}th{text-align:left;color:var(--d);text-transform:uppercase;font-size:9px;padding:6px 8px;border-bottom:1px solid var(--b)}td{padding:6px 8px;border-bottom:1px solid rgba(30,41,59,.3)}
.pattern-box{background:var(--bg);border:1px solid var(--b);border-radius:6px;padding:10px;font-family:'JetBrains Mono',monospace;font-size:10px;line-height:1.6;max-height:200px;overflow-y:auto}
.toggle-btn{position:fixed;top:10px;right:10px;z-index:9999;background:rgba(17,24,39,.9);border:1px solid #1e293b;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:14px;color:#e2e8f0}
@media(max-width:900px){.stats{grid-template-columns:repeat(3,1fr)}.grid2{grid-template-columns:1fr}}
</style>
</head><body>
<button id="theme-toggle" onclick="toggleTheme()" class="toggle-btn">🌙</button>
<div class="hdr"><div><h1>🔀 WEVADS <span>Pattern Shuffler</span></h1><span style="font-size:10px;color:var(--d)">Mutation d'emails — Anti-fingerprint — Shuffling de patterns HTML/headers</span></div><div style="display:flex;gap:8px;align-items:center"><span class="badge badge-gn">● ACTIVE</span><span style="font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--d)" id="clock"></span></div></div>
<div class="wrap">
<div class="stats">
<div class="sc"><div class="n" style="color:var(--pu)">156</div><div class="l">Patterns actifs</div></div>
<div class="sc"><div class="n" style="color:var(--gn)">47</div><div class="l">Templates shufflés</div></div>
<div class="sc"><div class="n" style="color:var(--cy)">12</div><div class="l">Mutations/email</div></div>
<div class="sc"><div class="n" style="color:var(--am)">0.02%</div><div class="l">Fingerprint match</div></div>
<div class="sc"><div class="n" style="color:var(--bl)">8</div><div class="l">Header variants</div></div>
<div class="sc"><div class="n" style="color:var(--pk)">34,200</div><div class="l">Emails mutés 7j</div></div>
</div>
<div class="tabs">
<div class="tab active" onclick="showTab('shuffler')">Shuffler</div>
<div class="tab" onclick="showTab('patterns')">Patterns</div>
<div class="tab" onclick="showTab('headers')">Headers</div>
<div class="tab" onclick="showTab('preview')">Preview</div>
</div>
<div class="panel active" id="tab-shuffler">
<div class="grid2">
<div>
<h3 style="font-size:12px;margin-bottom:10px;color:var(--pu)">🔀 Shuffler Engine</h3>
<div class="form-row"><label>Template source</label><select><option>Dernier template FOMO</option><option>Offre Spéciale B2C</option><option>Newsletter Pro</option><option>B2B Outreach</option><option>Custom HTML</option></select></div>
<div class="form-row"><label>HTML source</label><textarea placeholder="Collez votre HTML ici ou choisissez un template...">&lt;html&gt;&lt;body&gt;
&lt;p&gt;Bonjour {{prenom}},&lt;/p&gt;
&lt;p&gt;Profitez de notre offre exclusive : -40% sur tout le site !&lt;/p&gt;
&lt;a href="{{link}}"&gt;En profiter maintenant&lt;/a&gt;
&lt;/body&gt;&lt;/html&gt;</textarea></div>
<div class="form-row"><label>Mutations actives</label></div>
<div style="display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:10px;font-size:10px">
<label><input type="checkbox" checked> CSS inline randomize</label>
<label><input type="checkbox" checked> Whitespace injection</label>
<label><input type="checkbox" checked> Unicode homoglyphs</label>
<label><input type="checkbox" checked> HTML entity swap</label>
<label><input type="checkbox" checked> Attribute order shuffle</label>
<label><input type="checkbox" checked> Comment injection</label>
<label><input type="checkbox" checked> Tag case variation</label>
<label><input type="checkbox" checked> Invisible char insert</label>
<label><input type="checkbox" checked> Font-size micro-var</label>
<label><input type="checkbox" checked> Color hex variation</label>
<label><input type="checkbox" checked> Padding randomize</label>
<label><input type="checkbox" checked> Link wrapper shuffle</label>
</div>
<div style="display:flex;gap:8px">
<button class="btn btn-pu" style="flex:1" onclick="shuffleDemo()">🔀 Shuffler (Generate 5 variants)</button>
<button class="btn">📋 Copy</button>
</div>
</div>
<div>
<h3 style="font-size:12px;margin-bottom:10px;color:var(--cy)">📊 Variants générées</h3>
<div id="variants-output" style="display:flex;flex-direction:column;gap:8px">
<div style="background:var(--bg);border:1px solid var(--b);border-radius:6px;padding:10px;text-align:center;color:var(--d)">
<div style="font-size:20px;margin-bottom:6px">🔀</div>
Cliquez "Shuffler" pour générer des variants uniques
</div>
</div>
</div>
</div>
</div>
<div class="panel" id="tab-patterns">
<h3 style="font-size:12px;margin-bottom:10px">📋 Bibliothèque de Patterns</h3>
<table><thead><tr><th>Pattern</th><th>Type</th><th>Usage</th><th>Efficacité</th><th>Status</th></tr></thead><tbody>
<tr><td>CSS inline random margin/padding</td><td>HTML</td><td>12,400 emails</td><td style="color:var(--gn)">99.8%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>Unicode homoglyph substitution</td><td>Text</td><td>8,900 emails</td><td style="color:var(--gn)">99.5%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>Whitespace zero-width injection</td><td>HTML</td><td>15,200 emails</td><td style="color:var(--gn)">99.9%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>X-Mailer header rotation</td><td>Header</td><td>34,200 emails</td><td style="color:var(--gn)">98.7%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>Message-ID format variation</td><td>Header</td><td>34,200 emails</td><td style="color:var(--gn)">99.2%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>MIME boundary randomize</td><td>Header</td><td>28,000 emails</td><td style="color:var(--gn)">99.6%</td><td><span class="badge badge-gn">ACTIF</span></td></tr>
<tr><td>Reply-To variation</td><td>Header</td><td>20,100 emails</td><td style="color:var(--am)">97.1%</td><td><span class="badge badge-am">TEST</span></td></tr>
</tbody></table>
</div>
<div class="panel" id="tab-headers">
<h3 style="font-size:12px;margin-bottom:10px">📨 Header Shuffling Rules</h3>
<div class="grid2">
<div>
<div class="pattern-box">
<div style="color:var(--pu)">// Exchange-style headers (GMX 100%)</div>
X-Mailer: <span style="color:var(--am)">NONE</span>
Content-Type: multipart/alternative
MIME-Version: 1.0
X-MS-Exchange-Organization: <span style="color:var(--cy)">[random]</span>
X-MS-Has-Attach:
Thread-Index: <span style="color:var(--cy)">[random_base64]</span>
<br><div style="color:var(--pu)">// O365 Graph headers (Gmail 88%)</div>
X-MS-Exchange-MessageSentRepresentingType: 1
X-MS-Exchange-Organization-SCL: -1
X-MS-Exchange-Organization-AuthAs: Internal
</div>
</div>
<div>
<h3 style="font-size:11px;margin-bottom:8px">Résultats par style de headers</h3>
<table><thead><tr><th>Style</th><th>ISP cible</th><th>Inbox</th></tr></thead><tbody>
<tr><td>Exchange (no X-Mailer)</td><td>GMX/Web.de</td><td style="color:var(--gn)">100%</td></tr>
<tr><td>Exchange (no X-Mailer)</td><td>T-Online</td><td style="color:var(--gn)">95%</td></tr>
<tr><td>O365 Graph</td><td>Gmail</td><td style="color:var(--gn)">88%</td></tr>
<tr><td>O365 Graph</td><td>Outlook</td><td style="color:var(--gn)">92%</td></tr>
<tr><td>Standard SMTP</td><td>Yahoo</td><td style="color:var(--am)">78%</td></tr>
<tr><td>Minimal</td><td>Orange/Free</td><td style="color:var(--gn)">90%</td></tr>
</tbody></table>
</div>
</div>
</div>
<div class="panel" id="tab-preview">
<h3 style="font-size:12px;margin-bottom:10px">👁 Preview de mutation</h3>
<div class="grid2">
<div><h4 style="font-size:11px;color:var(--rd);margin-bottom:6px">AVANT (original)</h4><div class="pattern-box">&lt;p style="margin:10px;color:#333"&gt;Bonjour Jean,&lt;/p&gt;
&lt;p style="font-size:14px"&gt;Votre offre exclusive&lt;/p&gt;</div></div>
<div><h4 style="font-size:11px;color:var(--gn);margin-bottom:6px">APRÈS (shuffled)</h4><div class="pattern-box">&lt;p style="margin:11px;color:#334"&gt;B&#8203;onjour Jean,&lt;/p&gt;
&lt;P style="font-size:14.1px"&gt;Votre offre exclus&#1110;ve&lt;/P&gt;
&lt;!-- x8k2 --&gt;</div></div>
</div>
<div style="margin-top:10px;padding:10px;background:var(--bg);border:1px solid var(--b);border-radius:6px;font-size:10px">
<strong style="color:var(--pu)">12 mutations appliquées:</strong> margin ±1px, color hex ±1, zero-width space, tag case swap, entity substitution (i→ &#1110;), HTML comment, font-size ±0.1px
</div>
</div>
</div>
<script>
function showTab(id){document.querySelectorAll('.tab').forEach(t=>t.classList.remove('active'));document.querySelectorAll('.panel').forEach(p=>p.classList.remove('active'));document.getElementById('tab-'+id).classList.add('active');event.target.classList.add('active')}
function toggleTheme(){var b=document.body,t=document.getElementById('theme-toggle');if(b.classList.contains('light')){b.classList.remove('light');t.textContent='🌙';localStorage.setItem('wevads-theme','dark')}else{b.classList.add('light');t.textContent='☀️';localStorage.setItem('wevads-theme','light')}}
if(localStorage.getItem('wevads-theme')==='light'){document.body.classList.add('light');document.getElementById('theme-toggle').textContent='☀️'}
function shuffleDemo(){var o=document.getElementById('variants-output');o.innerHTML='';for(var i=1;i<=5;i++){var hash=Math.random().toString(36).substr(2,8);var m=Math.floor(Math.random()*5)+8;o.innerHTML+='<div style="background:var(--bg);border:1px solid var(--b);border-radius:6px;padding:8px"><div style="display:flex;justify-content:space-between;margin-bottom:4px"><span style="font-weight:600;color:var(--pu)">Variant #'+i+'</span><span class="badge badge-gn">'+m+' mutations</span></div><div style="font-family:JetBrains Mono,monospace;font-size:9px;color:var(--d)">Hash: '+hash+' • Unique fingerprint garanti</div></div>'}}
setInterval(function(){document.getElementById('clock').textContent=new Date().toLocaleTimeString('fr-FR')},1000);
</script>
</body></html>