Skip to content

Golang project utilizing Forescout's eyeSegment product, to programmatically download data into csv, using Forescout's groups.

Notifications You must be signed in to change notification settings

infosecwatchman/eyeSegmentAPI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Overview

This project is an extension of the Forescout (https://forescout.com) eyeSegment product. Information about eyeSegment can be found on here: https://www.forescout.com/resources/forescout-eyesegment-datasheet/. This project is a GoLang project to programatically download data into a CSV, using Forescout's groups.

Go 1.16 was used to build this project.

Steps to build this

These steps assume you already have Go installed, if not please visit https://golang.org/dl/ to download and install the version need for your computer.

Edit the constants

There are 3 constants (FSusername, FSpassword, and FSApplianceFQDN) that need to be changed in the main.go file. (If no these variables are not set before running, the application will automatically securely prompt for them one by one.)

  • FSusername: Username to login to the API and needs to have access to eyeSegment. Since the password is stored, it is recommended to use a different user than and administrative account.

  • FSpassword: Password to login to the API, this is stored in the main.go.

  • FSApplianceFQDN: Fully qualified domain name of the Appliance you are connecting. Since the API is calling the data stored in the cloud, we need to use the Enterprise Manager to pull this information.

Optional - Encrypt your stored credentials

For this method you'll need to add 2 custom files *helper.yml* and *key.yml*. You will not need to modify the existing source code for this method to work. In the current implementation both the username and password are encrypted with the same private key.

NOTE: You can easily generate a private key and encrypted strings through the [aesGenerate32](https://github.com/Rldeckard/aesGenerate32) repository using [this application](https://github.com/Rldeckard/aesGenerate32/blob/7c9674d6244f073f3dfc5d8414eb0f8dbb1c2020/aesGenerate.exe)

helper.yml

```
helper:
  username:
  password:
  url:
```

key.yml

```
helper:
  key:
```

Build the application

From the folder this was downloaded from execute the command: go build -ldflags="-s -w" . which will build everything

NOTE: When the application is run the first time, it will automatically download a trimmed version of chromium into the current user's AppData directory. The chromium is used during the login process to capture the session cookies.

Syntax

The following commands can be used with eyeSegmentAPI.exe

  • -c Print Zone ID from given name

  • -d Get all destination zones from selected source

  • -f int Set how many days to look back into the data (default 3)

  • -fS string Specify server to connect to, will use the embeded FQDN if configured.

  • -n string Specify a Zone name to lookup

  • -oD Export data given destination. (Requires -n)

  • -oS Export data given source name. (Requiers -n)

  • -p string Specify password to connecto server with. Will use the embedded password if configured

  • -s Getall source zones from selected destination

  • -t flag to test functions

  • -u string Specify username to connect to servier with. Will use embedded username

About

Golang project utilizing Forescout's eyeSegment product, to programmatically download data into csv, using Forescout's groups.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages