4.3.4 • Published 2 years ago

bifrost-common v4.3.4

Weekly downloads
10
License
ISC
Repository
-
Last release
2 years ago

bifrost-common

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

Installation

npm i bifrost-common

Components

BasicBifrostModule

A base class for simple BIFROST modules.

import { BasicBifrostModule } from 'bifrost-common'

const newModule = new BasicBifrostModule({
    moduleId            : 'NewModule',
    moduleDescription   : 'A simple template module',
    author              : 'rmos'
})

newModule.start()

Log

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

const { Log } = require('bifrost-common')

const log = new Log('myComponent', 'myApplication', options)

log.write(`Abandon ship`, Log.level.WARNING)
log.write(`Run like hell`, Log.level.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: 1m): maximum size of the log files, after which a new file will be started
  • 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.

const { idOfRef } = require('bifrost-common')

console.log(idOfRef({ A: { id: '1' }}, '/A')) // '1'
console.log(idOfRef({ A: { B: {} }}, '/A/B')) // 'B'

tokens

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

const { tokens } = require('bifrost-common')

console.log(tokens.tkId) // "id"

select

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

const { select } = require('bifrost-common')

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

safepointer

A wrapper around json-pointer 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

const { safepointer } = require('bifrost-common')
.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

const { select } = require('bifrost-common')

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.

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

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

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

2 years ago

4.2.8

2 years ago

4.3.2

2 years ago

4.3.1

2 years ago

4.2.10

2 years ago

4.3.4

2 years ago

4.2.11

2 years ago

4.3.3

2 years ago

4.2.12

2 years ago

4.3.0

2 years ago

4.2.13

2 years ago

4.2.14

2 years ago

4.2.3

2 years ago

4.2.2

2 years ago

4.2.5

2 years ago

4.2.4

2 years ago

4.2.1

2 years ago

4.2.0

2 years ago

4.2.7

2 years ago

4.2.6

2 years ago

4.1.0

2 years ago

4.0.5

2 years ago

4.0.4

2 years ago

4.0.3

2 years ago

4.0.2

2 years ago

4.0.1

2 years ago

4.0.0

2 years ago

3.0.4

2 years ago

3.0.13

2 years ago

3.0.3

2 years ago

3.0.10

2 years ago

3.0.2

2 years ago

3.0.11

2 years ago

3.0.16

2 years ago

3.0.8

2 years ago

3.0.7

2 years ago

3.0.14

2 years ago

3.0.6

2 years ago

3.0.15

2 years ago

3.0.5

2 years ago

3.0.9

2 years ago

2.0.19

2 years ago

2.0.20

2 years ago

2.0.18

3 years ago

2.0.17

3 years ago

2.0.15

3 years ago

2.0.16

3 years ago

2.0.14

3 years ago

2.0.13

3 years ago

2.0.12

3 years ago

2.0.11

3 years ago

2.0.9

3 years ago

2.0.8

3 years ago

2.0.7

3 years ago

2.0.5

3 years ago

2.0.6

3 years ago

2.0.4

3 years ago

2.0.3

3 years ago

2.0.2

3 years ago

2.0.1

3 years ago

2.0.0

3 years ago

1.1.18

3 years ago

1.1.17

4 years ago

1.1.16

4 years ago

1.1.15

4 years ago

1.1.14

4 years ago

1.1.13

4 years ago

1.1.12

4 years ago

1.1.11

4 years ago

1.1.9

4 years ago

1.1.10

4 years ago

1.1.8

4 years ago

1.1.7

4 years ago

1.1.6

4 years ago

1.1.5

4 years ago

1.1.4

4 years ago

1.1.3

4 years ago

1.1.2

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago