Files
html/office-hub.html
opus e30ddf5007
Some checks failed
WEVAL NonReg / nonreg (push) Has been cancelled
auto-sync via WEVIA git_sync_all intent 2026-04-20T13:11:38+02:00
2026-04-20 13:11:38 +02:00

173 lines
18 KiB
HTML

<!DOCTYPE html><html lang="fr"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1"><title>Office 365 Hub — WEVAL</title>
<style>
*{margin:0;padding:0;box-sizing:border-box}body{background:#0a0e1a;color:#e2e8f0;font-family:'Segoe UI',system-ui,sans-serif;min-height:100vh}
.top{background:linear-gradient(135deg,#0f172a 0%,#1a1040 50%,#1e293b 100%);padding:32px 40px;border-bottom:1px solid rgba(99,102,241,.2)}
.top h1{font-size:32px;font-weight:800;color:#fff;letter-spacing:-.5px}.top h1 span{background:linear-gradient(135deg,#818cf8,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.top p{color:#94a3b8;margin-top:6px;font-size:15px}
.nav{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.nav a{color:#a5b4fc;text-decoration:none;padding:6px 16px;border:1px solid rgba(99,102,241,.3);border-radius:20px;font-size:13px;transition:.2s}.nav a:hover{background:rgba(99,102,241,.15);color:#fff}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;padding:24px 40px}
.stat{background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.15);border-radius:14px;padding:18px;text-align:center}
.stat .v{font-size:26px;font-weight:800;color:#818cf8}.stat .l{font-size:11px;color:#94a3b8;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.stat.warn .v{color:#fbbf24}.stat.err .v{color:#ef4444}
h2{padding:8px 40px 0;font-size:16px;color:#6366f1;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:16px 40px}
.card{background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(99,102,241,.1);border-radius:14px;padding:24px;transition:.3s;cursor:pointer;text-decoration:none;color:inherit;display:block;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#818cf8);opacity:0;transition:.3s}.card:hover::before{opacity:1}
.card:hover{border-color:rgba(99,102,241,.4);transform:translateY(-3px);box-shadow:0 12px 40px rgba(99,102,241,.12)}
.card h3{font-size:17px;color:#fff;margin-bottom:6px;display:flex;align-items:center;gap:8px}.card h3 .ico{font-size:22px}
.card p{color:#94a3b8;font-size:13px;line-height:1.5}
.tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.tag{padding:3px 10px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.tag.ext{background:rgba(251,191,36,.12);color:#fbbf24}.tag.int{background:rgba(99,102,241,.12);color:#a5b4fc}.tag.exp{background:rgba(239,68,68,.12);color:#ef4444}.tag.ok{background:rgba(52,211,153,.12);color:#34d399}
.section{margin-top:8px}
.footer{text-align:center;padding:24px 40px;color:#475569;font-size:12px;border-top:1px solid rgba(99,102,241,.08);margin-top:24px}
</style></head><body>
<!-- MEGA-NAV -->
<div style="background:rgba(99,102,241,.04);border-bottom:1px solid rgba(99,102,241,.1);padding:8px 40px;display:flex;gap:8px;flex-wrap:wrap;align-items:center">
<span style="color:#64748b;font-size:11px;font-weight:600;letter-spacing:1px">HUBS</span>
<a href="/wevia-hub.html" style="color:#10b981;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(16,185,129,.2);border-radius:12px">🧠 WEVIA</a>
<a href="/ai-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">🤖 AI</a>
<a href="/agents-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">👥 Agents</a>
<a href="/monitoring-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">📊 Monitor</a>
<a href="/email-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">📧 Email</a>
<a href="/office-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">📊 Office</a>
<a href="/ethica-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">👨‍⚕️ Ethica</a>
<a href="/wevads-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">📧 WEVADS</a>
<a href="/blade-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">⚡ Blade</a>
<a href="/security-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">🛡️ Sécu</a>
<a href="/gpu-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">⚡ GPU</a>
<a href="/keys-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">🔐 Keys</a>
<a href="/cloudflare-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">☁️ CF</a>
<a href="/google-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">🔍 Google</a>
<a href="/namecheap-hub.html" style="color:#818cf8;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(99,102,241,.2);border-radius:12px">🌐 NC</a>
<a href="/tools-hub.html" style="color:#f59e0b;text-decoration:none;font-size:12px;padding:3px 10px;border:1px solid rgba(245,158,11,.2);border-radius:12px;font-weight:700">⭐ ALL</a>
</div>
<div class="top"><h1>&#x1F3E2; <span>Office 365</span> Hub</h1><p>Gestion comptes O365, licences, domaines, workflows Microsoft — 3 tenants Azure AD</p>
<div class="nav"><a href="/admin.html">&#x2699; Admin</a><a href="/cloudflare-hub.html">&#x1F536; Cloudflare</a><a href="/google-hub.html">&#x1F535; Google</a><a href="/wevia-master.html">&#x1F9E0; Master</a><a href="/namecheap-hub.html">&#x1F310; Domains</a></div></div>
<div class="stats">
<div class="stat"><div class="v">3</div><div class="l">Tenants Azure AD</div></div>
<div class="stat err"><div class="v">3 &#x26A0;</div><div class="l">Expirés</div></div>
<div class="stat"><div class="v">5+</div><div class="l">Licences</div></div>
<div class="stat"><div class="v">8</div><div class="l">Services</div></div>
<div class="stat warn"><div class="v">P1</div><div class="l">Re-registration</div></div>
</div>
<h2>&#x2601; Services Microsoft</h2>
<div class="grid">
<a class="card" href="https://portal.office.com" target="_blank"><h3><span class="ico">&#x1F4E7;</span> Exchange Online</h3><p>Messagerie, calendriers, contacts professionnels WEVAL Consulting</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://admin.microsoft.com" target="_blank"><h3><span class="ico">&#x2699;</span> Admin Center</h3><p>Gestion utilisateurs, licences, domaines, sécurité tenant</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://www.office.com" target="_blank"><h3><span class="ico">&#x1F4C4;</span> Office Apps</h3><p>Word, Excel, PowerPoint, OneNote — suite complète en ligne</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://teams.microsoft.com" target="_blank"><h3><span class="ico">&#x1F4AC;</span> Teams</h3><p>Chat, visioconférence, collaboration d'équipe, channels</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://onedrive.live.com" target="_blank"><h3><span class="ico">&#x1F4BE;</span> OneDrive</h3><p>Stockage cloud 1TB, partage fichiers, synchronisation</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://flow.microsoft.com" target="_blank"><h3><span class="ico">&#x26A1;</span> Power Automate</h3><p>Workflows automatisés, intégrations API, triggers events</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://powerbi.microsoft.com" target="_blank"><h3><span class="ico">&#x1F4CA;</span> Power BI</h3><p>Dashboards business, rapports interactifs, analytics temps réel</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
<a class="card" href="https://www.microsoft.com/en-us/security/business/microsoft-defender" target="_blank"><h3><span class="ico">&#x1F6E1;</span> Defender</h3><p>Sécurité endpoints, anti-phishing, threat protection</p><div class="tags"><span class="tag ext">EXTERNAL</span></div></a>
</div>
<h2>&#x1F511; Tenants Azure AD</h2>
<div class="grid">
<a class="card" href="https://portal.azure.com" target="_blank"><h3><span class="ico">&#x1F3E5;</span> mbman.onmicrosoft.com</h3><p>Tenant principal WEVAL — gestion identités et accès</p><div class="tags"><span class="tag exp">EXPIRÉ</span><span class="tag int">RE-REGISTER</span></div></a>
<a class="card" href="https://portal.azure.com" target="_blank"><h3><span class="ico">&#x1F30D;</span> globalmed.cl</h3><p>Tenant GlobalMed — secteur médical international</p><div class="tags"><span class="tag exp">EXPIRÉ</span><span class="tag int">RE-REGISTER</span></div></a>
<a class="card" href="https://portal.azure.com" target="_blank"><h3><span class="ico">&#x1F4BC;</span> accoff10.onmicrosoft.com</h3><p>Tenant AccOff10 — comptabilité et finance</p><div class="tags"><span class="tag exp">EXPIRÉ</span><span class="tag int">RE-REGISTER</span></div></a>
</div>
<h2>&#x1F517; Intégrations WEVIA</h2>
<div class="grid">
<a class="card" href="/wevia-master.html"><h3><span class="ico">&#x1F9E0;</span> WEVIA Master</h3><p>Intent "office 365" wiré — gestion via chat souverain</p><div class="tags"><span class="tag ok">WIRÉ</span></div></a>
<a class="card" href="/security-dashboard.html"><h3><span class="ico">&#x1F50D;</span> Security Scanner</h3><p>54 clés trackées, 5 outils actifs, rotation credentials</p><div class="tags"><span class="tag ok">ACTIF</span></div></a>
</div>
<div class="footer">WEVAL CONSULTING &middot; Office 365 Hub &middot; 8 services &middot; 3 tenants (mbman, globalmed, accoff10) &middot; Action P1: re-registration Azure AD</div>
<div style="padding:24px 40px">
<h2 style="font-size:20px;font-weight:700;color:#10b981;margin-bottom:16px">🔧 OUTILS INTERNES WEVAL</h2>
<div class="grid" style="display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px">
<a href="/office-365/office-accounts-edit.php" style="display:block;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:14px;padding:18px;text-decoration:none;transition:.2s"><div style="font-size:16px;font-weight:700;color:#10b981;margin-bottom:6px">📊 Accounts Manager</div><div style="font-size:13px;color:#94a3b8">Gestion des 1500+ comptes O365, édition, rotation</div><span style="display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;background:rgba(16,185,129,.15);color:#10b981;border-radius:8px">INTERNE</span></a>
<a href="/office-365/office-admins.html" style="display:block;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:14px;padding:18px;text-decoration:none;transition:.2s"><div style="font-size:16px;font-weight:700;color:#10b981;margin-bottom:6px">👥 Admin Panel</div><div style="font-size:13px;color:#94a3b8">Administration utilisateurs, rôles, permissions</div><span style="display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;background:rgba(16,185,129,.15);color:#10b981;border-radius:8px">INTERNE</span></a>
<a href="/office-365/office-checker.html" style="display:block;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:14px;padding:18px;text-decoration:none;transition:.2s"><div style="font-size:16px;font-weight:700;color:#10b981;margin-bottom:6px">✅ Email Checker</div><div style="font-size:13px;color:#94a3b8">Vérification état boîtes, quotas, deliverability</div><span style="display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;background:rgba(16,185,129,.15);color:#10b981;border-radius:8px">INTERNE</span></a>
<a href="/office-365/office-workflow.html" style="display:block;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:14px;padding:18px;text-decoration:none;transition:.2s"><div style="font-size:16px;font-weight:700;color:#10b981;margin-bottom:6px">⚡ Workflow</div><div style="font-size:13px;color:#94a3b8">Automatisation flux O365, triggers, actions</div><span style="display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;background:rgba(16,185,129,.15);color:#10b981;border-radius:8px">INTERNE</span></a>
<a href="/office-365/office-import.php" style="display:block;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:14px;padding:18px;text-decoration:none;transition:.2s"><div style="font-size:16px;font-weight:700;color:#10b981;margin-bottom:6px">📥 Import Tool</div><div style="font-size:13px;color:#94a3b8">Import massif comptes, CSV, bulk operations</div><span style="display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;background:rgba(16,185,129,.15);color:#10b981;border-radius:8px">INTERNE</span></a>
</div>
</div>
<!-- CARTO_REMOVED -->
<!-- CARTO_BANNER_V1 -->
<div style="position:fixed;bottom:20px;right:20px;z-index:9999;background:linear-gradient(135deg,#141931,#2d1b5e);border:1px solid #64ffda;border-radius:12px;padding:12px 18px;box-shadow:0 4px 20px rgba(100,255,218,.3);font-family:-apple-system,Segoe UI,sans-serif;font-size:13px">
<a href="/cartographie-screens.html" style="color:#64ffda;text-decoration:none;font-weight:600;display:flex;align-items:center;gap:8px" title="Cartographie exhaustive de tous les ecrans live">
<span style="font-size:18px">&#128506;</span> Cartographie live
<span id="carto-banner-count" style="color:#8892b0;font-size:11px">3914 ecrans</span>
</a>
</div>
<script>
(function(){
fetch('/api/screens-health.php?_='+Date.now(),{cache:'no-store'}).then(r=>r.json()).then(d=>{
const c=d.counts||{}; const up=c.UP||0; const slow=c.SLOW||0; const br=c.BROKEN||0;
const el=document.getElementById('carto-banner-count');
if(el) el.innerHTML=`<span style="color:#22c55e">${up} UP</span> / <span style="color:#f59e0b">${slow} Lent</span> / <span style="color:#ef4444">${br} 5xx</span>`;
}).catch(()=>{});
})();
</script>
<!-- /CARTO_BANNER_V1 -->
<!-- === OPUS UNIVERSAL DRILL-DOWN v1 19avr — append-only, doctrine #14 === -->
<script>
(function(){
if (window.__opusUniversalDrill) return; window.__opusUniversalDrill = true;
var d = document;
var m = d.createElement('div');
m.id = 'opus-udrill';
m.style.cssText = 'position:fixed;inset:0;background:rgba(0,0,0,0.82);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:99995;padding:20px;cursor:pointer';
var inner = d.createElement('div');
inner.id = 'opus-udrill-in';
inner.style.cssText = 'max-width:900px;width:100%;max-height:90vh;overflow:auto;background:#0b0d15;border:1px solid rgba(99,102,241,0.35);border-radius:14px;padding:28px;cursor:default;box-shadow:0 20px 60px rgba(0,0,0,0.6);color:#e2e8f0;font:14px/1.55 Inter,system-ui,sans-serif';
inner.addEventListener('click', function(e){ e.stopPropagation(); });
m.appendChild(inner);
m.addEventListener('click', function(){ m.style.display='none'; });
d.addEventListener('keydown', function(e){ if(e.key==='Escape') m.style.display='none'; });
(d.body || d.documentElement).appendChild(m);
function openCard(card) {
// Clone card content + show close btn + increase font-size
var html = '<div style="display:flex;justify-content:flex-end;margin-bottom:14px"><button id="opus-udrill-close" style="padding:6px 14px;background:#171b2a;border:1px solid rgba(99,102,241,0.25);color:#e2e8f0;border-radius:8px;cursor:pointer;font-size:12px">✕ Fermer (Esc)</button></div>';
html += '<div style="transform-origin:top left;font-size:1.05em">' + card.outerHTML + '</div>';
inner.innerHTML = html;
d.getElementById('opus-udrill-close').onclick = function(){ m.style.display='none'; };
m.style.display = 'flex';
}
function wire(root) {
var sels = '.card,[class*="card"],.kpi,[class*="kpi"],.stat,[class*="stat"],.tile,[class*="tile"],.metric,[class*="metric"],.widget,[class*="widget"]';
var cards = root.querySelectorAll(sels);
for (var i = 0; i < cards.length; i++) {
var c = cards[i];
if (c.__opusWired) continue;
if (c.closest('button, a, input, select, textarea, #opus-udrill')) continue;
var r = c.getBoundingClientRect();
if (r.width < 60 || r.height < 40) continue;
c.__opusWired = true;
c.style.cursor = 'pointer';
c.setAttribute('role','button');
c.setAttribute('tabindex','0');
c.addEventListener('click', function(ev){
// If a more-specific drill is already active (e.g. pp-card custom), let it handle
if (ev.target.closest('[data-pp-id]') && window.__opusDrillInit) return;
if (ev.target.closest('a,button,input,select')) return;
ev.preventDefault(); ev.stopPropagation();
openCard(this);
});
c.addEventListener('keydown', function(ev){ if(ev.key==='Enter'||ev.key===' '){ev.preventDefault();openCard(this);} });
}
}
// Initial + mutation observer
var initRun = function(){ wire(d.body || d.documentElement); };
if (d.readyState === 'loading') d.addEventListener('DOMContentLoaded', initRun);
else initRun();
var mo = new MutationObserver(function(muts){
var newCard = false;
for (var i=0;i<muts.length;i++) if (muts[i].addedNodes.length) { newCard = true; break; }
if (newCard) initRun();
});
mo.observe(d.body || d.documentElement, {childList:true, subtree:true});
})();
</script>
<!-- === OPUS UNIVERSAL DRILL-DOWN END === -->
<script src="/api/archi-meta-badge.js" defer></script>
</body></html>