Domain fetgen.com
Germany
Datacamp Limited
Software information

BunnyCDN-DE1-1079

tcp/443 tcp/80

BunnyCDN-DE1-1333

tcp/443 tcp/80

  • Open service 2400:52e0:1e00:2::1333:1:443 · fetgen.com

    2026-01-26 03:04

    HTTP/1.1 200 OK
    Date: Mon, 26 Jan 2026 03:04:07 GMT
    Content-Type: text/html
    Content-Length: 6474
    Connection: close
    Vary: Accept-Encoding
    Server: BunnyCDN-DE1-1333
    CDN-PullZone: 5071379
    CDN-RequestCountryCode: IN
    Cache-Control: public, max-age=2592000
    Last-Modified: Sun, 04 Jan 2026 23:35:22 GMT
    x-amz-request-id: HCFF00690058DF343E
    CDN-ProxyVer: 1.43
    CDN-RequestPullSuccess: True
    CDN-RequestPullCode: 206
    CDN-CachedAt: 01/10/2026 16:41:34
    CDN-EdgeStorageId: 752
    Cross-Origin-Opener-Policy: same-origin
    Cross-Origin-Embedder-Policy: require-corp
    Cross-Origin-Resource-Policy: same-origin
    Strict-Transport-Security: max-age=63072000; includeSubDomains; preload
    X-Content-Type-Options: nosniff
    Referrer-Policy: strict-origin-when-cross-origin
    Permissions-Policy: camera=(), microphone=(), geolocation=(), payment=()
    CDN-RequestId: e7609ff434232b5bc7857f48af8f6dc8
    CDN-Cache: HIT
    CDN-Status: 200
    CDN-RequestTime: 0
    Accept-Ranges: bytes
    
    
    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
    	<base href="/" />
        <style>
            :root {
                --font-stack: 'Inter', 'Noto Sans', sans-serif;
                --bg-color: #050505;
                --text-color: #050505;
            }
    
            body {
                margin: 0;
                background: var(--bg-color);
                color: var(--text-color);
                height: 100vh;
                display: flex;
                flex-direction: column;
                justify-content: center;
                align-items: center;
                font-family: var(--font-stack); 
                overflow: hidden;
            }
    
            h1 {
                font-weight: 700; 
                font-size: 8rem;
                margin: 0;
                letter-spacing: -0.04em;
                line-height: 1;
            }
    
            @media (max-width: 600px) {
                h1 { font-size: 4rem; }
            }
        </style>
    
    	<!-- 1. LOAD SHARED LOGIC SYNCHRONOUSLY -->
    	<script src="./config/loader.js"></script>
    
    	<!-- 2. SECURE CONFIG LOADER (Uses globals from ./config/loader.js) -->
    	<script>
    		(async () => {
    			// Use constants/functions from ./config/loader.js
    			const SALT = window.SALT || 'h3cr8';
    			const getID = window.getID;
    			const extractHostname = window.extractHostname;
    
    			if (!getID || !extractHostname) {
    				console.error("Critical: ./config/loader.js failed to load.");
    				return;
    			}
    
    			//const url = "https://app.example.com/index.html"; // Example with BRAND NAME
    			const url = window.location.href;
    			const hostname = extractHostname(url);
    
    			// Helper: Inject DOM Elements
    			const inject = (tag, attr = {}, parent = document.head) => {
    				const el = document.createElement(tag);
    				for (const k in attr) el.setAttribute(k, attr[k]);
    				parent.appendChild(el);
    				return el;
    			};
    
    			// Helper: Wait for DOM to be ready
    			const ready = () => new Promise(r => document.readyState !== 'loading' ? r() : document.addEventListener('DOMContentLoaded', r));
    
    			// --- CASCADING LOOKUP ---
    			let config = null;
    
    			// Generate hierarchy candidates: e.g. ["sub.domain.com", "domain.com", "com", ""]
    			const candidates = [];
    			if (hostname) {
    				const labels = hostname.split('.');
    				for (let i = 0; i < labels.length; i++) {
    					candidates.push(labels.slice(i).join('.'));
    				}
    			}
    			// Fallback: The empty string evaluates to the root hash (gtmu080g3r2e4eqoix3c6r1dw)
    			candidates.push("");
    
    			for (const domain of candidates) {
    				try {
    					const hash = await getID(domain, SALT);
    					// Import config. The config file itself MUST resolve its own asset paths.
    					config = (await import(`./config/${hash}/config.js`)).default;
    					if (config) {
    						console.log(`Config loaded for '${domain}' (${hash})`);
    						break;
    					}
    				} catch (e) {
    					// alert(domain);
    					// Config not found for this level, continue cascading up
    				}
    			}
    
    			// --- APPLY ---
    			if (config) {
    				// 1. Expose Config Globally for UI Components (OmniBar, etc.)
    				window.CONFIG = config;
    
    				// 2. Set Meta Title (Browser Tab)
    				// Priority: metaTitle -> title
    				document.title = config.metaTitle || config.title;
    
    				// 3. Set Theme Color
    				document.documentElement.style.setProperty('--bg-app', config.color);
    
    				if (config.manifest) inject('link', { rel: 'manifest', href: config.manifest });
    				if (config.color) inject('meta', { name: 'theme-color', content: config.color });
    
    				// --- DYNAMIC SVG ICON GENERATION ---
    				// UPDATED LOGIC: Prioritize explicit Initials over inherited Icons.
    				// This fixes the issue where spread syntax (...primary) causes specific configs
    				// to inherit the fallback icon even when they defined 'initials'.
    
    				const hasExplicitInitials = (typeof config.initials === 'string');
    
    				if (hasExplicitInitials) {
    					// 1. Explicit Initials (User wanted this)
    					const initials = config.initials;
    					const svgString = `
                        <svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="0 0 100 100">
                        <circle cx="5
    Found 2026-01-26 by HttpPlugin
    Create report
  • Open service 169.150.247.36:80 · fetgen.com

    2026-01-26 03:04

    HTTP/1.1 301 Moved Permanently
    Date: Mon, 26 Jan 2026 03:04:06 GMT
    Content-Type: text/html
    Content-Length: 166
    Connection: close
    Server: BunnyCDN-DE1-1079
    CDN-PullZone: 5071379
    CDN-RequestCountryCode: GB
    Location: https://fetgen.com/
    CDN-RequestId: 52a462b94ffc815575fe0ba116f19054
    Referrer-Policy: strict-origin-when-cross-origin
    Permissions-Policy: camera=(), microphone=(), geolocation=(), payment=()
    Strict-Transport-Security: max-age=63072000; includeSubDomains; preload
    Cross-Origin-Embedder-Policy: require-corp
    Cross-Origin-Resource-Policy: same-origin
    Cross-Origin-Opener-Policy: same-origin
    X-Content-Type-Options: nosniff
    CDN-RequestTime: 0
    
    Page title: 301 Moved Permanently
    
    <html>
    <head><title>301 Moved Permanently</title></head>
    <body>
    <center><h1>301 Moved Permanently</h1></center>
    <hr><center>openresty</center>
    </body>
    </html>
    
    Found 2026-01-26 by HttpPlugin
    Create report
  • Open service 2400:52e0:1e00:2::1333:1:80 · fetgen.com

    2026-01-26 03:04

    HTTP/1.1 301 Moved Permanently
    Date: Mon, 26 Jan 2026 03:04:06 GMT
    Content-Type: text/html
    Content-Length: 166
    Connection: close
    Server: BunnyCDN-DE1-1333
    CDN-PullZone: 5071379
    CDN-RequestCountryCode: DE
    Location: https://fetgen.com/
    CDN-RequestId: 4257beab42145fb8c6fbe97f09d5efd4
    Referrer-Policy: strict-origin-when-cross-origin
    Permissions-Policy: camera=(), microphone=(), geolocation=(), payment=()
    Strict-Transport-Security: max-age=63072000; includeSubDomains; preload
    Cross-Origin-Embedder-Policy: require-corp
    Cross-Origin-Resource-Policy: same-origin
    Cross-Origin-Opener-Policy: same-origin
    X-Content-Type-Options: nosniff
    CDN-RequestTime: 0
    
    Page title: 301 Moved Permanently
    
    <html>
    <head><title>301 Moved Permanently</title></head>
    <body>
    <center><h1>301 Moved Permanently</h1></center>
    <hr><center>openresty</center>
    </body>
    </html>
    
    Found 2026-01-26 by HttpPlugin
    Create report
  • Open service 169.150.247.36:443 · fetgen.com

    2026-01-26 03:04

    HTTP/1.1 200 OK
    Date: Mon, 26 Jan 2026 03:04:06 GMT
    Content-Type: text/html
    Content-Length: 6474
    Connection: close
    Vary: Accept-Encoding
    Server: BunnyCDN-DE1-1079
    CDN-PullZone: 5071379
    CDN-RequestCountryCode: US
    Cache-Control: public, max-age=2592000
    Last-Modified: Sun, 04 Jan 2026 23:35:22 GMT
    x-amz-request-id: HCFF00690058DF343E
    CDN-ProxyVer: 1.43
    CDN-RequestPullSuccess: True
    CDN-RequestPullCode: 206
    CDN-CachedAt: 01/10/2026 16:41:34
    CDN-EdgeStorageId: 752
    Cross-Origin-Opener-Policy: same-origin
    Cross-Origin-Embedder-Policy: require-corp
    Cross-Origin-Resource-Policy: same-origin
    Strict-Transport-Security: max-age=63072000; includeSubDomains; preload
    X-Content-Type-Options: nosniff
    Referrer-Policy: strict-origin-when-cross-origin
    Permissions-Policy: camera=(), microphone=(), geolocation=(), payment=()
    CDN-RequestId: f47861a2ff9204e5109e0931dd1b61ed
    CDN-Cache: HIT
    CDN-Status: 200
    CDN-RequestTime: 0
    Accept-Ranges: bytes
    
    
    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
    	<base href="/" />
        <style>
            :root {
                --font-stack: 'Inter', 'Noto Sans', sans-serif;
                --bg-color: #050505;
                --text-color: #050505;
            }
    
            body {
                margin: 0;
                background: var(--bg-color);
                color: var(--text-color);
                height: 100vh;
                display: flex;
                flex-direction: column;
                justify-content: center;
                align-items: center;
                font-family: var(--font-stack); 
                overflow: hidden;
            }
    
            h1 {
                font-weight: 700; 
                font-size: 8rem;
                margin: 0;
                letter-spacing: -0.04em;
                line-height: 1;
            }
    
            @media (max-width: 600px) {
                h1 { font-size: 4rem; }
            }
        </style>
    
    	<!-- 1. LOAD SHARED LOGIC SYNCHRONOUSLY -->
    	<script src="./config/loader.js"></script>
    
    	<!-- 2. SECURE CONFIG LOADER (Uses globals from ./config/loader.js) -->
    	<script>
    		(async () => {
    			// Use constants/functions from ./config/loader.js
    			const SALT = window.SALT || 'h3cr8';
    			const getID = window.getID;
    			const extractHostname = window.extractHostname;
    
    			if (!getID || !extractHostname) {
    				console.error("Critical: ./config/loader.js failed to load.");
    				return;
    			}
    
    			//const url = "https://app.example.com/index.html"; // Example with BRAND NAME
    			const url = window.location.href;
    			const hostname = extractHostname(url);
    
    			// Helper: Inject DOM Elements
    			const inject = (tag, attr = {}, parent = document.head) => {
    				const el = document.createElement(tag);
    				for (const k in attr) el.setAttribute(k, attr[k]);
    				parent.appendChild(el);
    				return el;
    			};
    
    			// Helper: Wait for DOM to be ready
    			const ready = () => new Promise(r => document.readyState !== 'loading' ? r() : document.addEventListener('DOMContentLoaded', r));
    
    			// --- CASCADING LOOKUP ---
    			let config = null;
    
    			// Generate hierarchy candidates: e.g. ["sub.domain.com", "domain.com", "com", ""]
    			const candidates = [];
    			if (hostname) {
    				const labels = hostname.split('.');
    				for (let i = 0; i < labels.length; i++) {
    					candidates.push(labels.slice(i).join('.'));
    				}
    			}
    			// Fallback: The empty string evaluates to the root hash (gtmu080g3r2e4eqoix3c6r1dw)
    			candidates.push("");
    
    			for (const domain of candidates) {
    				try {
    					const hash = await getID(domain, SALT);
    					// Import config. The config file itself MUST resolve its own asset paths.
    					config = (await import(`./config/${hash}/config.js`)).default;
    					if (config) {
    						console.log(`Config loaded for '${domain}' (${hash})`);
    						break;
    					}
    				} catch (e) {
    					// alert(domain);
    					// Config not found for this level, continue cascading up
    				}
    			}
    
    			// --- APPLY ---
    			if (config) {
    				// 1. Expose Config Globally for UI Components (OmniBar, etc.)
    				window.CONFIG = config;
    
    				// 2. Set Meta Title (Browser Tab)
    				// Priority: metaTitle -> title
    				document.title = config.metaTitle || config.title;
    
    				// 3. Set Theme Color
    				document.documentElement.style.setProperty('--bg-app', config.color);
    
    				if (config.manifest) inject('link', { rel: 'manifest', href: config.manifest });
    				if (config.color) inject('meta', { name: 'theme-color', content: config.color });
    
    				// --- DYNAMIC SVG ICON GENERATION ---
    				// UPDATED LOGIC: Prioritize explicit Initials over inherited Icons.
    				// This fixes the issue where spread syntax (...primary) causes specific configs
    				// to inherit the fallback icon even when they defined 'initials'.
    
    				const hasExplicitInitials = (typeof config.initials === 'string');
    
    				if (hasExplicitInitials) {
    					// 1. Explicit Initials (User wanted this)
    					const initials = config.initials;
    					const svgString = `
                        <svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="0 0 100 100">
                        <circle cx="5
    Found 2026-01-26 by HttpPlugin
    Create report
*.fetgen.comfetgen.com
CN:
*.fetgen.com
Key:
ECDSA-256
Issuer:
E8
Not before:
2025-12-27 18:34
Not after:
2026-03-27 18:34
Domain summary