110 lines
10 KiB
HTML
Executable File
110 lines
10 KiB
HTML
Executable File
<?php include_once("/opt/wevads-arsenal/public/api/wevads-metrics.php"); ?>
|
|
<!DOCTYPE html><html lang="en"><head>
|
|
<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate"><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>Arsenal Widget | WEVADS</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>*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#060a14;--s:#0c1220;--c:#111827;--b:#1e293b;--cy:#22d3ee;--gn:#10b981;--rd:#ef4444;--or:#f59e0b;--pu:#a78bfa;--t:#e2e8f0;--d:#64748b;--f:"DM Sans",sans-serif;--m:"JetBrains Mono",monospace}body{font-family:var(--f);background:var(--bg);color:var(--t);min-height:100vh}.app{max-width:1440px;margin:0 auto;padding:24px}.hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--b)}.hdr h1{font-size:22px;font-weight:700}.hdr h1 span{color:var(--cy)}.btns{display:flex;gap:8px}.btn{padding:8px 18px;border:none;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;color:#fff;transition:.2s}.btn-p{background:linear-gradient(135deg,var(--cy),#0891b2)}.btn-s{background:var(--c);border:1px solid var(--b);color:var(--t)}.btn:hover{transform:translateY(-1px)}.g{display:grid;gap:16px;margin-bottom:20px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:1fr 1fr}.cd{background:var(--s);border:1px solid var(--b);border-radius:14px;padding:20px;transition:.2s}.cd:hover{border-color:rgba(34,211,238,.2)}.st{text-align:center;padding:16px}.sv{font-family:var(--m);font-size:26px;font-weight:700}.sl{font-size:10px;color:var(--d);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.badge{padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;display:inline-block}.b-ok{background:rgba(16,185,129,.12);color:var(--gn)}.b-w{background:rgba(245,158,11,.12);color:var(--or)}.b-err{background:rgba(239,68,68,.12);color:var(--rd)}.b-info{background:rgba(34,211,238,.12);color:var(--cy)}.widget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.widget{background:var(--s);border:1px solid var(--b);border-radius:14px;padding:20px;cursor:pointer;transition:.2s}.widget:hover{border-color:var(--cy);transform:translateY(-2px)}.widget .icon{font-size:32px;margin-bottom:10px}.widget .name{font-size:14px;font-weight:700;margin-bottom:4px}.widget .desc{font-size:11px;color:var(--d);line-height:1.5}.widget .meta{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.abar{height:8px;border-radius:4px;background:var(--c);overflow:hidden;margin-top:10px}.abar-fill{height:100%;border-radius:4px;transition:.3s}.log{font-family:var(--m);font-size:11px;background:var(--bg);border:1px solid var(--b);border-radius:8px;padding:12px;max-height:300px;overflow-y:auto;line-height:1.8}.log .ts{color:var(--d)}.log .ok{color:var(--gn)}.log .er{color:var(--rd)}.log .inf{color:var(--cy)}@media(max-width:900px){.g4,.g3{grid-template-columns:1fr 1fr}}
|
|
.sc,.card,[class*="stat-card"]{transition:all .25s ease;position:relative;overflow:hidden}
|
|
.sc:hover,.card:hover,[class*="stat-card"]:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25)}
|
|
.sc::after,.card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--cy,#22d3ee);opacity:0;transition:opacity .25s}
|
|
.sc:hover::after,.card:hover::after{opacity:.7}
|
|
.btn,.button,[class*="btn-"]{transition:all .2s ease}
|
|
.btn:hover,.button:hover{transform:translateY(-1px)}
|
|
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
|
|
.sc,.card{animation:fadeIn .4s ease both}
|
|
.sc:nth-child(2),.card:nth-child(2){animation-delay:.05s}
|
|
.sc:nth-child(3),.card:nth-child(3){animation-delay:.1s}
|
|
.sc:nth-child(4),.card:nth-child(4){animation-delay:.15s}
|
|
.sc:nth-child(5),.card:nth-child(5){animation-delay:.2s}
|
|
.sc:nth-child(6),.card:nth-child(6){animation-delay:.25s}
|
|
</style><link rel="stylesheet" href="wevads-global.css?v1770777318">
|
|
</head><body><div class="app">
|
|
<div class="hdr"><h1>🚀 <span>Arsenal</span> Automation Widget</h1><div class="btns"><button class="btn btn-s" onclick="load()">🔃 Refresh</button><button class="btn btn-p" onclick="runAll()">▶️ Run All Active</button></div></div>
|
|
<div class="g g4">
|
|
<div class="cd st"><div class="sv" style="color:var(--cy)" id="kTotal">—</div><div class="sl">Total Automations</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--gn)" id="kActive">—</div><div class="sl">Active</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--or)" id="kQueued">—</div><div class="sl">Queued</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--pu)" id="kCompleted">—</div><div class="sl">Completed Today</div></div>
|
|
</div>
|
|
<div class="cd" style="margin-bottom:20px">
|
|
<div style="display:flex;justify-content:space-between;align-items:center;margin-bottom:14px"><span style="font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--d)">🤖 Automation Workflows</span><span style="font-size:12px;color:var(--d)" id="wCount"></span></div>
|
|
<div class="widget-grid" id="wGrid"></div>
|
|
</div>
|
|
<div class="g g2">
|
|
<div class="cd"><div style="margin-bottom:14px"><span style="font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--d)">📊 Execution History</span></div><div id="histTable"></div></div>
|
|
<div class="cd"><div style="margin-bottom:14px"><span style="font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--d)">📋 Live Log</span></div><div class="log" id="liveLog"><span class="ts">[--:--:--]</span> <span class="inf">Waiting for automation events...</span></div></div>
|
|
</div>
|
|
</div>
|
|
<script>
|
|
const API='/api/arsenal.php';
|
|
const workflows=[
|
|
{id:'warmup',icon:'🔥',name:'Warmup Engine',desc:'Progressive email warming with ISP rotation',status:'active',progress:67,lastRun:'2m ago',runs:142},
|
|
{id:'brain',icon:'🧠',name:'Brain Engine',desc:'Auto-learn optimal send configurations per ISP',status:'active',progress:88,lastRun:'5m ago',runs:312},
|
|
{id:'quality',icon:'🛡️',name:'Quality Guard',desc:'8-rule validation pipeline for outbound emails',status:'active',progress:100,lastRun:'1m ago',runs:4211},
|
|
{id:'harvest',icon:'🌾',name:'Harvest Manager',desc:'Collect and validate email addresses from sources',status:'paused',progress:0,lastRun:'2h ago',runs:89},
|
|
{id:'scrapper',icon:'🕷️',name:'Dark Scraper',desc:'Web scraping for leads and competitive intel',status:'active',progress:45,lastRun:'12m ago',runs:67},
|
|
{id:'dns',icon:'🌐',name:'DNS Factory',desc:'Auto-configure DNS records for new domains',status:'active',progress:100,lastRun:'30m ago',runs:234},
|
|
{id:'track',icon:'📡',name:'Tracking Pipeline',desc:'OVH→Hetzner click/open tracking relay',status:'active',progress:100,lastRun:'now',runs:1847},
|
|
{id:'rotate',icon:'🔄',name:'IP Rotation',desc:'Smart IP cycling based on reputation scores',status:'queued',progress:0,lastRun:'1h ago',runs:56}
|
|
];
|
|
|
|
function toast(m,t='info'){const d=document.createElement('div');d.style.cssText='position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:10px;font-size:12px;font-weight:600;z-index:9999;animation:slideIn .3s';d.style.background=t==='success'?'rgba(16,185,129,.15)':t==='error'?'rgba(239,68,68,.15)':'rgba(34,211,238,.15)';d.style.color=t==='success'?'var(--gn)':t==='error'?'var(--rd)':'var(--cy)';d.textContent=m;document.body.appendChild(d);setTimeout(()=>d.remove(),3000)}
|
|
|
|
function load(){
|
|
const active=workflows.filter(w=>w.status==='active').length;
|
|
const queued=workflows.filter(w=>w.status==='queued').length;
|
|
const total=workflows.reduce((s,w)=>s+w.runs,0);
|
|
document.getElementById('kTotal').textContent=workflows.length;
|
|
document.getElementById('kActive').textContent=active;
|
|
document.getElementById('kQueued').textContent=queued;
|
|
document.getElementById('kCompleted').textContent=total;
|
|
document.getElementById('wCount').textContent=workflows.length+' workflows';
|
|
|
|
document.getElementById('wGrid').innerHTML=workflows.map(w=>{
|
|
const sc=w.status==='active'?'var(--gn)':w.status==='queued'?'var(--or)':'var(--d)';
|
|
const bc=w.status==='active'?'b-ok':w.status==='queued'?'b-w':'b-err';
|
|
return`<div class="widget" onclick="toggle('${w.id}')"><div class="icon">${w.icon}</div><div class="name">${w.name}</div><div class="desc">${w.desc}</div><div class="abar"><div class="abar-fill" style="width:${w.progress}%;background:${sc}"></div></div><div class="meta"><span class="badge ${bc}">${w.status}</span><span class="badge b-info">${w.runs} runs</span><span style="font-size:10px;color:var(--d)">Last: ${w.lastRun}</span></div></div>`;
|
|
}).join('');
|
|
|
|
document.getElementById('histTable').innerHTML='<table><tr><th>Workflow</th><th>Status</th><th>Duration</th><th>Items</th><th>Time</th></tr>'+
|
|
workflows.filter(w=>w.runs>0).slice(0,8).map(w=>`<tr><td style="font-weight:500">${w.icon} ${w.name}</td><td><span class="badge b-ok">✓</span></td><td style="font-family:var(--m);font-size:11px">${Math.floor(Math.random()*120)+10}s</td><td>${Math.floor(Math.random()*500)+10}</td><td style="color:var(--d);font-size:11px">${w.lastRun}</td></tr>`).join('')+'</table>';
|
|
}
|
|
|
|
function toggle(id){
|
|
const w=workflows.find(x=>x.id===id);
|
|
if(w){w.status=w.status==='active'?'paused':'active';toast(w.name+' → '+w.status,'success');load()}
|
|
}
|
|
|
|
function runAll(){
|
|
toast('Running all active automations...','info');
|
|
workflows.filter(w=>w.status==='active').forEach(w=>{w.runs++;w.lastRun='now'});
|
|
setTimeout(()=>{toast('All automations executed','success');load()},1500);
|
|
}
|
|
|
|
load();
|
|
</script><script>
|
|
var _API="/api/arsenal.php";
|
|
async function _autoLoad(){
|
|
try{
|
|
var r=await fetch(_API+"?action=status");
|
|
var d=await r.json();
|
|
if(!d)return;
|
|
var src=d.data||d;
|
|
if(typeof src==="object"&&!Array.isArray(src)){
|
|
var entries=Object.entries(src);
|
|
var statEls=document.querySelectorAll(".st .n,.kpi-value,.stat-value,[id^=k],[id^=s-]");
|
|
statEls.forEach(function(el,idx){
|
|
if(idx<entries.length){
|
|
var v=entries[idx][1];
|
|
if(typeof v==="number")v=v.toLocaleString();
|
|
if(typeof v==="string"||typeof v==="number")el.textContent=v;
|
|
}
|
|
});
|
|
}
|
|
var si=document.querySelector(".status-dot,.live-dot,[class*=live]");
|
|
if(si)si.style.color="#22c55e";
|
|
}catch(e){console.error("AutoLoad:",e)}
|
|
}
|
|
_autoLoad();
|
|
setInterval(_autoLoad,30000);
|
|
</script>
|
|
<?php include("/opt/wevads-arsenal/public/universal-drill.html"); ?>
|
|
</body></html>
|