node-opcua-schemas
Advanced tools
Comparing version 2.5.10 to 2.6.0-alpha.5
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
/** | ||
* @module node-opcua-schemas | ||
*/ | ||
exports.createDynamicObjectConstructor = exports.DynamicExtensionObject = exports.getOrCreateConstructor = void 0; | ||
const node_opcua_assert_1 = require("node-opcua-assert"); | ||
@@ -18,3 +16,2 @@ const node_opcua_debug_1 = require("node-opcua-debug"); | ||
const schema = dataTypeFactory.getStructuredTypeSchema(dataTypeName); | ||
// istanbul ignore next | ||
if (!schema) { | ||
@@ -27,7 +24,5 @@ throw new Error("Unknown type in dictionary " + dataTypeName); | ||
} | ||
// istanbul ignore next | ||
if (!dataTypeFactory.hasStructuredType(dataTypeName)) { | ||
dataTypeFactory.registerClassDefinition(schema.id, dataTypeName, constructor); | ||
return constructor; | ||
// hrow new Error("constructor should now be registered - " + fieldType); | ||
} | ||
@@ -68,3 +63,2 @@ if (encodingDefaultBinary && encodingDefaultBinary.value !== 0) { | ||
if (!obj[field.name].encode) { | ||
// tslint:disable:no-console | ||
console.log(obj.schema.fields, field); | ||
@@ -91,3 +85,2 @@ throw new Error("encodeArrayOrElement: object field " | ||
else { | ||
// construct an instance | ||
const constructor = factory.getStructureTypeConstructor(field.fieldType); | ||
@@ -120,3 +113,2 @@ const element = new constructor({}); | ||
const constructor = factory.getStructureTypeConstructor(field.fieldType); | ||
// getOrCreateConstructor(field.fieldType, factory) || BaseUAObject; | ||
if (field.isArray) { | ||
@@ -132,3 +124,2 @@ const arr = options[name] || []; | ||
} | ||
// xx processStructuredType(fieldSchema); | ||
break; | ||
@@ -147,18 +138,8 @@ } | ||
} | ||
/** | ||
* @private | ||
* @param thisAny | ||
* @param options | ||
* @param schema | ||
* @param factory | ||
*/ | ||
function initializeFields(thisAny, options, schema, factory) { | ||
// initialize base class first | ||
if (schema._baseSchema && schema._baseSchema.fields.length) { | ||
initializeFields(thisAny, options, schema._baseSchema, factory); | ||
} | ||
// finding fields that are in options but not in schema! | ||
for (const field of schema.fields) { | ||
const name = field.name; | ||
// dealing with optional fields | ||
if (field.switchBit !== undefined && options[field.name] === undefined) { | ||
@@ -178,3 +159,2 @@ (thisAny)[name] = undefined; | ||
function _internal_encodeFields(thisAny, schema, stream) { | ||
// encodeFields base class first | ||
if (schema._baseSchema && schema._baseSchema.fields.length) { | ||
@@ -184,3 +164,2 @@ _internal_encodeFields(thisAny, schema._baseSchema, stream); | ||
for (const field of schema.fields) { | ||
// ignore | ||
if (field.switchBit !== undefined && (thisAny)[field.name] === undefined) { | ||
@@ -198,3 +177,2 @@ continue; | ||
default: | ||
/* istanbul ignore next*/ | ||
throw new Error("Invalid category " + field.category + " " + node_opcua_factory_1.FieldCategory[field.category]); | ||
@@ -205,3 +183,2 @@ } | ||
function makeBitField(thisAny, schema, bo) { | ||
// tslint:disable-next-line: prefer-const | ||
let { bitField, offset, allOptional } = schema._baseSchema ? makeBitField(thisAny, schema._baseSchema, bo) : bo; | ||
@@ -218,3 +195,2 @@ let nbOptionalFields = 0; | ||
} | ||
// tslint:disable-next-line:no-bitwise | ||
bitField |= (1 << (field.switchBit + offset)); | ||
@@ -226,3 +202,2 @@ } | ||
const hasOptionalFields = hasOptionalFieldsF(schema); | ||
// ============ Deal with switchBits | ||
if (hasOptionalFields) { | ||
@@ -237,3 +212,2 @@ const { bitField, allOptional } = makeBitField(thisAny, schema, { bitField: 0, offset: 0, allOptional: true }); | ||
function internal_decodeFields(thisAny, bitField, hasOptionalFields, schema, stream, factory) { | ||
// encodeFields base class first | ||
if (schema._baseSchema && schema._baseSchema.fields.length) { | ||
@@ -243,5 +217,3 @@ internal_decodeFields(thisAny, bitField, hasOptionalFields, schema._baseSchema, stream, factory); | ||
for (const field of schema.fields) { | ||
// ignore fields that have a switch bit when bit is not set | ||
if (hasOptionalFields && field.switchBit !== undefined) { | ||
// tslint:disable-next-line:no-bitwise | ||
if ((bitField & (1 << field.switchBit)) === 0) { | ||
@@ -253,3 +225,2 @@ (thisAny)[field.name] = undefined; | ||
if (field.category === node_opcua_factory_1.FieldCategory.complex && (thisAny)[field.name] === undefined) { | ||
// need to create empty structure for deserialisation | ||
initializeField(field, thisAny, {}, schema, factory); | ||
@@ -268,3 +239,2 @@ } | ||
default: | ||
/* istanbul ignore next*/ | ||
throw new Error("Invalid category " + field.category + " " + node_opcua_factory_1.FieldCategory[field.category]); | ||
@@ -275,3 +245,2 @@ } | ||
function decodeFields(thisAny, schema, stream, factory) { | ||
// ============ Deal with switchBits | ||
const hasOptionalFields = hasOptionalFieldsF(schema); | ||
@@ -294,3 +263,2 @@ let bitField = 0; | ||
default: | ||
/* istanbul ignore next*/ | ||
throw new Error("Invalid category " + field.category + " " + node_opcua_factory_1.FieldCategory[field.category]); | ||
@@ -322,38 +290,40 @@ } | ||
const _private = new WeakMap(); | ||
class DynamicExtensionObject extends node_opcua_extension_object_1.ExtensionObject { | ||
constructor(options, schema, factory) { | ||
node_opcua_assert_1.assert(schema, "expecting a schema here "); | ||
node_opcua_assert_1.assert(factory, "expecting a typeDic"); | ||
super(options); | ||
options = options || {}; | ||
_private.set(this, { schema, factory }); | ||
node_opcua_factory_1.check_options_correctness_against_schema(this, this.schema, options); | ||
initializeFields(this, options, this.schema, factory); | ||
} | ||
encode(stream) { | ||
super.encode(stream); | ||
encodeFields(this, this.schema, stream); | ||
} | ||
decode(stream) { | ||
super.decode(stream); | ||
decodeFields(this, this.schema, stream, _private.get(this).factory); | ||
} | ||
get schema() { | ||
const r = _private.get(this); | ||
if (!r) { | ||
console.log("cannot find private stuff for", this.constructor.name); | ||
console.log(new Error()); | ||
let DynamicExtensionObject = (() => { | ||
class DynamicExtensionObject extends node_opcua_extension_object_1.ExtensionObject { | ||
constructor(options, schema, factory) { | ||
node_opcua_assert_1.assert(schema, "expecting a schema here "); | ||
node_opcua_assert_1.assert(factory, "expecting a typeDic"); | ||
super(options); | ||
options = options || {}; | ||
_private.set(this, { schema, factory }); | ||
node_opcua_factory_1.check_options_correctness_against_schema(this, this.schema, options); | ||
initializeFields(this, options, this.schema, factory); | ||
} | ||
return r.schema; | ||
encode(stream) { | ||
super.encode(stream); | ||
encodeFields(this, this.schema, stream); | ||
} | ||
decode(stream) { | ||
super.decode(stream); | ||
decodeFields(this, this.schema, stream, _private.get(this).factory); | ||
} | ||
get schema() { | ||
const r = _private.get(this); | ||
if (!r) { | ||
console.log("cannot find private stuff for", this.constructor.name); | ||
console.log(new Error()); | ||
} | ||
return r.schema; | ||
} | ||
toJSON() { | ||
const pojo = {}; | ||
encodeToJson(this, this.schema, pojo); | ||
return pojo; | ||
} | ||
} | ||
toJSON() { | ||
const pojo = {}; | ||
encodeToJson(this, this.schema, pojo); | ||
return pojo; | ||
} | ||
} | ||
DynamicExtensionObject.schema = node_opcua_extension_object_1.ExtensionObject.schema; | ||
DynamicExtensionObject.possibleFields = []; | ||
return DynamicExtensionObject; | ||
})(); | ||
exports.DynamicExtensionObject = DynamicExtensionObject; | ||
DynamicExtensionObject.schema = node_opcua_extension_object_1.ExtensionObject.schema; | ||
DynamicExtensionObject.possibleFields = []; | ||
// tslint:disable-next-line:max-classes-per-file | ||
class UnionBaseClass extends node_opcua_factory_1.BaseUAObject { | ||
@@ -369,7 +339,5 @@ constructor(options, schema, factory) { | ||
let switchFieldName = ""; | ||
// finding fields that are in options but not in schema! | ||
for (const field of this.schema.fields) { | ||
const name = field.name; | ||
if (field.switchValue === undefined) { | ||
// this is the switch value field | ||
switchFieldName = field.name; | ||
@@ -380,6 +348,3 @@ continue; | ||
node_opcua_assert_1.assert(field.switchValue !== undefined, "union schema must only have one switched value field"); | ||
// dealing with optional fields | ||
/* istanbul ignore next */ | ||
if (uniqueFieldHasBeenFound && options[field.name] !== undefined) { | ||
// let try to be helpful for the developper by providing some hint | ||
debugLog(this.schema); | ||
@@ -391,3 +356,2 @@ throw new Error("union must have only one choice in " + JSON.stringify(options) + | ||
if (options[switchFieldName] !== undefined) { | ||
// then options[switchFieldName] must equal | ||
if (options[switchFieldName] !== field.switchValue) { | ||
@@ -398,3 +362,2 @@ continue; | ||
else { | ||
// the is no switchFieldName , in this case the i | ||
if (options[name] === undefined) { | ||
@@ -409,3 +372,2 @@ continue; | ||
const constuctor = factory.getStructureTypeConstructor(field.fieldType); | ||
// getOrCreateConstructor(field.fieldType, factory) || BaseUAObject; | ||
if (field.isArray) { | ||
@@ -417,3 +379,2 @@ this[name] = (options[name] || []).map((x) => constuctor ? new constuctor(x) : null); | ||
} | ||
// xx processStructuredType(fieldSchema); | ||
break; | ||
@@ -438,7 +399,4 @@ } | ||
const r = schema.fields.filter((f) => f.switchValue !== undefined).map((f) => f.name).join(" , "); | ||
// it is possible also that the switchfield value do not correspond to a valid field | ||
const foundFieldForSwitchValue = schema.fields.findIndex((f) => f.switchValue !== undefined && f.switchValue === options[switchFieldName]); | ||
if (foundFieldForSwitchValue) { | ||
// throw new Error(this.schema.name + ": cannot find field with value " | ||
// + options[switchFieldName]); | ||
} | ||
@@ -471,3 +429,2 @@ else { | ||
default: | ||
/* istanbul ignore next*/ | ||
throw new Error("Invalid category " + field.category + " " + node_opcua_factory_1.FieldCategory[field.category]); | ||
@@ -496,3 +453,2 @@ } | ||
default: | ||
/* istanbul ignore next*/ | ||
throw new Error("Invalid category " + field.category + " " + node_opcua_factory_1.FieldCategory[field.category]); | ||
@@ -533,12 +489,13 @@ } | ||
const possibleFields = schema.fields.map((x) => x.name); | ||
// tslint:disable-next-line:max-classes-per-file | ||
class UNION extends UnionBaseClass { | ||
constructor(options) { | ||
super(options, schema, factory); | ||
node_opcua_assert_1.assert(this.schema === schema); | ||
let UNION = (() => { | ||
class UNION extends UnionBaseClass { | ||
constructor(options) { | ||
super(options, schema, factory); | ||
node_opcua_assert_1.assert(this.schema === schema); | ||
} | ||
} | ||
} | ||
UNION.possibleFields = possibleFields; | ||
UNION.schema = schema; | ||
// to do : may be remove DataType suffix here ? | ||
UNION.possibleFields = possibleFields; | ||
UNION.schema = schema; | ||
return UNION; | ||
})(); | ||
Object.defineProperty(UNION, "name", { value: schema.name }); | ||
@@ -579,21 +536,22 @@ return UNION; | ||
} | ||
// tslint:disable-next-line:max-classes-per-file | ||
class EXTENSION extends BaseClass { | ||
constructor(options, schema2, factory2) { | ||
super(options, schema2 ? schema2 : schema, factory2 ? factory2 : dataTypeFactory); | ||
let EXTENSION = (() => { | ||
class EXTENSION extends BaseClass { | ||
constructor(options, schema2, factory2) { | ||
super(options, schema2 ? schema2 : schema, factory2 ? factory2 : dataTypeFactory); | ||
} | ||
toString() { | ||
return super.toString(); | ||
} | ||
toJSON() { | ||
const pojo = {}; | ||
encodeToJson(this, this.schema, pojo); | ||
return pojo; | ||
} | ||
} | ||
toString() { | ||
return super.toString(); | ||
} | ||
toJSON() { | ||
const pojo = {}; | ||
encodeToJson(this, this.schema, pojo); | ||
return pojo; | ||
} | ||
} | ||
EXTENSION.encodingDefaultXml = new node_opcua_nodeid_1.ExpandedNodeId(node_opcua_nodeid_1.NodeIdType.NUMERIC, 0, 0); | ||
EXTENSION.encodingDefaultBinary = new node_opcua_nodeid_1.ExpandedNodeId(node_opcua_nodeid_1.NodeIdType.NUMERIC, 0, 0); | ||
EXTENSION.possibleFields = possibleFields; | ||
EXTENSION.schema = schema; | ||
// to do : may be remove DataType suffix here ? | ||
EXTENSION.encodingDefaultXml = new node_opcua_nodeid_1.ExpandedNodeId(node_opcua_nodeid_1.NodeIdType.NUMERIC, 0, 0); | ||
EXTENSION.encodingDefaultBinary = new node_opcua_nodeid_1.ExpandedNodeId(node_opcua_nodeid_1.NodeIdType.NUMERIC, 0, 0); | ||
EXTENSION.possibleFields = possibleFields; | ||
EXTENSION.schema = schema; | ||
return EXTENSION; | ||
})(); | ||
Object.defineProperty(EXTENSION, "name", { value: schema.name }); | ||
@@ -600,0 +558,0 @@ schemaPriv.$Constructor = EXTENSION; |
"use strict"; | ||
function __export(m) { | ||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; | ||
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||
if (k2 === undefined) k2 = k; | ||
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); | ||
}) : (function(o, m, k, k2) { | ||
if (k2 === undefined) k2 = k; | ||
o[k2] = m[k]; | ||
})); | ||
var __exportStar = (this && this.__exportStar) || function(m, exports) { | ||
for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p); | ||
} | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
__export(require("./parse_binary_xsd")); | ||
__export(require("./dynamic_extension_object")); | ||
__export(require("./toTypeScript")); | ||
__export(require("./tools")); | ||
__exportStar(require("./parse_binary_xsd"), exports); | ||
__exportStar(require("./dynamic_extension_object"), exports); | ||
__exportStar(require("./toTypeScript"), exports); | ||
__exportStar(require("./tools"), exports); | ||
//# sourceMappingURL=index.js.map |
@@ -1,4 +0,1 @@ | ||
/** | ||
* @module node-opcua-schemas | ||
*/ | ||
import { DataTypeFactory } from "node-opcua-factory"; | ||
@@ -5,0 +2,0 @@ import { NodeId } from "node-opcua-nodeid"; |
"use strict"; | ||
/** | ||
* @module node-opcua-schemas | ||
*/ | ||
// tslint:disable:no-console | ||
// tslint:disable:object-literal-sort-keys | ||
// tslint:disable:no-empty | ||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||
@@ -18,2 +12,3 @@ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.parseBinaryXSDAsync = exports.parseBinaryXSD = exports.TypeDictionary = void 0; | ||
const chalk = require("chalk"); | ||
@@ -96,3 +91,2 @@ const node_opcua_assert_1 = require("node-opcua-assert"); | ||
exports.TypeDictionary = TypeDictionary; | ||
/* tslint:disable:object-literal-shorthand */ | ||
const state0 = { | ||
@@ -115,3 +109,2 @@ init: () => { | ||
finish: function () { | ||
// _register_namespace_uri(this.text); | ||
if (doDebug) { | ||
@@ -183,3 +176,2 @@ debugLog("Import NameSpace = ", this.attrs.Namespace, " Location", this.attrs.Location); | ||
if (this.attrs.SourceType) { | ||
// ignore this field, This is a repetition of the base type field with same name | ||
return; | ||
@@ -197,3 +189,2 @@ } | ||
if (field.fieldType === "opc:Bit") { | ||
// do something to collect bits but ignore them as field | ||
structuredType.bitFields = structuredType.bitFields || []; | ||
@@ -213,6 +204,4 @@ const length = this.attrs.Length || 1; | ||
if (this.attrs.SwitchField) { | ||
// field is optional and can be omitted | ||
const switchField = this.attrs.SwitchField; | ||
if (this.attrs.SwitchValue) { | ||
// we are in a union | ||
field.switchValue = parseInt(this.attrs.SwitchValue, 10); | ||
@@ -248,3 +237,2 @@ if (doDebug) { | ||
parser.parseString(xmlString, (err) => { | ||
// resolve and prepare enumerations | ||
for (const key in typeDictionary.enumeratedTypesRaw) { | ||
@@ -265,3 +253,2 @@ if (!typeDictionary.enumeratedTypesRaw.hasOwnProperty(key)) { | ||
} | ||
// create area in navigation order | ||
function createExplorationOrder() { | ||
@@ -303,3 +290,2 @@ const array = []; | ||
} | ||
// resolve complex types | ||
const schemaInVisitingOrder = createExplorationOrder(); | ||
@@ -306,0 +292,0 @@ for (const structuredType of schemaInVisitingOrder) { |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.getOrCreateStructuredTypeSchema = void 0; | ||
const node_opcua_factory_1 = require("node-opcua-factory"); | ||
@@ -17,3 +18,2 @@ const dynamic_extension_object_1 = require("./dynamic_extension_object"); | ||
function _adjustFieldTypeName(fieldTypeName) { | ||
// special cases | ||
if (fieldTypeName === "String" || fieldTypeName === "CharArray") { | ||
@@ -32,3 +32,2 @@ fieldTypeName = "UAString"; | ||
} | ||
// construct it ! | ||
const structuredType = typeDictionary.getStructuredTypesRawByName(_name); | ||
@@ -54,7 +53,5 @@ if (!structuredType) { | ||
else { | ||
// must be a structure then .... | ||
field.category = node_opcua_factory_1.FieldCategory.complex; | ||
field.schema = _getOrCreateStructuredTypeSchema(fieldTypeName); | ||
if (!field.schema) { | ||
// tslint:disable-next-line:no-console | ||
console.log("cannot find schema for ", fieldTypeName); | ||
@@ -76,6 +73,4 @@ } | ||
field.category = node_opcua_factory_1.FieldCategory.basic; | ||
// try in this | ||
field.schema = _getOrCreateStructuredTypeSchema(fieldTypeName); | ||
if (!field.schema) { | ||
// tslint:disable-next-line:no-console | ||
console.log("What should I do ??", fieldTypeName, " ", node_opcua_factory_1.hasStructuredType(fieldTypeName)); | ||
@@ -96,3 +91,2 @@ } | ||
field.fieldType = "NumericRange"; | ||
// xx console.log(" NumericRange detected here !"); | ||
} | ||
@@ -99,0 +93,0 @@ else { |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.toTypeScript = void 0; | ||
function toTypeScript(dataTypeFactory) { | ||
@@ -14,6 +15,4 @@ const enumeratedTypes = dataTypeFactory._enumerations; | ||
const l = []; | ||
// enumeration | ||
for (const e of Object.values(enumeratedTypes)) { | ||
l.push(`export enum ${e.name} {`); | ||
// console.log((e.typedEnum as any).enumItems); | ||
for (const v of Object.entries(e.enumValues)) { | ||
@@ -31,3 +30,2 @@ const vv = parseInt(v[0], 10); | ||
var _a; | ||
// base type first | ||
const b = o.baseType; | ||
@@ -43,6 +41,4 @@ const bt = (_a = structuredTypes[b]) === null || _a === void 0 ? void 0 : _a.schema; | ||
let switchFieldName = ""; | ||
// find switchFieldName | ||
for (const field of o.fields) { | ||
if (field.switchValue === undefined) { | ||
// this is the switch value field | ||
switchFieldName = field.name; | ||
@@ -52,3 +48,2 @@ break; | ||
} | ||
// export all flavors | ||
for (const field of o.fields) { | ||
@@ -91,3 +86,2 @@ const name = field.name; | ||
} | ||
// objects | ||
for (const o of Object.values(structuredTypes)) { | ||
@@ -94,0 +88,0 @@ if (alreadyDone[o.schema.name]) { |
{ | ||
"name": "node-opcua-schemas", | ||
"version": "2.5.10", | ||
"version": "2.6.0-alpha.5+2620e75a", | ||
"description": "pure nodejs OPCUA SDK - module -schemas", | ||
@@ -13,3 +13,3 @@ "main": "dist/source/index.js", | ||
"dependencies": { | ||
"node-opcua-assert": "2.5.8", | ||
"node-opcua-assert": "^2.5.8", | ||
"node-opcua-binary-stream": "^2.5.9", | ||
@@ -23,3 +23,3 @@ "node-opcua-data-model": "^2.5.10", | ||
"node-opcua-utils": "^2.5.9", | ||
"node-opcua-variant": "^2.5.10", | ||
"node-opcua-variant": "^2.6.0-alpha.5+2620e75a", | ||
"node-opcua-xml2json": "^2.5.9", | ||
@@ -46,3 +46,3 @@ "thenify": "^3.3.0" | ||
"homepage": "http://node-opcua.github.io/", | ||
"gitHead": "f83ada4e88fdeedc0710c5a3b75bbd4b44d9ff76" | ||
"gitHead": "2620e75a3de3fd14b2c084d864e39c3ea7003d10" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
141566
2365
2
1
- Removedansi-regex@2.1.1(transitive)
- Removedbetter-assert@1.0.2(transitive)
- Removedboolbase@1.0.0(transitive)
- Removedcallsite@1.0.0(transitive)
- Removedcss-select@4.3.0(transitive)
- Removedcss-what@6.1.0(transitive)
- Removeddom-converter@0.2.0(transitive)
- Removeddom-serializer@1.4.1(transitive)
- Removeddomelementtype@2.3.0(transitive)
- Removeddomhandler@4.3.1(transitive)
- Removeddomutils@2.8.0(transitive)
- Removedentities@2.2.0(transitive)
- Removedhtmlparser2@6.1.0(transitive)
- Removedlodash@4.17.21(transitive)
- Removednode-opcua-assert@2.5.8(transitive)
- Removednth-check@2.1.1(transitive)
- Removedpretty-error@2.1.2(transitive)
- Removedrenderkid@2.0.7(transitive)
- Removedstrip-ansi@3.0.1(transitive)
- Removedutila@0.4.0(transitive)
Updatednode-opcua-assert@^2.5.8