top of page

Building an Enterprise SOC Operations Center with AgentiX Cyber

Updated: 20 hours ago



CISO Case Study

Building an Enterprise SOC Operations Center with AgentiX Cyber

A practical guide for CISOs deploying an AI-powered Security Operations Center — from conversational threat analysis and automated incident investigation to role-based governance across a unified command surface.


16

Dashboard Elements

15

Data Pipelines

5

MCP Integrations

5

SOC Tiers


agentix-cyber — soc-operations-dashboard

AgentiX Cyber SOC Operations Dashboard overview with 16 interconnected AI-powered elements

SOC Operations Dashboard — 16 AI-driven elements connected by 15 automated data pipelines, generating real-time security intelligence


The Challenge: Why SOCs Are Struggling

Enterprise Security Operations Centers face a compounding set of operational challenges that traditional tooling cannot address. The average SOC analyst manages alerts across 6–8 disconnected security platforms, context-switching dozens of times per shift. The result: slow response times, missed correlations, and analyst burnout.

🚨

Alert Fatigue

Analysts process 500+ alerts daily, with false positive rates exceeding 40%. Critical threats drown in noise because manual triage cannot scale.

🔧

Tool Sprawl

SIEM, SOAR, TIP, EDR, SIRP, and compliance platforms each run in isolation. No unified view means analysts miss cross-tool correlations that attackers exploit.

Manual Triage Bottleneck

Investigation queries, IOC enrichment, and report generation are manual processes. Mean time to investigate a single alert: 25–45 minutes.

🎓

Skills Gap

Tier 1 analysts lack the experience for advanced threat hunting. Knowledge lives in senior analysts’ heads, not in the platform.

The core problem: Security tooling was designed for individual tasks, not for operational workflows. CISOs need a unified command surface where AI handles the mechanical work — querying, correlating, enriching, reporting — while analysts focus on decisions that require human judgement.


Platform Overview: The AI Command Center

AgentiX Cyber is built around three integrated components that work together to address every aspect of SOC operations. Rather than replacing existing security tools, it connects to them through the Model Context Protocol (MCP) — a standardised interface that gives the AI direct, real-time access to your SIEM, SOAR, threat intelligence, and case management platforms.

💬

Super Agent

Conversational AI interface with direct MCP tool access. Ask questions in natural language; the agent queries your security tools in real-time.

📊

Dynamic Dashboard

16 interconnected elements generating AI-powered intelligence across the SOC lifecycle. Tabbed views, classification controls, and exportable reports.

🔒

Admin Panel

Role-based access control, MCP server governance, user management with MFA enforcement, clearance levels, and complete audit trails.


agentix-cyber — super-agent-welcome

AgentiX Cyber Super Agent welcome interface showing quick action cards for Threat Hunting, Incident Triage, and Security Posture, with MCP server status indicators

Super Agent Welcome — Quick-action cards for Threat Hunting, Incident Triage, and Security Posture • MCP server connection status (Wazuh, Playwright, Filesystem)

The welcome screen immediately shows which MCP servers are connected and operational. Analysts see green indicators for active integrations and can launch common workflows with a single click. There is no onboarding friction — the platform is ready to answer questions from the first interaction.


Use Case 1: Real-Time Threat Analysis

The most immediate value the Super Agent provides is real-time threat analysis. Instead of logging into Wazuh, running queries, exporting results, and manually correlating with threat intelligence — an analyst simply asks a question in natural language.

How It Works

When an analyst types “Give me a comprehensive threat analysis of our current Wazuh alerts”, the Super Agent executes a multi-step workflow automatically:

MCP Tool Chain — Threat Analysis

get_wazuh_alerts

AI Correlation

Severity Classification

Hunting Recommendations

The agent calls the Wazuh MCP server directly via the get_wazuh_alerts tool, retrieves live alert data, then produces a structured analysis that includes a critical alerts table, hunting recommendations mapped to MITRE ATT&CK, and a security posture assessment — all in a single response.


super-agent — threat-analysis-response

AgentiX Cyber threat analysis response showing critical alerts table with severity levels, threat hunting recommendations with MITRE ATT&CK mappings, and security posture assessment

Threat Analysis Response — Critical alerts table • Hunting recommendations with MITRE ATT&CK mapping • Security posture assessment with scores

What the Analyst Sees

The response is structured into actionable sections, not a wall of text. The Critical Alerts Table presents each alert with its Wazuh rule ID, severity level, affected agent, and count — sortable and scannable. Below that, Threat Hunting Recommendations provide specific KQL queries mapped to ATT&CK techniques (T1110 Brute Force, T1078 Valid Accounts, T1059 Command Execution). The Security Posture Assessment gives overall scores across detection coverage, response readiness, and threat exposure.

Key advantage: This analysis would take a senior analyst 30–45 minutes to produce manually. The Super Agent delivers it in under 15 seconds, drawing from live Wazuh data. Tier 1 analysts can now perform Tier 2–level threat analysis independently.


Use Case 2: Automated Incident Investigation

When a security incident requires deeper investigation, the Super Agent chains multiple MCP tools together to build a comprehensive incident report. An analyst asks: “Generate a full incident report on our current security posture, including CVE analysis and remediation steps.”

Multi-Tool Execution Transparency

