Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

twpayne/g-record

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

G-record

IGC G-record signing proof of concept

Copyright © Tom Payne 2010

Quick start

Dependencies

  • OpenSSL development files (package libssl-dev on Ubuntu)

Building

Run make.

Usage

genkey

genkey filename generates a random signing key in filename. It is automatically compiled and invoked during the build process.

sign-xtp

sign-xtp copies its standard input to its standard output and appends a one line G-record. The G-record is one line hexadecimal encoding of the HMAC-SHA256 of the data read.

vali-xtp

vali-xtp reads a single file, calculates its HMAC-SHA256 and compares this to the G-record found at the end. If the file validates successfully then it prints Validation check passed, data indicated as correct and returns 0 (success), otherwise it prints Validation check failed and returns 1 (failure).

Example

  1. Build the software:

    $ make
    
  2. Create a file to sign. Note that lines beginning with "G" will be interpreted as invalid G-records, causing validation to fail.

    $ $EDITOR example.igc
    
  3. Sign it with sign-xtp:

    $ ./sign-xtp < example.igc > example.igc.g
    
  4. Verify the signature with vali-xtp:

    $ ./vali-xtp example.igc.g
    Validation check passed, data indicated as correct
    
  5. Modify the signed file:

    $ $EDITOR example.igc.g
    
  6. Check that the signature is no longer valid:

    $ ./vali-xtp example.igc.g
    Validation check failed
    

Known bugs

The G-record generation is inherently insecure because the signing key has to be distributed with the signing program. Practically, the generated G-records can dissuade casual tampering but cannot prevent a technically competent attacker. The attack vectors are, in approximate order of effort:

  • Running the signing program in a controlled environment and connecting a fake GPS.
  • Reverse engineering the program binary or firmware to extract the signing algorithm and key.
  • Generating fake GPS signals :-)

References

About

IGC g-record signing proof of concept

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages