JetStream: Cloud Data Manager - A comprehensive tool for managing local-to-cloud uploads with queue management, statistics, and folder analysis
Project description
NOAA JetStream — Cloud Data Management Transfer System
A comprehensive web-based application for managing Google Cloud Storage uploads with features including job queuing, real-time analytics, cloud bucket analysis, and batch processing capabilities.
Features
- Upload Management
- Analytics & Monitoring
- Cloud Bucket Analysis
- File Filtering
- Web Dashboard
Screenshots
| Dashboard | Upload Jobs | Analytics |
|---|---|---|
Prerequisites
- Python 3.9+
- Google Cloud SDK (includes gsutil) — for cloud upload features
- Permissions to target GCS buckets
Google Cloud Setup
Required only for cloud upload features:
# Install Google Cloud SDK
# Download from: https://cloud.google.com/sdk/docs/install
# Authenticate
gcloud auth login --no-launch-browser
gcloud auth application-default login --no-launch-browser
# Verify access (optional)
gsutil ls
gcloud auth list
Installation
Option 1: Install from PyPI (Recommended)
pip install noaa-jetstream
Using Anaconda/conda? If you see dependency resolver warnings, use
uv(recommended) or--no-cache-dir:# Option A: use uv (faster, cleaner resolver — recommended for conda users) pip install uv uv pip install noaa-jetstream # May need to create virtual environment first, so do it in a local directory then activate uv venv then .venv\Activate\scripts.bat # Option B: skip pip cache pip install --no-cache-dir --no-user noaa-jetstream
Upgrade
uv pip install --no-cache --upgrade noaa-jetstream
Option 2: Install from Source (Development)
# Clone the repository
git clone https://github.com/MichaelAkridge-NOAA/jetstream.git
cd jetstream
# Install in development mode
pip install -e .
# Or using uv (recommended)
pip install uv
uv pip install -e ".[dev]"
# May need to pip install uvicorn, pip install fastapi, pip install google-cloud-storage separately
Starting the Application
If Installed via pip
# Start the server (opens browser automatically)
jetstream
# view options
jetstream --help
# With custom options
jetstream --port 9000
jetstream --host 127.0.0.1 --port 8080
jetstream --no-browser
jetstream --log-level debug
If Running from Source
# Using the CLI
python main.py
# Or with the diagnostic startup script
python start.py
# Or directly with uvicorn
python -m uvicorn jetstream.main:app --reload
The application will start on http://localhost:8000 and automatically open in your default browser.
Desktop Shortcuts
Desktop and Start Menu shortcuts are included with the default install. The shortcut will automatically use the JetStream icon (icon.ico) when created.
# Create desktop + Start Menu shortcut (uses JetStream icon automatically)
jetstream-create-shortcuts
# Remove shortcuts
jetstream-remove-shortcuts
Shortcuts launch JetStream directly using the current Python environment and open a terminal window. On Windows a .lnk shortcut is created on the desktop and in the Start Menu. On macOS/Linux a .app/.desktop shortcut is created in Applications.
Troubleshooting Startup Issues
If the server appears to start but you can't connect:
-
Run diagnostics:
python diagnose.py -
Run with debug logging:
jetstream --log-level debug # or from source: python -m uvicorn jetstream.main:app --reload --log-level debug
Troubleshooting
Cannot connect to GCS:
- Verify authentication:
gcloud auth list - Check bucket permissions
- Ensure Application Default Credentials are set
Jobs stuck in queue:
- Check queue status in dashboard
- Verify no jobs are blocking the queue
- Restart the application if needed
Database errors:
- Delete
jetstream.dbto reset (loses history) - Check file permissions in application directory
API not responding:
- Check if port 8000 is already in use
- View logs in terminal for error messages
- Ensure all dependencies are installed
Disclaimer
This repository is a scientific product and is not official communication of the National Oceanic and Atmospheric Administration, or the United States Department of Commerce. All NOAA GitHub project content is provided on an 'as is' basis and the user assumes responsibility for its use. Any claims against the Department of Commerce or Department of Commerce bureaus stemming from the use of this GitHub project will be governed by all applicable Federal law. Any reference to specific commercial products, processes, or services by service mark, trademark, manufacturer, or otherwise, does not constitute or imply their endorsement, recommendation or favoring by the Department of Commerce. The Department of Commerce seal and logo, or the seal and logo of a DOC bureau, shall not be used in any manner to imply endorsement of any commercial product or activity by DOC or the United States Government.
License
See the LICENSE.md for details
Project details
Release history Release notifications | RSS feed
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 noaa_jetstream-0.1.14.tar.gz.
File metadata
- Download URL: noaa_jetstream-0.1.14.tar.gz
- Upload date:
- Size: 2.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
65dea7f13236a8ff938b4b2477f302b13549924b50729a365755d768a6a9977e
|
|
| MD5 |
878b588ffa782d609be9241fa329af91
|
|
| BLAKE2b-256 |
1f7021c06f2cfd94ba11f990b7b48c08109ae6efa5a39ffd5ea7eaf7be647391
|
Provenance
The following attestation bundles were made for noaa_jetstream-0.1.14.tar.gz:
Publisher:
publish.yml on MichaelAkridge-NOAA/jetstream
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
noaa_jetstream-0.1.14.tar.gz -
Subject digest:
65dea7f13236a8ff938b4b2477f302b13549924b50729a365755d768a6a9977e - Sigstore transparency entry: 1189981948
- Sigstore integration time:
-
Permalink:
MichaelAkridge-NOAA/jetstream@a3aa8383dce797238af252bd9253ab892e7560b3 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MichaelAkridge-NOAA
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a3aa8383dce797238af252bd9253ab892e7560b3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file noaa_jetstream-0.1.14-py3-none-any.whl.
File metadata
- Download URL: noaa_jetstream-0.1.14-py3-none-any.whl
- Upload date:
- Size: 2.9 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7eb009c07a1a3c65261ffb34cdedb643a1d23b5dbbc36c09ba45b3df91d02fc
|
|
| MD5 |
687d4ef4d30d676dec21d55da42832e3
|
|
| BLAKE2b-256 |
ea51e707cac3dd75ae208cb8e4d10261cd2c6b85dd5814fc12169e4d17bced84
|
Provenance
The following attestation bundles were made for noaa_jetstream-0.1.14-py3-none-any.whl:
Publisher:
publish.yml on MichaelAkridge-NOAA/jetstream
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
noaa_jetstream-0.1.14-py3-none-any.whl -
Subject digest:
f7eb009c07a1a3c65261ffb34cdedb643a1d23b5dbbc36c09ba45b3df91d02fc - Sigstore transparency entry: 1189981950
- Sigstore integration time:
-
Permalink:
MichaelAkridge-NOAA/jetstream@a3aa8383dce797238af252bd9253ab892e7560b3 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MichaelAkridge-NOAA
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a3aa8383dce797238af252bd9253ab892e7560b3 -
Trigger Event:
push
-
Statement type: