View on GitHub

Airports Common Information Model for Splunk

A guide on how to implement Splunk for operational use cases within airports

How to use the CIM

The Splunk4Airports CIM has been compiled using multiple data sources in order to gain a uniformed approach to Airport data. You can see the data sources used in the About page.

How does it work

The first step is to identify the various values for the fields listed in the CIM. For example; in the Airfield > Aircraft dataset You’ll see the following:

Dataset Name Field Name Data Type Description Examples
Airfield flightNumber int(4) The numerical flight number of the aircraft 1234
Airfield airline String The IATA code for the operating airline EZY, DY, AA
Airfield FQFC String Fully Qualified Flight Code EZY1234

These are the first three fields I would start with. So if you connect directly to your AODB through DBConnect, you simply need to find these fields in your dataset and alias them to the CIM field name above. Making sure you conform to the data type. For the most part, data types are free form strings. But all timestamps, unless stated otherwise are in epoch.

All field names are camelCase - Exluding acronyms, which are all capitals.

The flightUID

In some instances, your data may not give a unique identifier to flights. The flightUID is important because it allows you to run analysis over multiple days where the same FQFC exists. For example, if you search for On-Time Departure information across multiple days using the FQFC, you’ll have a hard time differentiating the same flight on different days. If you don’t have a flightUID, you can create one using an eval

| eval flightUID=sha1(FQFC. "" .SOBT)

Time

Operational time stamps

Airport data contains a huge amount of operational timestamps. All the way from Scheduled Off Block Time(SOBT) to Actual Take Off Time(ATOT).

All timestamps, unless stated otherwise are in epoch. Epoch allows you to perform simple calculations on multiple timestamps

So in the case of making your timestamps CIM compliant, you may need to apply strptime to them using a calulated field

Lets say, in your data, your SOBT is called sch_ofb and is presented like this: 31/12/2020T09:15:00

You’d need to create a calculated field using strptime and call it SOBT. See image: Calculated Field

Timezones

Ensure your data is in the timezone that you expect it to be in. Many European Airports use Zulu time as a standard in their Airport Operational Database(AODB). If this is the case, ensure you’re aware of what timezones you are using so you can adjust your Splunk settings accordingly. Inaccurate timezones can lead to unexpected search results.

Which time should I use for _time?

This is up to you, I have seen some airports use SOBT, but the most success I have seen is where lastUpdated is used as _time.

If lastUpdated is used as the time field. It’s important to add an _SOBT filter to your searches, to ensure you’re only searching flights where the SOBT falls within the time picker. The best way I have found to do this is by adding addinfo and using where like in this example:

index="flights"
| addinfo 
| where (SOBT>info_min_time AND SOBT<info_max_time)

You will see, the Splunk4Airports app expects lastUpdated to be used as _time, and uses syntax like this:

stats latest(x), latest(y) by flightUid

This ensures you retrieve the latest value for fields X and Y, but in effect, it’s also deduping by the flightUid.

Lookups

Various lookups are included in the Splunk4Airports App. The lookups are there to help enrich your data. For example, in your data you’ll no doubt have an origin and destination airport. The airports.csv lookup includes all international airports, so you can use the three letter IATA code for the airport, and it will output valuable information, including latitude and longitude. Thus allowing you to create visually stunning geo-maps. Lookups have been used from open source repositories. For a list of data sources, see the about page. Due to its size, the Splunk4Airports app has a search included that inputs the airports.csv file into the KV store, allowing for faster retrieval.

Baggage

As there is no know universal schema for overall baggage processing (The are multiple, smaller schemas for different parts of the baggage journey). The CIM was created with the most commonly used fields between them.

Here’s an acronym buster for the types of data you may see in your Airport:

Acronym Meaning
BTM Baggage Transfer Message. Usually sent from the inbound carrier to the outbound carrier to inform them about the bags that will be transferred.
BSM Baggage Source Message. These messages are generated for every single back that is checked in at the airport.
BPM Bagagge Processed Message. BPMs are send locally in the airport whenever a bag has reached a different stage of processing. i.e The bag has cleared security screening, or it’s been loaded onto a ULD
BUM Baggage Unload Message. This message is an instruction to the handler to unload a bag from an aircraft. Typically if the passenger did not show up to the gate.
BNS Baggage Not Seen. The passenger is present for the flight, but the bag is not. The bag has missed the connection. Sometimes referred to as an SSB, or Short-Shipped Bag

The most valuable of these messages are BSMs and BPMs as they will allow you to intricately measure the bag volumes and journeys.

Baggage messages can come in a variety of formats and accessed from multiple systems. One example of a messaging is IATA Type B. Refer to the IATA Passenger Services Resolution Manual.

A note on Type B Messaging: It’s usually better to gain the BSM type information for another system, rather than directly from the source. This is because these messages contain no timestamps in their schema, whereas, it’s likely the intermediate system will record a timestamp

You’ll likely have lots of sources for baggage data, and 2 of the key generic ones are Baggage Handling System (BHS) and Baggage Reconciliation System (BRS). These mainly differ in the following way; The BHS is usually responsible for the automatic movement of baggage from point A to B through multiple levels and security screening points. The BRS is generally wherever bags are manually sorted and scanned, like at the end of a baggage chute or when being loaded into an Aircraft or ULD. The Splunk App for Airports assumes you have BHS type data.

Contents
Home