﻿[dotenv@17.2.3] injecting env (155) from .env -- tip: ≡ƒôí add observability to secrets: https://dotenvx.com/ops
[dotenv@17.2.3] injecting env (0) from .env -- tip: ≡ƒöÉ prevent committing .env to code: https://dotenvx.com/precommit
[protected-image] IMAGE_ROOTS = [ 'C:\\Bordales Projects\\giftwrap - Copy\\protected\\images' ]
[protected-image] IMAGE_ROOT = /home/bordales/public_html/v1/protected/images
[protected-image] SKU fallback enabled
[Server] Γ£à Real-Time Monitor: Initialized
[protected-image] Cache initialized with 9640 files
[Schema] PRICE_HAS_COST_MARKUP = true
Γ£à Database synced ΓÇô tables are ready
[Server] Running on port 3000 in development mode
[Server] Health check: http://localhost:3000/healthz
[Server] Ready check: http://localhost:3000/readyz
[Server] Γ£à WhatsApp Service: Loaded
[Server] Γ£à AI Assistant: Loaded
[Server] Γ£à Gate System: Loaded
{"t":"2026-03-05T16:29:45.914Z","event":"tenancy.host","rid":"023223ca-1ad7-49c6-a107-2f7767417293","raw":"localhost","norm":"localhost"}
{"t":"2026-03-05T16:29:45.941Z","event":"tenants.lookup.localhost.ok","rid":"023223ca-1ad7-49c6-a107-2f7767417293","ms":20.8974,"sql":"SELECT id, name, domain, base_currency, timezone, recaptcha_secret, recaptcha_site_key, theme, email, phone, address, company_name FROM tenants WHERE id = 1 LIMIT 1","params":[],"rows":1}
{"t":"2026-03-05T16:29:45.962Z","event":"tenants.profile.ok","rid":"023223ca-1ad7-49c6-a107-2f7767417293","ms":20.3924,"sql":"SELECT logo_path, trading_name, phone_main, phone_alt, support_email, website_url FROM tenant_company_profiles WHERE tenant_id=? LIMIT 1","params":[1],"rows":1}
{"t":"2026-03-05T16:29:45.988Z","event":"tenants.brand.ok","rid":"023223ca-1ad7-49c6-a107-2f7767417293","ms":25.4155,"sql":"SELECT brand_name, brand_tagline, voice_tone, guidelines FROM tenant_brand_profiles WHERE tenant_id=? LIMIT 1","params":[1],"rows":1}
{"t":"2026-03-05T16:29:45.988Z","event":"tenancy.recaptcha","rid":"023223ca-1ad7-49c6-a107-2f7767417293","tenant":"Giftwrap Trading (Pty) Ltd","has_recaptcha_secret":true,"has_recaptcha_key":true}
{"t":"2026-03-05T16:29:45.990Z","event":"tenancy.ok","rid":"023223ca-1ad7-49c6-a107-2f7767417293","ms":78,"hostRaw":"localhost:3000","hostNorm":"localhost","matched":true,"tenant":{"id":1,"domain":"giftwrap.co.za"},"hdrs":{"host":"localhost:3000","xfh":null,"xoh":null}}
[DEBUG] [ROOT] Handler reached for host: localhost:3000
[buildSpa] Final Path: C:\Bordales Projects\giftwrap - Copy\public\bdls-mts\dist\index.html
[DEBUG] [SPA] buildSpa called for path: /
[buildSpa] Tenant resolved: 1 - Giftwrap Trading (Pty) Ltd
[buildSpa] Serving SPA from: C:\Bordales Projects\giftwrap - Copy\public\bdls-mts\dist\index.html
[buildSpa] Initial HTML length: 2540
[SPA] Building for path: /
[DEBUG] [SEO] applyThemeAndSeo called for path: /
[DEBUG] [SEO] Fetching data...
[DEBUG] [SEO] fetchThemeVars for tenant: 1
[DEBUG] [SEO] fetchThemeVars done: 16 rows
[DEBUG] [SEO] fetchSeoMeta for tenant: 1, path: /
[DEBUG] [SEO] fetchSeoMeta done: meta=true, links=4
[DEBUG] [SEO] Data fetched.
[seoService] injectionBlock length: 2250
[seoService] Found 'Premier Pro' in injectionBlock
Running periodic AI performance monitoring...
Running periodic AI performance monitoring...