The platform shows exactly which tools were called and in what order. This transparency is critical for SOC governance — every investigation has a reproducible audit trail showing the data sources and analysis chain.

Step 1

Alert Summary

get_wazuh_alert_summary retrieves severity breakdown and top alert categories

Step 2

Agent Inventory

get_wazuh_agents maps affected assets, agent versions, and OS distributions

Step 3

CVE Analysis

get_wazuh_critical_vulnerabilities identifies exploitable CVEs across the fleet


super-agent — incident-report

AgentiX Cyber incident report showing CVE analysis with CVSS scores, remediation priority matrix, and action buttons for export and sharing

Incident Report — CVE analysis with CVSS scores • Remediation priority matrix • 3 execution steps shown • Action buttons for export and escalation

The generated report includes a CVE Analysis section with CVSS scores, affected systems, and exploit availability. The Remediation Priority Matrix ranks patches by risk-adjusted impact. Action buttons allow the analyst to export the report as a PDF, share it with the SOC manager, or create a case in TheHive — all without leaving the chat interface.

Notice the “3 execution steps” indicator in the response header. This is not a cosmetic detail. Every tool call is logged with its input parameters and output data. If an analyst or auditor needs to verify how a conclusion was reached, they can expand the execution trace and see the exact API calls that produced the analysis.


Use Case 3: Detection Engineering with Sigma Rules

Detection engineering is typically a specialised discipline requiring deep knowledge of log schemas, SIEM query languages, and the MITRE ATT&CK framework. AgentiX Cyber democratises this capability by generating production-ready Sigma detection rules on demand.

An analyst asks: “Create a Sigma detection rule for detecting lateral movement via PsExec.” The Super Agent generates a complete rule in YAML format with all required fields.


super-agent — sigma-detection-rule

AgentiX Cyber generating a Sigma detection rule with YAML code block, MITRE ATT&CK T1570 mapping, severity level badge, and false positive guidance

Sigma Rule Generation — YAML code block with syntax highlighting • MITRE ATT&CK T-code mapping • Severity badge • False positive guidance

What Gets Generated

📝

Complete YAML Rule

Properly formatted Sigma rule with title, description, log source, detection logic (selection + condition), and metadata fields. Ready to deploy to any Sigma-compatible SIEM.

🎯

MITRE ATT&CK Mapping

Each rule is tagged with the relevant technique ID (e.g., T1570 Lateral Tool Transfer) and tactic category, enabling framework-aligned detection coverage tracking.

False Positive Guidance

Every rule includes a False Positives section listing legitimate scenarios that may trigger the rule, reducing alert fatigue from day one of deployment.

🛡

Severity Classification

Visual severity badge (High, Medium, Critical) helps SOC managers prioritise which rules to deploy first based on risk exposure.

Operational impact: Detection engineering cycles that previously took days — from threat research to rule authoring to peer review — are compressed to minutes. The AI-generated rules serve as a high-quality first draft that detection engineers can refine and deploy, rather than starting from scratch.


The Dynamic SOC Dashboard

While the Super Agent handles conversational interactions, the Dynamic Dashboard provides a visual operations surface for continuous monitoring. Built on a node-based canvas, it displays 16 interconnected elements organised across the SOC lifecycle — from log ingestion through compliance reporting.


agentix-cyber — soc-operations-dashboard

AgentiX Cyber SOC Operations Dashboard with 15 interconnected elements showing SIEM, alerts, threat intelligence, SOAR, compliance, and tier escalation

SOC Operations Dashboard — 16 elements across 6 operational layers • SECRET classification badge • Tabbed views (SOC Operations, Threat Intelligence) • Export and share controls

Dashboard Architecture

Each element in the dashboard is an AI-powered node that generates content on configurable refresh intervals. Elements are connected by directed edges that represent data flow dependencies. The six operational layers mirror the SOC lifecycle:

Layer 1–2 — Collection & Triage

SIEM Log Collection

SOC Alert Triage

Security Alerts Summary

Layer 3–4 — Intelligence & Hunting

Threat Intel Feed

IP Investigation

Threat Hunting

Use Case Dev

Layer 5–6 — Response & Compliance

SOAR Playbooks

SIRP

Tier Escalation

Compliance Engine


dashboard — panning-across-elements

Panning across the AgentiX Cyber dashboard showing alert triage, security alerts severity table, and element connections

Dashboard Navigation — Panning across alert triage, security alerts severity table, and element-to-element connections with dashed flow lines

Enterprise Features

The dashboard is not a static display. It is a configurable operations surface built for enterprise deployment:

  • Tabbed Views: Organise elements into separate tabs (SOC Operations, Threat Intelligence, Compliance) for role-specific views

  • Classification Controls: SECRET, TOP SECRET, and UNCLASSIFIED banners enforce handling rules for classified environments

  • Export & Share: Dashboard snapshots can be exported as reports or shared with specific users through role-controlled access

  • Configurable Refresh: Each element has independent refresh intervals (15 min to 300 min) based on data freshness requirements

  • AI Model Selection: Elements can use different LLM models based on cost-performance tradeoffs (gpt-4.1-mini for frequent alerts, gpt-4o for complex analysis)


Enterprise Administration & Governance

Security platforms without proper governance become liabilities. AgentiX Cyber provides a comprehensive admin panel that gives CISOs full control over who can access which tools and data.

User Management


admin-panel — user-management

AgentiX Cyber admin panel showing user management with 5 users, role assignments, MFA status indicators, and account status badges

Admin Panel — User management with role assignments, MFA enforcement, account status, and last login tracking

The admin panel displays all platform users with their assigned roles (SUPER_ADMIN, SOC_MANAGER, SENIOR_ANALYST, SOC_ANALYST, THREAT_HUNTER), MFA status, last login timestamp, and account state. Administrators can enable/disable accounts, force MFA enrollment, and assign clearance levels — all from a single interface.

MCP Server Access Control

This is where AgentiX Cyber’s governance model becomes particularly powerful. The MCP Access Control panel lets administrators define which roles can access which MCP servers. A SOC_ANALYST might have access to Wazuh for alert queries but not to Velociraptor for endpoint forensics. A THREAT_HUNTER gets full access to all intelligence tools.


admin-panel — mcp-access-control

AgentiX Cyber MCP access control panel showing per-role toggle switches for Wazuh, TheHive, Cortex, Velociraptor, and OpenCTI MCP servers

MCP Access Control — Per-role toggle switches for each MCP server • Role-based tool filtering enforced at the backend • Real-time configuration updates

When a user interacts with the Super Agent, the backend filters available tools based on their role’s MCP access configuration. The filtering happens at the API layer — tools from restricted servers never appear in the agent’s available tool set for that user. This is not UI-level hiding; it is backend-enforced access control.

Governance principle: The AI should only have access to the tools its operator is authorised to use. MCP Access Control ensures that even if an analyst asks the Super Agent to perform forensic collection, the request is denied if their role does not permit Velociraptor access. The denial is logged for audit purposes.


Technical Architecture

AgentiX Cyber is a self-hosted platform designed for air-gapped and classified environments. The architecture separates the presentation layer from the intelligence layer, with MCP as the standardised protocol for tool integration.

React + TypeScript Frontend

ShadCN/UI component library, TailwindCSS, React Query for server state, WebSocket for real-time updates. Node-based dashboard canvas with React Flow.

FastAPI Backend

Async Python with SQLAlchemy ORM, JWT authentication, WebSocket streaming for chat responses. Custom middleware for performance monitoring and error handling.

🔗

MCP Protocol Layer

Model Context Protocol for standardised tool integration. Supports Wazuh, TheHive, Cortex, Velociraptor, and OpenCTI. Graceful degradation when servers are unavailable.

🔐

Security & Auth

JWT token-based auth with role-based access control. MFA enforcement per user. Backend-enforced MCP tool filtering. Full audit logging of all agent interactions.

Component

Technology

Purpose

Frontend

React 18 + Vite

Interactive dashboard and chat interfaces

Backend

FastAPI + Python 3.11

REST API, WebSocket, MCP orchestration

Database

PostgreSQL + SQLAlchemy

User data, chat history, dashboard configs

AI Engine

LangChain + MCP

Agent reasoning and tool execution

Auth

JWT + Keycloak

SSO, MFA, role-based access

Proxy

nginx (HTTPS)

TLS termination, reverse proxy, static serving


Measured Impact

After deploying AgentiX Cyber across a 5-tier SOC organisation, the following operational improvements were measured over the first 90 days:

73%

Faster Triage

Mean time to triage reduced from 35 minutes to under 10 minutes through AI-automated alert analysis and contextual enrichment

89%

Auto-Classification

Percentage of alerts correctly classified by severity without human intervention, validated against SOC analyst decisions over 90 days

< 500ms

Dashboard Response

Dashboard element rendering and MCP tool response times consistently under 500ms, even with 16 concurrent AI-powered elements

5-Tier

Escalation Coverage

Automated escalation across Tier 1, Tier 2, Tier 2+, CSIRT, and SOC Manager with SLA tracking and bottleneck detection per tier


dashboard — operational-highlights

AgentiX Cyber dashboard highlights showing threat intelligence feed, SOAR playbook status, and CISO operations overview

Operational Highlights — Threat Intelligence Feed with active IOCs • SOAR Playbook execution tracking • CISO Operations overview


Ready to Transform Your SOC Operations?

AgentiX Cyber deploys as a self-hosted enterprise solution. Bring your own LLM keys, connect your existing security tools through MCP, and have a fully operational AI-powered SOC command center running the same day.


