The flight-pipeline mechanism allows for uploading new flights to the STAC index using the ElasticSearch client. The flight-pipeline scripts push new records that are not currently in the index and can remove or archive pushed records on the local system.
Project description
flight-pipeline
Repository for python code to concatenate data sources and construct new flight records for CEDA flight-finder
Objectives:
- Mechanism for uploading new flights to stac index
- Use ES Client to determine array of ids that currently exists in the index
- Push new records that are not currently in the index
- Remove or archive pushed records on local system
Installation:
You can either install the PyPi package through pip or clone the GitHub repository. The two options can be found below.
1. Install using pip
- Run
pip install ceda-flight-pipeline - Install requirements into a local virtual environment using
Poetry:poetry install
- Configure dirconfig with relative paths
OR
2. Install by cloning GitHub repository
- Clone the repository from github by running
git clone https://github.com/cedadev/flight-pipeline.git - Install requirements into a local virtual environment using
Poetry:poetry install
- Configure dirconfig with relative paths
Setting up environment variables
In order to run the flight-pipeline project, you will need the following variables in your environment.
CONFIG_FILE=/path/to/your/dir/config/dirconfig
STAC_TEMPLATE=/path/to/your/dir/config/stac_template.json
SETTINGS_FILE=/path/to/your/dir/config/settings.json
In bash you can run:
export CONFIG_FILE=/path/to/your/dir/config/dirconfig
Running the program
1. Use stac_template to write new records
Follow the STAC template json file to create new flight records (more details further down)
2. Configure dirconfig file
Add on lines 2 and 4 the directory paths to where your new flights to push are stored, and where the pushed flights should go once they have been uploaded to the index (store them or write DELETE to remove them from the local system). Update line 6 with a directory path to a logfile.
3. Push New Flights
Run with command flight-pipeline flight-update with a filled in dirconfig file to push new records to the index.
Or run with command flight-pipeline flight-update --archive_path ../../ --flights_dir ../../ --add_mode y --update_mode n --update_id n
Update Existing Flights
Note: In case of repair or adjustment to existing records, the individual records can be updated in place.
Run with command python flight_update.py update <pyfile>, where pyfile is a python file containing an update function that can be applied to each record in elasticsearch.
STAC Template
From the template, the following should be filled in:
- id (fnum/pcode * date)
- es_id (random string of ASCII characters to generate one of 9 colours in flight finder)
- description_path
- collection
- geometry.display.coordinates
- geometry.display.type (if coordinates are not MultiLineString)
- properties:
- data_format
- start_datetime
- end_datetime
- flight_num (if applicable)
- pcode (if applicable)
- aircraft
- variables
- location
- platform
- instruments
- pi
Geometries Development
Correct Version of mapping that exists in the arsf index
"spatial" : {
"properties" : {
"geometries" : {
"properties" : {
"display" : {
"properties" : {
"coordinates" : {
"type" : "double",
"index" : false
},
"type" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
},
"full_search" : {
"type" : "geo_shape"
},
"search" : {
"type" : "geo_shape"
}
}
}
}
Incorrect version currently in stac-flightfinder-items
"geometry" : {
"properties" : {
"display" : {
"properties" : {
"coordinates" : {
"type" : "float"
},
"type" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
},
"geometries" : {
"properties" : {
"display" : {
"properties" : {
"coordinates" : {
"type" : "float"
},
"type" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
},
"search" : {
"properties" : {
"coordinates" : {
"type" : "float"
},
"type" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
}
}
},
"search" : {
"properties" : {
"coordinates" : {
"type" : "float"
},
"type" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
}
}
}
Ammendments:
- Remove geometries subfield.
- Remove all subfields of search and just add
"type":"geo_shape". - Add full_search sub_field with
"type":"geo_shape".
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ceda_flight_pipeline-1.2.0.tar.gz.
File metadata
- Download URL: ceda_flight_pipeline-1.2.0.tar.gz
- Upload date:
- Size: 29.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.9.21 Darwin/24.5.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
26d2221b44cd1139ce0e9d6962d9ee1b20417f9fb6d1e77fc666a0684e12361e
|
|
| MD5 |
4f154cf3416bf17d23ec9e722938bca4
|
|
| BLAKE2b-256 |
8fa345cfe9e0c6275506e097948a9b3a3a3e998ae3c62ecc3c14476554f49afd
|
File details
Details for the file ceda_flight_pipeline-1.2.0-py3-none-any.whl.
File metadata
- Download URL: ceda_flight_pipeline-1.2.0-py3-none-any.whl
- Upload date:
- Size: 31.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.9.21 Darwin/24.5.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca1983d228fe2b546f8cc09927a04bb1892d5d4a35266c6a5e2506bb3813a368
|
|
| MD5 |
ed95a984bed396c6851eeb551f0984e3
|
|
| BLAKE2b-256 |
bd73f97e828ed4187ed71015818ab615c098b4f8c05789e86c97dc0ce5e7db58
|