l-four/notam

Parse ICAO formatted NOTAM messages.

1.0.0 2023-02-15 10:47 UTC

This package is not auto-updated.

Last update: 2025-06-18 21:46:52 UTC


README

Demo

https://notam-reader.kyahrindlisbacher.com/

Install

composer require l-four/notam

Usage

First we tokenize the notam string into an array of tokens. Then it's possible to parse the tokens into a Notam object.

This is the basic usage:

require  __DIR__ .  '\vendor\autoload.php';

$notam_string = 'J2187/22 NOTAMN' .
                'Q) YBBB/QMXLC/IV/M/A/000/999/2738S15243E005' . 
                'A) YAMB' .
                'B) 2207062200 C) 2207070400' .
                'E) TWY Z NOT AVBL DUE PARKED ACFT';

$tokens = \LFour\notam\NotamFunctions::tokenize_notam($notam_string);
print_r($tokens);

This will output an array of tokens:

Array
(
    [0] => LFour\notam\TOKEN Object
        (
            [type] => LFour\notam\NotamToken Enum
                (
                    [name] => IDENT_SERIES
                )

            [start] => 0
            [end] => 1
        )
        ... etc
)

Each token represents a part of the notam string.

The type enum is used to identify the token type.

The value of a token can be retrieved by using the substr() function.

  $token = $tokens[0];
  $value = substr($notam_string, $token->start, $token->end - $token->start);
  print_r($value);

Output: J

For more ergonomic usage. The tokens can be parsed into a Notam object.

$notam = \LFour\notam\NotamFunctions::object_from_tokens($tokens, $notam_string);
print_r($notam->ident->series);

Output: J

Token Type Reference Table

TokenMeaning
WHITE_SPACEWhitespace
SLASHSlash
IDENT_SERIESIdent series
IDENT_NUMBERIdent number
IDENT_YEARIdent year
IDENT_TYPEIdent type
IDENT_REF_YEARIdent ref year
IDENT_REF_NUMBERIdent ref number
IDENT_REF_SERIESIdent ref series
UNKNOWNUnknown
QQualifier line
Q_FIRQualifier Flight Information Region
Q_NOTAM_CODEQualifier NOTAM code
Q_TRAFFICQualifier traffic
Q_PURPOSEQualifier purpose
Q_SCOPEQualifier scope
Q_LOWERQualifier lower flight level
Q_UPPERQualifier upper flight level
Q_COORDINATESQualifier coordinates
Q_RADIUSQualifier coordinates radius
AICAO line
A_LOCATIONICAO location indicator of the aerodrome or FIR
A_LOCATION_2ICAO location indicator of the aerodrome or FIR
A_EXTRAICAO extra
BEffective period line
B_DATE_TIMEEffective period date time
CEnd effective period line
C_PERMANENTis permanent
C_ESTIMATEis estimate
C_DATE_TIMECancellation date time
DSchedule line
D_SCHEDULESchedule
EMain body line
E_TEXTMain body text
FLower level line.
F_LEVELLower level
F_SFCLower level is Surface
GUpper level line
G_LEVELUpper level
G_UNLUpper level is Unlimited

Full Example

$notam_string = 'J2187/22 NOTAMN' .
                'Q) YBBB/QMXLC/IV/M/A/000/999/2738S15243E005' .
                'A) YAMB' .
                'B) 2207062200 C) 2207070400' .
                'E) TWY Z NOT AVBL DUE PARKED ACFT';

$tokens = \LFour\notam\NotamFunctions::tokenize_notam($notam_string);
print_r($tokens);

$token = $tokens[0];
$value = substr($notam_string, $token->start, $token->end - $token->start);
print_r($value);

$notam = \LFour\notam\NotamFunctions::object_from_tokens($tokens, $notam_string);
print_r($notam->ident->series);