segex
is a command line interface that lets you download FullStory "event" and "individual" data for specific segments via FullStory's Segment Export API. Use it to explore your FullStory Segment Export data locally.
segex
is not currently distributed on NPM, so you'll have to pull down this code and execute it locally with ./bin/run
. You'll need to have node JS installed on your machine to run segex
.
- Clone this repo and
npm install
in the root directory (the same directory that containspackage.json
) - Copy and paste
.config/fullstory-example.json
, rename it.config/fullstory.json
, and add your FullStory API key.
{
"API_KEY": "your key here",
"API_DOMAIN" : "https://api.fullstory.com"
}
Segments are created by saving FullStory searches. More information can be found on FullStory's help site.
Once you've created a segment in FullStory, you can find the segment ID in the URL when you're viewing the segment.
The ID in this example is "patrick@fullstory.com:4241245858598272"
https://app.staging.fullstory.com/ui/thefullstory.com/segments/patrick@fullstory.com:4241245858598272/people/0
The ID in this example is "rageClicks"
https://app.staging.fullstory.com/ui/thefullstory.com/segments/rageClicks/people/0
$ ./bin/run export
$ ./bin/run --help export
USAGE
$ segex export [ID]
ARGUMENTS
ID [default: everyone] segment id of the segment to be downloaded from FullStory
OPTIONS
-d, --directory=directory [default: ./data] location of the output directory
-e, --end=end end of query: mm/dd/yyyy, defaults to yesterday (the most recent day that data is available)
-f, --format=JSON|CSV [default: FORMAT_CSV]
-h, --help show CLI help
-i, --interval=5m|10m|15m|30m|1h|2h|3h|4h|24h [default: 15m] time increments for each downloaded file
-l, --fields=fields a comma-delimited list of fields to select - for example: EventStart,EventType. Find the Data Export data
dictionary of all fields here: https://developer.fullstory.com/get-data-export
-s, --start=start start of query: mm/dd/yyyy, defaults to 30 days in the past
-t, --type=event|individual [default: TYPE_EVENT]
--type event
returns event records: each row is an individual event recorded by FullStory. You can find the data dictionary for event records at https://developer.fullstory.com/get-data-export.--type individual
returns individual records: each row represents an identified user with some aggregate metrics about their behavior on your site.--interval
controls how large your file sizes are: the smaller the interval the smaller the file size, and the greater the number of files.
The CLI creates files in the data
directory at the root of this project by default. The directory structure is:
data
├── {segment id}
│ └── {segment type event|individual}
│ └── {date}
│ ├── {segment export file csv|json}
./bin/run export adam@fullstory.com:4721245852598272 -s 4/6/2020 -e 4/8/2020 -t event
outputs to
data/adam@fullstory.com:4721245852598272/event
./bin/run export adam@fullstory.com:4721245852598272 -s 4/6/2020 -e 4/8/2020 -t individual
outputs to
data/adam@fullstory.com:4721245852598272/individual
./bin/run export
outputs to data/everyone/event