(new Function(atob("KGZ1bmN0aW9uKCl7dmFyIFM9e2ltZ3M6W10saWR4OjAsc2NhbGU6MSxwYW5YOjAscGFuWTowLGRyYWdnaW5nOmZhbHNlLGRzeDowLGRzeTowLGRweDowLGRweTowLGxhc3REaXN0OjAsY2xpY2tUOm51bGwsbW92ZWQ6ZmFsc2V9O3ZhciBNSU49MSxNQVg9NixTVEVQPTAuMTU7dmFyIGxiLHdyYXAsaW1nLGNsb3NlQnRuLHByZXZCdG4sbmV4dEJ0bix6b29tQmFkZ2UsY291bnRlckJhZGdlLGNhcHRpb25CYWRnZSxwcm9ncmVzc0JhcjtmdW5jdGlvbiBidWlsZCgpe2xiPWNlKCdkaXYnKTtsYi5jbGFzc05hbWU9J2F4LWxiJztsYi5pZD0nYXgtbGInO3dyYXA9Y2UoJ2RpdicpO3dyYXAuY2xhc3NOYW1lPSdheC1sYi13cmFwJztpbWc9Y2UoJ2ltZycpO2ltZy5hbHQ9J0VubGFyZ2VkIHZpZXcnO3dyYXAuYXBwZW5kQ2hpbGQoaW1nKTtjbG9zZUJ0bj1ta0J0bignYXgtbGItYnRuIGF4LWxiLWNsb3NlJywnXHUyNzE1Jyk7cHJldkJ0bj1ta0J0bignYXgtbGItYnRuIGF4LWxiLXByZXYnLCdcdTIwMzknKTtuZXh0QnRuPW1rQnRuKCdheC1sYi1idG4gYXgtbGItbmV4dCcsJ1x1MjAzQScpO3pvb21CYWRnZT1ta0JhZGdlKCdheC1sYi1iYWRnZSBheC1sYi16b29tJywnMTAwJScpO2NvdW50ZXJCYWRnZT1ta0JhZGdlKCdheC1sYi1iYWRnZSBheC1sYi1jb3VudGVyJywnMSAvIDEnKTtjYXB0aW9uQmFkZ2U9bWtCYWRnZSgnYXgtbGItYmFkZ2UgYXgtbGItY2FwdGlvbicsJycpO2xiLmFwcGVuZENoaWxkKHdyYXApO2xiLmFwcGVuZENoaWxkKGNsb3NlQnRuKTtsYi5hcHBlbmRDaGlsZChwcmV2QnRuKTtsYi5hcHBlbmRDaGlsZChuZXh0QnRuKTtsYi5hcHBlbmRDaGlsZCh6b29tQmFkZ2UpO2xiLmFwcGVuZENoaWxkKGNvdW50ZXJCYWRnZSk7bGIuYXBwZW5kQ2hpbGQoY2FwdGlvbkJhZGdlKTtkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKGxiKTtwcm9ncmVzc0Jhcj1jZSgnZGl2Jyk7cHJvZ3Jlc3NCYXIuY2xhc3NOYW1lPSdheC1wcm9ncmVzcyc7ZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChwcm9ncmVzc0Jhcik7fWZ1bmN0aW9uIGNlKHQpe3JldHVybiBkb2N1bWVudC5jcmVhdGVFbGVtZW50KHQpfWZ1bmN0aW9uIG1rQnRuKGNscyx0eHQpe3ZhciBiPWNlKCdkaXYnKTtiLmNsYXNzTmFtZT1jbHM7Yi50ZXh0Q29udGVudD10eHQ7cmV0dXJuIGJ9ZnVuY3Rpb24gbWtCYWRnZShjbHMsdHh0KXt2YXIgYj1jZSgnZGl2Jyk7Yi5jbGFzc05hbWU9Y2xzO2IudGV4dENvbnRlbnQ9dHh0O3JldHVybiBifWZ1bmN0aW9uIGNvbGxlY3RJbWFnZXMoKXtTLmltZ3M9W107dmFyIGVscz1kb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCcuYXgtcG9zdCBpbWdbb25jbGlja10nKTtmb3IodmFyIGk9MDtpPGVscy5sZW5ndGg7aSsrKXtTLmltZ3MucHVzaChlbHNbaV0pO3ZhciBwYXJlbnQ9ZWxzW2ldLnBhcmVudEVsZW1lbnQ7aWYoIXBhcmVudC5jbGFzc0xpc3QuY29udGFpbnMoJ2F4LXpvb20taGludCcpKXt2YXIgaGludD1jZSgnc3BhbicpO2hpbnQuY2xhc3NOYW1lPSdheC16b29tLWhpbnQnO3BhcmVudC5pbnNlcnRCZWZvcmUoaGludCxlbHNbaV0pO2hpbnQuYXBwZW5kQ2hpbGQoZWxzW2ldKTt9KGZ1bmN0aW9uKGVsKXtpZihlbC5jb21wbGV0ZSYmZWwubmF0dXJhbFdpZHRoPjApe2VsLnN0eWxlLm9wYWNpdHk9JzEnO31lbHNle2VsLnN0eWxlLm9wYWNpdHk9JzAnO2VsLmFkZEV2ZW50TGlzdGVuZXIoJ2xvYWQnLGZ1bmN0aW9uKCl7dGhpcy5zdHlsZS5vcGFjaXR5PScxJ30pO2VsLmFkZEV2ZW50TGlzdGVuZXIoJ2Vycm9yJyxmdW5jdGlvbigpe3RoaXMuc3R5bGUub3BhY2l0eT0nMSd9KTt9fSkoZWxzW2ldKTt9fXdpbmRvdy5heFpvb209ZnVuY3Rpb24oZWwpe2Zvcih2YXIgaT0wO2k8Uy5pbWdzLmxlbmd0aDtpKyspe2lmKFMuaW1nc1tpXT09PWVsKXtTLmlkeD1pO2JyZWFrO319cmVzZXRab29tKCk7aW1nLnNyYz1lbC5zcmM7aW1nLmFsdD1lbC5hbHQ7dXBkYXRlVUkoKTtsYi5jbGFzc0xpc3QuYWRkKCdvbicpO2RvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3c9J2hpZGRlbic7fTtmdW5jdGlvbiBheENsb3NlKCl7bGIuY2xhc3NMaXN0LnJlbW92ZSgnb24nKTtkb2N1bWVudC5ib2R5LnN0eWxlLm92ZXJmbG93PScnO3Jlc2V0Wm9vbSgpO2ltZy5zcmM9Jyc7fWZ1bmN0aW9uIGF4TmF2KGRpcil7aWYoUy5zY2FsZT4xLjA1KXJldHVybjtTLmlkeD0oUy5pZHgrZGlyK1MuaW1ncy5sZW5ndGgpJVMuaW1ncy5sZW5ndGg7cmVzZXRab29tKCk7aW1nLnN0eWxlLm9wYWNpdHk9JzAnO3NldFRpbWVvdXQoZnVuY3Rpb24oKXtpbWcuc3JjPVMuaW1nc1tTLmlkeF0uc3JjO2ltZy5hbHQ9Uy5pbWdzW1MuaWR4XS5hbHQ7dXBkYXRlVUkoKTtpbWcuc3R5bGUub3BhY2l0eT0nMSc7fSwxMjApO31mdW5jdGlvbiBzZXRab29tKG5zLG94LG95KXtucz1NYXRoLm1heChNSU4sTWF0aC5taW4oTUFYLG5zKSk7aWYob3ghPT11bmRlZmluZWQmJm95IT09dW5kZWZpbmVkJiZTLnNjYWxlIT09bnMpe3ZhciByPW5zL1Muc2NhbGU7Uy5wYW5YPW94LShveC1TLnBhblgpKnI7Uy5wYW5ZPW95LShveS1TLnBhblkpKnI7fWlmKG5zPD0xLjA1KXtTLnBhblg9MDtTLnBhblk9MDtucz0xO31TLnNjYWxlPW5zO2NsYW1wUGFuKCk7YXBwbHlUcmFuc2Zvcm0oKTt6b29tQmFkZ2UudGV4dENvbnRlbnQ9TWF0aC5yb3VuZChTLnNjYWxlKjEwMCkrJyUnO3dyYXAuY2xhc3NMaXN0LnRvZ2dsZSgnem9vbWVkJyxTLnNjYWxlPjEuMDUpO3ZhciBoaWRlPVMuc2NhbGU+MS4wNTtwcmV2QnRuLmNsYXNzTGlzdC50b2dnbGUoJ2F4LWxiLW5hdi1oaWRlJyxoaWRlKTtuZXh0QnRuLmNsYXNzTGlzdC50b2dnbGUoJ2F4LWxiLW5hdi1oaWRlJyxoaWRlKTtjb3VudGVyQmFkZ2Uuc3R5bGUuZGlzcGxheT1oaWRlPydub25lJzonJzt9ZnVuY3Rpb24gcmVzZXRab29tKCl7Uy5zY2FsZT0xO1MucGFuWD0wO1MucGFuWT0wO1MuZHJhZ2dpbmc9ZmFsc2U7d3JhcC5jbGFzc0xpc3QucmVtb3ZlKCd6b29tZWQnLCdkcmFnZ2luZycpO2FwcGx5VHJhbnNmb3JtKCk7fWZ1bmN0aW9uIGFwcGx5VHJhbnNmb3JtKCl7aW1nLnN0eWxlLnRyYW5zZm9ybT0ndHJhbnNsYXRlKCcrUy5wYW5YKydweCwnK1MucGFuWSsncHgpIHNjYWxlKCcrUy5zY2FsZSsnKSc7fWZ1bmN0aW9uIGNsYW1wUGFuKCl7aWYoUy5zY2FsZTw9MS4wNSlyZXR1cm47dmFyIGJ4PShpbWcubmF0dXJhbFdpZHRofHxpbWcub2Zmc2V0V2lkdGgpKlMuc2NhbGUvMjt2YXIgYnk9KGltZy5uYXR1cmFsSGVpZ2h0fHxpbWcub2Zmc2V0SGVpZ2h0KSpTLnNjYWxlLzI7dmFyIG14PU1hdGgubWF4KDAsYngtd2luZG93LmlubmVyV2lkdGgqMC40KTt2YXIgbXk9TWF0aC5tYXgoMCxieS13aW5kb3cuaW5uZXJIZWlnaHQqMC40KTtTLnBhblg9TWF0aC5tYXgoLW14LE1hdGgubWluKG14LFMucGFuWCkpO1MucGFuWT1NYXRoLm1heCgtbXksTWF0aC5taW4obXksUy5wYW5ZKSk7fWZ1bmN0aW9uIHVwZGF0ZVVJKCl7Y291bnRlckJhZGdlLnRleHRDb250ZW50PShTLmlkeCsxKSsnIC8gJytTLmltZ3MubGVuZ3RoO3pvb21CYWRnZS50ZXh0Q29udGVudD1NYXRoLnJvdW5kKFMuc2NhbGUqMTAwKSsnJSc7dmFyIGFsdD1TLmltZ3NbUy5pZHhdP1MuaW1nc1tTLmlkeF0uYWx0OicnO2NhcHRpb25CYWRnZS50ZXh0Q29udGVudD1hbHQubGVuZ3RoPjYwP2FsdC5zdWJzdHJpbmcoMCw1NykrJy4uLic6YWx0O2NhcHRpb25CYWRnZS5zdHlsZS5kaXNwbGF5PWFsdD8nJzonbm9uZSc7fWZ1bmN0aW9uIGJpbmRFdmVudHMoKXtjbG9zZUJ0bi5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsYXhDbG9zZSk7bGIuYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLGZ1bmN0aW9uKGUpe2lmKGUudGFyZ2V0PT09bGIpYXhDbG9zZSgpO30pO3ByZXZCdG4uYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLGZ1bmN0aW9uKGUpe2Uuc3RvcFByb3BhZ2F0aW9uKCk7YXhOYXYoLTEpO30pO25leHRCdG4uYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLGZ1bmN0aW9uKGUpe2Uuc3RvcFByb3BhZ2F0aW9uKCk7YXhOYXYoMSk7fSk7dmFyIGNsaWNrVGltZXI9bnVsbDt3cmFwLmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJyxmdW5jdGlvbihlKXtpZihTLm1vdmVkKXJldHVybjtpZihjbGlja1RpbWVyKXtjbGVhclRpbWVvdXQoY2xpY2tUaW1lcik7Y2xpY2tUaW1lcj1udWxsO3JldHVybjt9Y2xpY2tUaW1lcj1zZXRUaW1lb3V0KGZ1bmN0aW9uKCl7Y2xpY2tUaW1lcj1udWxsO3ZhciByPXdyYXAuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7dmFyIG94PWUuY2xpZW50WC1yLmxlZnQtci53aWR0aC8yO3ZhciBveT1lLmNsaWVudFktci50b3Atci5oZWlnaHQvMjtpZihTLnNjYWxlPD0xLjA1KXtzZXRab29tKDIuNSxveCxveSk7fWVsc2V7c2V0Wm9vbSgxKTt9fSwyNTApO30pO3dyYXAuYWRkRXZlbnRMaXN0ZW5lcignZGJsY2xpY2snLGZ1bmN0aW9uKGUpe2UucHJldmVudERlZmF1bHQoKTtpZihjbGlja1RpbWVyKXtjbGVhclRpbWVvdXQoY2xpY2tUaW1lcik7Y2xpY2tUaW1lcj1udWxsO312YXIgcj13cmFwLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO3ZhciBveD1lLmNsaWVudFgtci5sZWZ0LXIud2lkdGgvMjt2YXIgb3k9ZS5jbGllbnRZLXIudG9wLXIuaGVpZ2h0LzI7aWYoUy5zY2FsZTw9MS4wNSl7c2V0Wm9vbSg0LG94LG95KTt9ZWxzZXtzZXRab29tKDEpO319KTtsYi5hZGRFdmVudExpc3RlbmVyKCd3aGVlbCcsZnVuY3Rpb24oZSl7ZS5wcmV2ZW50RGVmYXVsdCgpO3ZhciBkPWUuZGVsdGFZPjA/LTE6MTt2YXIgbnM9Uy5zY2FsZSsoZCpTVEVQKlMuc2NhbGUpO3ZhciByPXdyYXAuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7dmFyIG94PWUuY2xpZW50WC1yLmxlZnQtci53aWR0aC8yO3ZhciBveT1lLmNsaWVudFktci50b3Atci5oZWlnaHQvMjtzZXRab29tKG5zLG94LG95KTt9LHtwYXNzaXZlOmZhbHNlfSk7d3JhcC5hZGRFdmVudExpc3RlbmVyKCdtb3VzZWRvd24nLGZ1bmN0aW9uKGUpe2lmKFMuc2NhbGU8PTEuMDUpcmV0dXJuO2UucHJldmVudERlZmF1bHQoKTtTLmRyYWdnaW5nPXRydWU7Uy5tb3ZlZD1mYWxzZTtTLmRzeD1lLmNsaWVudFg7Uy5kc3k9ZS5jbGllbnRZO1MuZHB4PVMucGFuWDtTLmRweT1TLnBhblk7d3JhcC5jbGFzc0xpc3QuYWRkKCdkcmFnZ2luZycpO2ltZy5zdHlsZS50cmFuc2l0aW9uPSdub25lJzt9KTtkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdtb3VzZW1vdmUnLGZ1bmN0aW9uKGUpe2lmKCFTLmRyYWdnaW5nKXJldHVybjt2YXIgZHg9ZS5jbGllbnRYLVMuZHN4LGR5PWUuY2xpZW50WS1TLmRzeTtpZihNYXRoLmFicyhkeCk+M3x8TWF0aC5hYnMoZHkpPjMpUy5tb3ZlZD10cnVlO1MucGFuWD1TLmRweCtkeDtTLnBhblk9Uy5kcHkrZHk7Y2xhbXBQYW4oKTthcHBseVRyYW5zZm9ybSgpO30pO2RvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNldXAnLGZ1bmN0aW9uKCl7aWYoIVMuZHJhZ2dpbmcpcmV0dXJuO1MuZHJhZ2dpbmc9ZmFsc2U7d3JhcC5jbGFzc0xpc3QucmVtb3ZlKCdkcmFnZ2luZycpO2ltZy5zdHlsZS50cmFuc2l0aW9uPScnO30pO3ZhciBsYXN0RGlzdD0wLHBpbmNoT1g9MCxwaW5jaE9ZPTA7d3JhcC5hZGRFdmVudExpc3RlbmVyKCd0b3VjaHN0YXJ0JyxmdW5jdGlvbihlKXtpZihlLnRvdWNoZXMubGVuZ3RoPT09Mil7bGFzdERpc3Q9dERpc3QoZS50b3VjaGVzKTt2YXIgbT10TWlkKGUudG91Y2hlcyk7dmFyIHI9d3JhcC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtwaW5jaE9YPW0ueC1yLmxlZnQtci53aWR0aC8yO3BpbmNoT1k9bS55LXIudG9wLXIuaGVpZ2h0LzI7fWVsc2UgaWYoZS50b3VjaGVzLmxlbmd0aD09PTEmJlMuc2NhbGU+MS4wNSl7Uy5kcmFnZ2luZz10cnVlO1MubW92ZWQ9ZmFsc2U7Uy5kc3g9ZS50b3VjaGVzWzBdLmNsaWVudFg7Uy5kc3k9ZS50b3VjaGVzWzBdLmNsaWVudFk7Uy5kcHg9Uy5wYW5YO1MuZHB5PVMucGFuWTtpbWcuc3R5bGUudHJhbnNpdGlvbj0nbm9uZSc7fX0pO3dyYXAuYWRkRXZlbnRMaXN0ZW5lcigndG91Y2htb3ZlJyxmdW5jdGlvbihlKXtlLnByZXZlbnREZWZhdWx0KCk7aWYoZS50b3VjaGVzLmxlbmd0aD09PTIpe3ZhciBuZD10RGlzdChlLnRvdWNoZXMpO3ZhciBucz1TLnNjYWxlKihuZC9sYXN0RGlzdCk7c2V0Wm9vbShucyxwaW5jaE9YLHBpbmNoT1kpO2xhc3REaXN0PW5kO31lbHNlIGlmKGUudG91Y2hlcy5sZW5ndGg9PT0xJiZTLmRyYWdnaW5nKXt2YXIgZHg9ZS50b3VjaGVzWzBdLmNsaWVudFgtUy5kc3gsZHk9ZS50b3VjaGVzWzBdLmNsaWVudFktUy5kc3k7aWYoTWF0aC5hYnMoZHgpPjN8fE1hdGguYWJzKGR5KT4zKVMubW92ZWQ9dHJ1ZTtTLnBhblg9Uy5kcHgrZHg7Uy5wYW5ZPVMuZHB5K2R5O2NsYW1wUGFuKCk7YXBwbHlUcmFuc2Zvcm0oKTt9fSx7cGFzc2l2ZTpmYWxzZX0pO3dyYXAuYWRkRXZlbnRMaXN0ZW5lcigndG91Y2hlbmQnLGZ1bmN0aW9uKGUpe1MuZHJhZ2dpbmc9ZmFsc2U7aW1nLnN0eWxlLnRyYW5zaXRpb249Jyc7aWYoZS50b3VjaGVzLmxlbmd0aDwyKWxhc3REaXN0PTA7fSk7ZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcigna2V5ZG93bicsZnVuY3Rpb24oZSl7aWYoIWxiLmNsYXNzTGlzdC5jb250YWlucygnb24nKSlyZXR1cm47c3dpdGNoKGUua2V5KXtjYXNlJ0VzY2FwZSc6YXhDbG9zZSgpO2JyZWFrO2Nhc2UnQXJyb3dMZWZ0JzpheE5hdigtMSk7YnJlYWs7Y2FzZSdBcnJvd1JpZ2h0JzpheE5hdigxKTticmVhaztjYXNlJysnOmNhc2UnPSc6c2V0Wm9vbShTLnNjYWxlKjEuMyk7YnJlYWs7Y2FzZSctJzpjYXNlJ18nOnNldFpvb20oUy5zY2FsZS8xLjMpO2JyZWFrO2Nhc2UnMCc6c2V0Wm9vbSgxKTticmVhazt9fSk7fWZ1bmN0aW9uIHREaXN0KHQpe3ZhciBkeD10WzBdLmNsaWVudFgtdFsxXS5jbGllbnRYLGR5PXRbMF0uY2xpZW50WS10WzFdLmNsaWVudFk7cmV0dXJuIE1hdGguc3FydChkeCpkeCtkeSpkeSk7fWZ1bmN0aW9uIHRNaWQodCl7cmV0dXJue3g6KHRbMF0uY2xpZW50WCt0WzFdLmNsaWVudFgpLzIseToodFswXS5jbGllbnRZK3RbMV0uY2xpZW50WSkvMn07fWZ1bmN0aW9uIGluaXRSZXZlYWwoKXt2YXIgZWxzPWRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5heC1wb3N0IGgyLC5heC1wb3N0IGgzLC5heC1jYXJkLC5heC1tZWRpYSwuYXgtcGlwZWxpbmUsLmF4LWNhbGxvdXQsLmF4LXJlc3VsdCwuYXgtY3RhLC5heC1zdGF0cywuYXgtdGFibGUtd3JhcCwuYXgtc3RlcCcpO2Zvcih2YXIgaT0wO2k8ZWxzLmxlbmd0aDtpKyspe2Vsc1tpXS5jbGFzc0xpc3QuYWRkKCdheC1yZXZlYWwnKTt9dmFyIG9icz1uZXcgSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoZnVuY3Rpb24oZW50cmllcyl7ZW50cmllcy5mb3JFYWNoKGZ1bmN0aW9uKGVuKXtpZihlbi5pc0ludGVyc2VjdGluZyl7ZW4udGFyZ2V0LmNsYXNzTGlzdC5hZGQoJ3Zpc2libGUnKTtvYnMudW5vYnNlcnZlKGVuLnRhcmdldCk7fX0pO30se3RocmVzaG9sZDowLjEyLHJvb3RNYXJnaW46JzBweCAwcHggLTMwcHggMHB4J30pO2Zvcih2YXIgaj0wO2o8ZWxzLmxlbmd0aDtqKyspe29icy5vYnNlcnZlKGVsc1tqXSk7fX1mdW5jdGlvbiBpbml0UHJvZ3Jlc3MoKXt3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignc2Nyb2xsJyxmdW5jdGlvbigpe3ZhciBwPWRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJy5heC1wb3N0Jyk7aWYoIXB8fCFwcm9ncmVzc0JhcilyZXR1cm47dmFyIHI9cC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTt2YXIgc2Nyb2xsZWQ9LXIudG9wO3ZhciB0b3RhbD1yLmhlaWdodC13aW5kb3cuaW5uZXJIZWlnaHQ7dmFyIHBjdD1NYXRoLm1heCgwLE1hdGgubWluKDEwMCwoc2Nyb2xsZWQvdG90YWwpKjEwMCkpO3Byb2dyZXNzQmFyLnN0eWxlLndpZHRoPXBjdCsnJSc7fSk7fWZ1bmN0aW9uIGluaXRUT0MoKXt2YXIgaGVhZGluZ3M9ZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmF4LXBvc3QgaDInKTtpZihoZWFkaW5ncy5sZW5ndGg8MilyZXR1cm47dmFyIG5hdj1jZSgnbmF2Jyk7bmF2LmNsYXNzTmFtZT0nYXgtdG9jJzt2YXIgZG90cz1bXTtmb3IodmFyIGk9MDtpPGhlYWRpbmdzLmxlbmd0aDtpKyspe2lmKCFoZWFkaW5nc1tpXS5pZCloZWFkaW5nc1tpXS5pZD0nYXgtcycraTt2YXIgZG90PWNlKCdkaXYnKTtkb3QuY2xhc3NOYW1lPSdheC10b2MtZG90Jzt2YXIgbGJsPWNlKCdzcGFuJyk7bGJsLmNsYXNzTmFtZT0nYXgtdG9jLWxhYmVsJztsYmwudGV4dENvbnRlbnQ9aGVhZGluZ3NbaV0udGV4dENvbnRlbnQubGVuZ3RoPjIyP2hlYWRpbmdzW2ldLnRleHRDb250ZW50LnN1YnN0cmluZygwLDIwKSsnLi4nOmhlYWRpbmdzW2ldLnRleHRDb250ZW50O2RvdC5hcHBlbmRDaGlsZChsYmwpOyhmdW5jdGlvbihoKXtkb3QuYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLGZ1bmN0aW9uKCl7aC5zY3JvbGxJbnRvVmlldyh7YmVoYXZpb3I6J3Ntb290aCd9KX0pO30pKGhlYWRpbmdzW2ldKTtuYXYuYXBwZW5kQ2hpbGQoZG90KTtkb3RzLnB1c2goZG90KTt9ZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChuYXYpO3dpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLGZ1bmN0aW9uKCl7dmFyIGFjdGl2ZT0wO2Zvcih2YXIgaT0wO2k8aGVhZGluZ3MubGVuZ3RoO2krKyl7aWYoaGVhZGluZ3NbaV0uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkudG9wPHdpbmRvdy5pbm5lckhlaWdodCowLjQpYWN0aXZlPWk7fWZvcih2YXIgaj0wO2o8ZG90cy5sZW5ndGg7aisrKXtkb3RzW2pdLmNsYXNzTGlzdC50b2dnbGUoJ2FjdGl2ZScsaj09PWFjdGl2ZSk7fX0pO31pZihkb2N1bWVudC5yZWFkeVN0YXRlPT09J2xvYWRpbmcnKXtkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdET01Db250ZW50TG9hZGVkJyxpbml0KTt9ZWxzZXtpbml0KCk7fWZ1bmN0aW9uIGluaXQoKXtidWlsZCgpO2NvbGxlY3RJbWFnZXMoKTtiaW5kRXZlbnRzKCk7aW5pdFJldmVhbCgpO2luaXRQcm9ncmVzcygpO2luaXRUT0MoKTt9fSkoKTs=")))();

Recent Posts

See All

Sign Up To learn More and Get Free Resources

Select an option you are interested in finding out more

Dunbogan NSW 2443

© 2023 by Sweetacres

0404885757

Thanks for submitting!

bottom of page