Skip to main content

Common python library functions for interacting with BIFROST.

Project description

bifrost-common

A library of commonly used functions to interact with BIFROST. Useful for module developers.

Installation

pip install bifrost-common-py

Components

Log

A module to print nice logging information to the console and, optionally, to files.

from bifrost_common_py.Log import Log

log = Log('myComponent', 'myApplication', options={'maxLogFileSize':1e4, 'enableLogFiles':True})

log.write(`Abandon ship`, Log.WARNING)
log.write(`Run like hell`, Log.INFO)

Log levels are DEBUG, INFO, WARNING, ERROR, FAILURE

Allowed options are:

  • enableLogFiles (default: false): log to files as well as the console
  • logDir (default: log): the log file directory (will be created as necessary)
  • maxLogFileSize (default: 0): maximum byte size of the log files, after which a new file will be started, default =0 never rollover
  • maxArchiveSize(default: 5): maximum number of log files to keep

time

Some useful operations involving time, mostly for formatting Log output.

idOfRef

Resolve the ID contained in an object. If no 'id' field is found in the object pointed to with ref, the last part of the reference is returned instead.

from bifrost_common_py.idOfRef import idOfRef

print(idOfRef({ 'A': { 'id': '1' }}, '/A')) // '1'

tokens

An object collecting string tokens commonly used in the BIFROST state.

import bifrost_common_py.tokens as tokens

print(tokens.tkId) // "id"

select

Selectors returning fully-qualified JSON paths into the BIFROST state.

import bifrost_common_py.pathSelectors as select

print(select.meta())                      # "/meta"
print(select.dynamicId('DYNAMIC-1'))      # "/dynamics/byId/DYNAMIC-1"
print(select.eventParentRef('EVENT-1'))   # "/events/byId/EVENT-1/parentRef"

safepointer

A wrapper that allows to specify default values if paths can not be resolved. This is best used in conjunction with select and a copy of the BIFROST state.

API

import bifrost_common_py.safepointer
.has(obj, path)

Determine whether the fully-qualified JSON pointer path points to something in obj.

safepointer.has({ 'A': { 'B': 1} }, '/A/B') # true
safepointer.has({ 'A': { 'B': 1} }, '/A/C') # false
.get(obj, path, def = null)

Resolve path against obj. If the path does not exist, def is returned instead.

safepointer.get({ 'A': { 'B': 1} }, '/A/B', 0)  # 1
safepointer.get({ 'A': { 'B': 1} }, '/A/C', 0)  # 0

import bifrost_common_py.pathSelectors as select

safepointer.get(state, select.meta(), {}) // { id: ... }

SelectFrom

A declarative state selection library. Use this to select elements from the BIFROST state or from module subscription data.

    from bifrost_common_py.SelectFrom import SelectFrom

    SelectFrom(state).allDynamics().ofType('VOLTAGE-3P').asValueMap()

    SelectFrom(subs).allEntries().ofType('CLIMATE-MODEL').asValueList()

    SelectFrom(subs, state).allEntries().withParentOfType('WEATHER').asValueMap()

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

bifrost_common_py-0.8.tar.gz (18.4 kB view details)

Uploaded Source

Built Distribution

bifrost_common_py-0.8-py3-none-any.whl (20.1 kB view details)

Uploaded Python 3

File details

Details for the file bifrost_common_py-0.8.tar.gz.

File metadata

  • Download URL: bifrost_common_py-0.8.tar.gz
  • Upload date:
  • Size: 18.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for bifrost_common_py-0.8.tar.gz
Algorithm Hash digest
SHA256 5f0993acc3eacb81680e0faf183b35da7b0acb9058753e3f796ca79a89d87ebf
MD5 e577f4fdf33c74b8050e5d8b82f5e5a5
BLAKE2b-256 953ea6e9221c9edc2bb007db5ff985fe8184c202a3f0747f23de56066ef0eb1d

See more details on using hashes here.

File details

Details for the file bifrost_common_py-0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for bifrost_common_py-0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 accc2800fd6d705fde52e98b67e11b86850def3fec4a7b19e9431d00c186f64b
MD5 0a344f4e1a7b3b431e7f26a534041f35
BLAKE2b-256 f25db2ff8d95067d943cf11fb5b6ff5e7dfe0fa07d8e53a4c1fe91e430070a96

See more details on using hashes here.

Supported by

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