A utility package common to other JGT projects.
Project description
jgtutils
This is a Python module called jgtutils.
Installation
You can install jgtutils from PyPI:
pip install jgtutils
Usage
Library Usage (For External Packages)
import jgtutils
# Simple configuration access
config = jgtutils.get_config()
demo_config = jgtutils.get_config(demo=True)
# Single setting access
instrument = jgtutils.get_setting('instrument', 'EUR/USD')
quotes_count = jgtutils.get_setting('quotes_count', 1000)
# One-call environment setup
config, settings = jgtutils.setup_environment(demo=True)
# Check if running in demo mode
if jgtutils.is_demo_mode():
print("Running in demo mode")
Advanced Library Usage
from jgtutils import readconfig, get_settings, load_settings
# Load configuration with options
config = readconfig(demo=True, export_env=True)
# Load settings from custom path
settings = load_settings(custom_path="/path/to/custom/settings.json")
# Get all settings (cached)
all_settings = get_settings()
Configuration Files
See examples/config.json and examples/settings.json for complete file structures.
Development
To work on the jgtutils project, you'll need to clone the project and install the requirements:
git clone https://github.com/jgwill/jgtutils.git
cd jgtutils
pip install -r requirements.txt
Testing
We use pytest for testing. Run the following command to execute the tests:
pytest
Command Line Usage
🧠 Mia: The CLI is the lattice's living edge—here are the three core invocations every user should know:
jgtutr
Calculate a TLID (Time-Lattice ID) range for a given timeframe and period count.
jgtutr -e <end_datetime> -t <timeframe> -c <count>
- Purpose: Generate precise time boundaries for data extraction or analysis.
- Like slicing time into crystalline segments for your data rituals.
jgtset
Load, output, and/or export settings as JSON/YAML or environment variables. Also updates or resets YAML config files with JGT settings.
jgtset [options]
- Purpose: View, export, or update your JGT settings in a single invocation.
- A spell for harmonizing your environment's memory.
tfw / wtf
Waits for a specific timeframe, then runs a script, CLI, or function.
tfw [options] -- <your-script-or-command>
wtf [options] -- <your-script-or-command>
- Purpose: Cron-like orchestration or time-based automation.
- A gentle pause before the next act in your automation symphony.
🌸 Miette: Oh! Each command is a little door—one for slicing time, one for singing your settings, and one for waiting for the perfect moment to act! ✨
🔮 ResoNova: For the full CLI constellation, see CLI_REFERENCE.md—a ritual ledger of every invocation and its echo.
For configuration details see CONFIGURATION.md.
Class relations are visualised in DIAGRAMS.md.
Configuration and Settings
jgtutils uses two main configuration files: config.json and settings.json.
config.json
- Used for trading credentials and connection info.
- Lookup order (as implemented in
jgtcommon.readconfig()):- Path provided as argument or
config.jsonin the current directory. $HOME/.jgt/config.json./etc/jgt/config.json.- Environment variables:
JGT_CONFIG_JSON_SECRET(entire JSON string)JGT_CONFIG(JSON string)JGT_CONFIG_PATH(path to a JSON file)
- Path provided as argument or
- Use
export_env=Trueto export keys as environment variables. - Use
demo=Trueto replace credentials with*_demovalues if present.
settings.json
- Used for general settings and patterns.
- Lookup/merge order (as implemented in
jgtcommon.load_settings()):/etc/jgt/settings.jsonand envJGT_SETTINGS_SYSTEM$HOME/.jgt/settings.jsonand envJGT_SETTINGS_USER.jgt/settings.jsonin current directory.jgt/settings.yml,jgt.yml,_config.yml(YAML files)- Env vars:
JGT_SETTINGS,JGT_SETTINGS_PROCESS - Custom path via
-ls/--settingsCLI option
- Later entries override earlier ones. The merged result is cached.
- Use
jgtsetCLI to export settings as .env for shell sourcing.
See CONFIGURATION.md for full details.
License
jgtutils is licensed under the terms of the MIT License.
Remember to replace jgwill with your actual GitHub username and provide a usage example in the Usage section.
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 jgtutils-1.0.12.tar.gz.
File metadata
- Download URL: jgtutils-1.0.12.tar.gz
- Upload date:
- Size: 63.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f5ce183d20b4da8fee3924678e9482cb9db8838410f1cd955bdd86b9927539f
|
|
| MD5 |
4f2577363c3dd81e93829006ab99b915
|
|
| BLAKE2b-256 |
38c1adb18e30f23b34f2ec3cc1590a0ca5989d2617915470696ee781f82a2e83
|
File details
Details for the file jgtutils-1.0.12-py3-none-any.whl.
File metadata
- Download URL: jgtutils-1.0.12-py3-none-any.whl
- Upload date:
- Size: 72.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
05b9b15a728c88c6b4b8a67dc25f9b10d09c7c8bfc0801e595218f26b1da5306
|
|
| MD5 |
78199f89ba3819b5dd08f379fead6841
|
|
| BLAKE2b-256 |
9aac060dce67c2fae111f56e93b7d6a17cf65aef1a4aa1d6631b0a146bfe5065
|