badarsebard / terraform-provider-xsoar

Apache License 2.0
9 stars 3 forks source link

Error: Creating Account Integration #9

Closed Xboarder56 closed 1 year ago

Xboarder56 commented 1 year ago

I’m getting a generic xsoar 200 error when trying to make an account level integration identical to this resource example below. Removing account and letting it create at the master tenant however works just fine.

xsoar build 6.10 - multi tenant

resource "xsoar_integration_instance" "threatcentral1" {
  name               = "threatcentral_instance_1"
  integration_name   = "threatcentral"
  propagation_labels = ["all"]
  account            = xsoar_account.acc1.name
  config = {
    APIAddress : "https://threatcentral.io/tc/rest/summaries"
    APIKey : "123"
    useproxy : "true"
  }
}
badarsebard commented 1 year ago

Can you post the output of the error?

Xboarder56 commented 1 year ago

It's just the generic API error you typically get from XSOAR when making a bad request. I see this sometimes in some python scripts I make that utilize the API when something is missing like in the payload/bad API endpoint/method.

Pulled this by enabling debug for terraform and running the apply. Typically without debug it will just loop until it times out trying the request over and over.

2023-02-15T18:18:34.652-0800 [DEBUG] provider.terraform-provider-xsoar_v0.3.61.exe: 2023/02/15 18:18:34 code: 200 status: 200 OK headers: map[Accept-Ranges:[bytes] Content-Type:[text/html; charset=utf-8] Date:[Thu, 16 Feb 2023 02:18:34 GMT] Last-Modified:[Thu, 01 Dec 2022 10:34:58 GMT] Server-Timing:[169] Strict-Transport-Security:[max-age=10886400000000000; includeSubDomains] Vary:[Accept-Encoding] X-Content-Type-Options:[nosniff] X-Frame-Options:[DENY] X-Xss-Protection:[1; mode=block]] body: <!doctype html><html lang="en"><head><title>Cortex XSOAR</title><meta charset="utf-8"><meta name="description" content="Cortex XSOAR"><meta name="keywords" content="security,incident response,attack playback,forensics"><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1"><link rel="shortcut icon" href="/favicon.ico?v=1669890354308"><link href="/assets/light-bundle-1669890354308.css?v=1669890354308" rel="stylesheet"></head><body><div id="app"></div><script src="/assets/light-bundle-1669890354308.js?v=1669890354308"></script></body></html>

2023-02-15T18:18:34.652-0800 [DEBUG] provider.terraform-provider-xsoar_v0.3.61.exe: 2023/02/15 18:18:34 undefined response type

badarsebard commented 1 year ago

So the HTML content looks like the redirect you sometimes get with a bad API endpoint. Have you verified the host you're testing on is enabled for MT and the account is there and active? You should also try grabbing the payload in dev tools after creating an integration in the UI. There may be some missing parameters and XSOAR doesn't know what to do with itself. My team is currently using this in production with multi-tenant integrations without issue.

Xboarder56 commented 1 year ago

Are you running 6.10 on any of those MT installations wondering if they tweaked the call at all? It feels like a provider error because the below main.tf file works fine as soon as I remove the account parameter (nothing else changes).

I'm using the same version of the provider to create the accounts just fine (the accounts are on the same XSOAR box so no HA group).

main.tf example of what I'm doing with it failing:

terraform {
  required_version = "~> 1.3.0"

  required_providers {
    xsoar = {
      source  = "badarsebard/xsoar"
      version = "0.3.61"
    }
  }
}

provider "xsoar" {
  main_host = var.host
  api_key   = var.xsoar_api_key
  insecure  = true
}

resource "xsoar_account" "tt1" {
  name            = "TT1"
  account_roles   = ["Administrator"]
  host_group_name = ""
}

resource "xsoar_integration_instance" "example" {
  name               = "foo"
  integration_name   = "threatcentral"
  propagation_labels = ["all"]
  account = xsoar_account.tt1.name
  config = {
    APIAddress : "https://threatcentral.io/tc/rest/summaries"
    APIKey : "123"
    useproxy : "true"
  }
}

Trace Error:

xsoar_integration_instance.example1: Still creating... [7m30s elapsed]
2023-02-15T19:08:16.317-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:16.317-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
2023-02-15T19:08:21.322-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
2023-02-15T19:08:21.322-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:25.319-0800 [DEBUG] provider.terraform-provider-xsoar_v0.3.61.exe: 2023/02/15 19:08:25 code: 200 status: 200 OK headers: map[Accept-Ranges:[bytes] Content-Type:[text/html; charset=utf-8] Date:[Thu, 16 Feb 2023 03:08:25 GMT] Last-Modified:[Thu, 01 Dec 2022 10:34:58 GMT] Server-Timing:[169] Strict-Transport-Security:[max-age=10886400000000000; includeSubDomains] Vary:[Accept-Encoding] X-Content-Type-Options:[nosniff] X-Frame-Options:[DENY] X-Xss-Protection:[1; mode=block]] body: <!doctype html><html lang="en"><head><title>Cortex XSOAR</title><meta charset="utf-8"><meta name="description" content="Cortex XSOAR"><meta name="keywords" content="security,incident response,attack playback,forensics"><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1"><link rel="shortcut icon" href="/favicon.ico?v=1669890354308"><link href="/assets/light-bundle-1669890354308.css?v=1669890354308" rel="stylesheet"></head><body><div id="app"></div><script src="/assets/light-bundle-1669890354308.js?v=1669890354308"></script></body></html>
2023-02-15T19:08:25.319-0800 [DEBUG] provider.terraform-provider-xsoar_v0.3.61.exe: 2023/02/15 19:08:25 undefined response type
xsoar_integration_instance.example1: Still creating... [7m40s elapsed]
2023-02-15T19:08:26.335-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
2023-02-15T19:08:26.335-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:31.349-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:31.350-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
xsoar_integration_instance.example1: Still creating... [7m50s elapsed]
2023-02-15T19:08:36.353-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
2023-02-15T19:08:36.353-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:41.363-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:41.363-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
xsoar_integration_instance.example1: Still creating... [8m0s elapsed]
2023-02-15T19:08:46.373-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
2023-02-15T19:08:46.373-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:51.384-0800 [TRACE] dag/walk: vertex "root" is waiting for "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)"
2023-02-15T19:08:51.385-0800 [TRACE] dag/walk: vertex "provider[\"registry.terraform.io/badarsebard/xsoar\"] (close)" is waiting for "xsoar_integration_instance.example1"
Xboarder56 commented 1 year ago

Manually creating the integration with dev tools (chrome):

Request URL: https://$IP/acc_TT1/settings/integration
Request Method: PUT

{"name":"foo","id":"","engine":"","engineGroup":"","defaultIgnore":false,"configuration":{"display":"Threat Central","canGetSamples":false,"packName":"","itemVersion":"","brand":"","modified":"2023-02-16T00:32:36.357237722Z","isPasswordProtected":true,"shouldCommit":false,"hidden":false,"fromServerVersion":"","name":"threatcentral","detailedDescription":"For an API key, go to your user profile at your ThreatCentral account, and press Manage API Keys, where you can generate a new API key.","definitionId":"","vcShouldKeepItemLegacyProdMachine":false,"commitMessage":"","vcShouldIgnore":false,"packID":"","configuration":[{"hiddenUsername":false,"display":"Server URL (e.g. https://192.168.0.1)","hiddenPassword":false,"hidden":false,"name":"APIAddress","info":"","defaultValue":"https://threatcentral.io/tc/rest/summaries","type":0,"displayPassword":"","options":null,"required":true,"value":"https://threatcentral.io/tc/rest/summaries","hasvalue":true},{"hiddenUsername":false,"display":"API Key","hiddenPassword":false,"hidden":false,"name":"APIKey","info":"","defaultValue":"","type":4,"displayPassword":"","options":null,"required":true,"value":"asdf","hasvalue":true},{"hiddenUsername":false,"display":"Do not validate server certificate (insecure)","hiddenPassword":false,"hidden":false,"name":"tcIgnoreTLS","info":"","defaultValue":"","type":8,"displayPassword":"","options":null,"required":false},{"hiddenUsername":false,"display":"Use system proxy settings","hiddenPassword":false,"hidden":false,"name":"useproxy","info":"","defaultValue":"true","type":8,"displayPassword":"","options":null,"required":false,"value":"true","hasvalue":true}],"version":1,"icon":"tc.png","toServerVersion":"","id":"threatcentral","image":"","cacheVersn":0,"description":"Get actionable threat analysis and intelligence from HPE’s cloud-based, standards-compliant sharing platform","category":"Data Enrichment & Threat Intelligence","prevName":"threatcentral","integrationScript":null,"instances":[]},"enabled":"true","propagationLabels":["all"],"data":[{"name":"APIAddress","value":"https://threatcentral.io/tc/rest/summaries","hasvalue":true,"type":0,"defaultValue":"","required":true,"options":null},{"name":"APIKey","value":"asdf","hasvalue":true,"type":4,"defaultValue":"","required":true,"options":null},{"name":"tcIgnoreTLS","type":8,"defaultValue":"","required":false,"options":null},{"name":"useproxy","value":"true","hasvalue":true,"type":8,"defaultValue":"","required":false,"options":null}],"brand":"threatcentral","canSample":false,"category":"Data Enrichment & Threat Intelligence","version":0,"isIntegrationScript":false,"isLongRunning":false,"passwordProtected":false,"mappingId":"","incomingMapperId":"","outgoingMapperId":"","resetContext":false,"integrationLogLevel":""}
Xboarder56 commented 1 year ago

