Git-based version control for Cortex platform security configurations.
gcgit is a command-line tool that synchronises security configurations between Palo Alto Networks Cortex platform instances and local Git repositories. It pulls configurations from Cortex XSIAM, Cortex Cloud AppSec, Agent Configurations, and Cortex Cloud Workload Protection (CWP) APIs, stores them as YAML files, and tracks all changes through Git.
What it does:
- Pulls security configurations from Cortex platform instances via REST APIs
- Stores each configuration object as an individual YAML file
- Commits all changes to a local Git repository with descriptive messages
- Supports multiple Cortex platform modules from a single tool
- Compares local configurations against remote platform state
Why it exists:
Cortex platform instances have no built-in version control for security configurations. gcgit fills this gap by providing a Git-based audit trail and change tracking mechanism that works across multiple Cortex modules and platform instances.
- Multi-module support for Cortex XSIAM, Cortex Cloud AppSec, Agent Configurations, and Cortex Cloud Workload Protection (CWP)
- 29 content types across four modules
- Automatic Git commits with change tracking and audit trail
- Deterministic YAML serialisation with idempotent re-pulls (server-bumped timestamp fields are excluded so unchanged objects produce no diffs)
- Plugin architecture for adding new Cortex modules
- Environment variable expansion for secure credential management
- File locking to prevent concurrent operations
- Self-contained binary using libgit2 (no external Git installation required)
- Five reusable pull strategies: JsonCollection, Paginated, OffsetPaginated, ScriptCode, ZipArtifact
- Graceful handling of licence-gated endpoints (a 403 on an optional endpoint is reported as a warning and the rest of the pull continues)
| Content Type | Description |
|---|---|
| dashboards | Security dashboards and visualisations |
| biocs | Behavioural indicators of compromise |
| correlation_searches | Detection and correlation rules |
| widgets | Dashboard components |
| authentication_settings | SSO and authentication configurations |
| scripts | Automation scripts (two-step code retrieval) |
| scheduled_queries | XQL scheduled queries |
| xql_library | Reusable XQL query library |
| rbac_users | Role-based access control users |
| datasets | XQL dataset definitions (runtime/usage stats excluded) |
| Content Type | Description |
|---|---|
| applications | Application inventory and configuration |
| policies | Security policies for threat detection |
| rules | Custom security rules |
| repositories | Code repository configurations |
| integrations | Third-party integrations |
| application_configuration | Singleton application configuration |
| application_criteria | Application filtering criteria |
Each Agent Configurations content type is a global singleton that produces exactly one settings.yaml file.
| Content Type | Description |
|---|---|
| content_management | Content update settings |
| agent_status | Agent status reporting configuration |
| auto_upgrade | Automatic agent upgrade settings |
| wildfire_analysis | WildFire analysis configuration |
| informative_btp_issues | Informative BTP issue settings |
| cortex_xdr_log_collection | XDR log collection configuration |
| action_center_expiration | Action Center expiration policy |
| critical_environment_versions | Critical environment version pinning |
| advanced_analysis | Advanced analysis configuration |
| endpoint_administration_cleanup | Endpoint administration cleanup policy |
| Content Type | Description |
|---|---|
| policies | CWP policies (server-bumped createdAt/modifiedAt excluded for stable diffs) |
| registry_onboarding | Registry onboarding instances (requires the Cortex Cloud Runtime Security add-on; returns 403 and is skipped with a warning on tenants without it) |
Build from source:
cargo build --release
./target/release/gcgit --versionCreate an instance:
gcgit init --instance productionThis creates the following structure:
production/
+-- .git/
+-- config.toml
+-- xsiam/
| +-- dashboards/
| +-- correlation_searches/
| +-- biocs/
| +-- widgets/
| +-- authentication_settings/
| +-- scripts/
| +-- scheduled_queries/
| +-- xql_library/
| +-- rbac_users/
| +-- datasets/
+-- appsec/
| +-- applications/
| +-- policies/
| +-- rules/
| +-- repositories/
| +-- integrations/
| +-- application_configuration/
| +-- application_criteria/
+-- agent/
| +-- content_management/
| +-- agent_status/
| +-- auto_upgrade/
| +-- wildfire_analysis/
| +-- informative_btp_issues/
| +-- cortex_xdr_log_collection/
| +-- action_center_expiration/
| +-- critical_environment_versions/
| +-- advanced_analysis/
| +-- endpoint_administration_cleanup/
+-- cwp/
+-- policies/
+-- registry_onboarding/
Configure API access in production/config.toml:
[modules.xsiam]
enabled = true
fqdn = "api-production.xdr.eu.paloaltonetworks.com"
api_key = "${XSIAM_API_KEY}"
api_key_id = "${XSIAM_API_KEY_ID}"
[modules.appsec]
enabled = true
fqdn = "api-production.xdr.eu.paloaltonetworks.com"
api_key = "${APPSEC_API_KEY}"
api_key_id = "${APPSEC_API_KEY_ID}"
[modules.agent]
enabled = true
fqdn = "api-production.xdr.eu.paloaltonetworks.com"
api_key = "${AGENT_API_KEY}"
api_key_id = "${AGENT_API_KEY_ID}"
[modules.cwp]
enabled = true
fqdn = "api-production.xdr.eu.paloaltonetworks.com"
api_key = "${CWP_API_KEY}"
api_key_id = "${CWP_API_KEY_ID}"Environment variables are expanded automatically using ${VARIABLE} syntax. gcgit also recognises DEMISTO_BASE_URL, DEMISTO_API_KEY, and XSIAM_AUTH_ID as fallback variables for cross-project compatibility.
Pull configurations:
gcgit xsiam pull --instance production
gcgit appsec pull --instance production
gcgit agent pull --instance production
gcgit cwp pull --instance productionAll changes are automatically committed to the local Git repository.
| Command | Description |
|---|---|
| init --instance NAME | Create a new instance directory with module subdirectories |
| xsiam pull --instance NAME | Pull all XSIAM configurations from the platform |
| xsiam diff --instance NAME | Show differences between local and remote |
| xsiam test --instance NAME | Test API connectivity to the XSIAM module |
| appsec pull --instance NAME | Pull all AppSec configurations from the platform |
| appsec diff --instance NAME | Show differences between local and remote |
| appsec test --instance NAME | Test API connectivity to the AppSec module |
| agent pull --instance NAME | Pull all Agent Configurations singletons from the platform |
| agent diff --instance NAME | Show differences between local and remote |
| agent test --instance NAME | Test API connectivity to the Agent module |
| cwp pull --instance NAME | Pull all CWP configurations from the platform |
| cwp diff --instance NAME | Show differences between local and remote |
| cwp test --instance NAME | Test API connectivity to the CWP module |
Each module supports the same set of operations (pull, diff, test) through a consistent interface.
| Status | Operations |
|---|---|
| Production-ready | pull, diff, test |
| Under development | push, delete, deploy |
Push operations are disabled pending thorough testing to prevent accidental modification of production configurations.
Each instance has a config.toml file with per-module credential blocks:
[modules.xsiam]
enabled = true
fqdn = "api-instance.xdr.region.paloaltonetworks.com"
api_key = "${XSIAM_API_KEY}"
api_key_id = "${XSIAM_API_KEY_ID}"
[modules.appsec]
enabled = false
fqdn = "api-instance.xdr.region.paloaltonetworks.com"
api_key = "${APPSEC_API_KEY}"
api_key_id = "${APPSEC_API_KEY_ID}"
[modules.agent]
enabled = false
fqdn = "api-instance.xdr.region.paloaltonetworks.com"
api_key = "${AGENT_API_KEY}"
api_key_id = "${AGENT_API_KEY_ID}"
[modules.cwp]
enabled = false
fqdn = "api-instance.xdr.region.paloaltonetworks.com"
api_key = "${CWP_API_KEY}"
api_key_id = "${CWP_API_KEY_ID}"Set enabled = false to disable a module whilst keeping its configuration. Each module can use different API credentials and even different platform FQDNs.
Store API keys in environment variables rather than directly in config.toml to prevent credentials from being committed to Git.
If the primary environment variables are empty or unset, gcgit checks these fallback variables for cross-project compatibility:
| Primary Field | Fallback Variable | Notes |
|---|---|---|
| fqdn | DEMISTO_BASE_URL | https:// prefix and trailing slash are stripped automatically |
| api_key | DEMISTO_API_KEY | Used as-is |
| api_key_id | XSIAM_AUTH_ID | Used as-is |
When a fallback is used, gcgit prints an informational message to the console.
Configurations are stored as individual YAML files in a structured hierarchy:
instance-name/
+-- config.toml
+-- module-name/
+-- content-type/
+-- object-id.yaml
Each YAML file contains the complete configuration for one object. Changes to individual objects produce clean, readable Git diffs. Singleton content types (Agent Configurations, AppSec application_configuration) produce a single settings.yaml file per content type.
Requirements:
- Rust 1.70 or later
- Cortex XSIAM, Cortex Cloud AppSec, Agent Configurations, and/or Cortex Cloud Workload Protection API access
- API key and key ID for each module
No external Git installation is required. gcgit uses libgit2 for all Git operations.
git clone <repository-url>
cd gcgit
cargo build --release
./target/release/gcgit --versionThe compiled binary is self-contained with no runtime dependencies.
gcgit --help
gcgit xsiam --help
gcgit appsec --help
gcgit agent --help
gcgit cwp --helpThis project is licensed under the GNU Affero General Public License v3.0 or later (AGPL-3.0-or-later). See the LICENSE file for the full licence text.
