Skip to main content

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()):
    1. Path provided as argument or config.json in the current directory.
    2. $HOME/.jgt/config.json.
    3. /etc/jgt/config.json.
    4. Environment variables:
      • JGT_CONFIG_JSON_SECRET (entire JSON string)
      • JGT_CONFIG (JSON string)
      • JGT_CONFIG_PATH (path to a JSON file)
  • Use export_env=True to export keys as environment variables.
  • Use demo=True to replace credentials with *_demo values if present.

settings.json

  • Used for general settings and patterns.
  • Lookup/merge order (as implemented in jgtcommon.load_settings()):
    1. /etc/jgt/settings.json and env JGT_SETTINGS_SYSTEM
    2. $HOME/.jgt/settings.json and env JGT_SETTINGS_USER
    3. .jgt/settings.json in current directory
    4. .jgt/settings.yml, jgt.yml, _config.yml (YAML files)
    5. Env vars: JGT_SETTINGS, JGT_SETTINGS_PROCESS
    6. Custom path via -ls/--settings CLI option
  • Later entries override earlier ones. The merged result is cached.
  • Use jgtset CLI 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

jgtutils-1.0.13.tar.gz (63.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jgtutils-1.0.13-py3-none-any.whl (72.8 kB view details)

Uploaded Python 3

File details

Details for the file jgtutils-1.0.13.tar.gz.

File metadata

  • Download URL: jgtutils-1.0.13.tar.gz
  • Upload date:
  • Size: 63.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.16

File hashes

Hashes for jgtutils-1.0.13.tar.gz
Algorithm Hash digest
SHA256 8eb8b091213aca86d8739efc4d55e17c029ca4af48fb38e51dd113dc2e1b6425
MD5 3b5dd7d1994a4d14d077e05f030e1ce4
BLAKE2b-256 39d47ac3688141f6a6402651b836846aba3ac5e839234713bbd5bbfa7d2eba41

See more details on using hashes here.

File details

Details for the file jgtutils-1.0.13-py3-none-any.whl.

File metadata

  • Download URL: jgtutils-1.0.13-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

Hashes for jgtutils-1.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 c5d08742e7c1f107ce4484241bbdf1ba2e5927aa6a371461ea6a298d4e3719f5
MD5 bcbaa8755a7f3bc3f73e165d74ea93c7
BLAKE2b-256 c2d47fe72c8c4ee521d7d76114f99b44bce174ff237112741fbe52997c4b3e70

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page