@badarsebard so I spent time and sent the traffic through a proxy. It's a bug with the API call having a double slashes. //. Most of the calls with a double slash are auto redirected but at the tenant level I get a /#/404 redirection. Making a proxy rule to find and replace the double slashes allows terraform to complete the request.

Request Payload (Tenant Level Integration):

PUT //acc_TT1/settings/integration HTTP/1.1
Host: 192.168.50.50
User-Agent: OpenAPI-Generator/1.0.0/go
Content-Length: 8149
Accept: application/json
Accept: application/json,*/*
Authorization: 57E827B989A1FC1C3D2FF77186A479DE
Content-Type: application/json
Accept-Encoding: gzip, deflate
Connection: close

{"brand":"threatcentral","canSample":false,"category":"Data Enrichment \u0026 Threat Intelligence","configuration":{"brand":"","cacheVersn":0,"canGetSamples":false,"category":"Data Enrichment \u0026 Threat Intelligence","commitMessage":"","configuration":[{"defaultValue":"https://threatcentral.io/tc/rest/summaries","display":"Server URL (e.g. https://192.168.0.1)","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"APIAddress","options":null,"required":true,"type":0,"value":"https://threatcentral.io/tc/rest/summaries"},{"defaultValue":"","display":"API Key","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"APIKey","options":null,"required":true,"type":4,"value":"123"},{"defaultValue":"","display":"Do not validate server certificate (insecure)","displayPassword":"","hasvalue":false,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"tcIgnoreTLS","options":null,"required":false,"type":8},{"defaultValue":"true","display":"Use system proxy settings","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"useproxy","options":null,"required":false,"type":8,"value":"false"}],"definitionId":"","description":"Get actionable threat analysis and intelligence from HPE’s cloud-based, standards-compliant sharing platform","detailedDescription":"For an API key, go to your user profile at your ThreatCentral account, and press Manage API Keys, where you can generate a new API key.","display":"Threat Central","fromServerVersion":"","hidden":false,"icon":"tc.png","id":"threatcentral","image":"","integrationScript":null,"isPasswordProtected":true,"itemVersion":"","modified":"2023-02-08T01:36:42.806157503Z","name":"threatcentral","packID":"","packName":"","prevName":"threatcentral","shouldCommit":false,"toServerVersion":"","vcShouldIgnore":false,"vcShouldKeepItemLegacyProdMachine":false,"version":1},"data":[{"defaultValue":"https://threatcentral.io/tc/rest/summaries","display":"Server URL (e.g. https://192.168.0.1)","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"APIAddress","options":null,"required":true,"type":0,"value":"https://threatcentral.io/tc/rest/summaries"},{"defaultValue":"","display":"API Key","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"APIKey","options":null,"required":true,"type":4,"value":"123"},{"defaultValue":"","display":"Do not validate server certificate (insecure)","displayPassword":"","hasvalue":false,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"tcIgnoreTLS","options":null,"required":false,"type":8},{"defaultValue":"true","display":"Use system proxy settings","displayPassword":"","hasvalue":true,"hidden":false,"hiddenPassword":false,"hiddenUsername":false,"info":"","name":"useproxy","options":null,"required":false,"type":8,"value":"false"}],"defaultIgnore":false,"enabled":"true","incomingMapperId":"","isIntegrationScript":false,"mappingId":"","name":"foo","propagationLabels":null,"version":-1}

Response Payload:

HTTP/1.1 303 See Other
Location: /#/404
Server-Timing: 167
Strict-Transport-Security: max-age=10886400000000000; includeSubDomains
Vary: Accept-Encoding
X-Content-Type-Options: nosniff
X-Frame-Options: DENY
X-Xss-Protection: 1; mode=block
Date: Thu, 16 Feb 2023 18:32:42 GMT
Content-Length: 0
Connection: close
Xboarder56 commented 1 year ago

Example of some of the other double slash calls that get properly redirected by XSOAR. I'm not sure if this is a regression in the latest server build but this is 100% the issue of why the integration creation is failing at the tenant level.

It looks like lots of requests are done with double slashes in the provider. Example of a few below.

image

Xboarder56 commented 1 year ago

So checking my XSOAR host value again. I left a trailing slash which is exactly why I'm getting the double slashes. Closing this as resolved but leaving it for others to reference potentially.

badarsebard commented 1 year ago

Ah interesting. Thanks for digging into it. I'll add into my notes this behavior. Next release I'll put in something to strip any trailing slashes off the host value. Thanks.